云功能不起作用

时间:2017-06-20 22:00:06

标签: android node.js firebase firebase-cloud-messaging google-cloud-functions

我想向我制作的在线Android聊天应用添加通知。我是云功能的新手,所以我尝试使用这里给出的代码https://firebase.googleblog.com/2016/08/sending-notifications-between-android.html

我的index.js文件

var firebase = require('firebase-admin');
var request = require('request');

var API_KEY = "xyz"; // Your Firebase 
Cloud Messaging Server API key

// Fetch the service account key JSON file contents
var serviceAccount = require("firebase.json");

// Initialize the app with a service account, granting admin privileges
firebase.initializeApp({
credential: firebase.credential.cert(serviceAccount),
  databaseURL: "https://firebaseio.com/"
});
ref = firebase.database().ref();

function listenForNotificationRequests() {
var requests = ref.child('notificationRequests');
requests.on('child_added', function(requestSnapshot) {
var request = requestSnapshot.val();
sendNotificationToUser(
  request.username, 
  request.message,
  function() {
      console.log('notificationrecived, sent and removed- ' + 
request.username + '  '+ request.message,);
    requestSnapshot.ref.remove();
  }
 );
 }, function(error) {
  console.error(error);
 });
 };

 function sendNotificationToUser(username, message, onSuccess) {
 request({
 url: 'https://fcm.googleapis.com/fcm/send',
 method: 'POST',
 headers: {
  'Content-Type' :' application/json',
  'Authorization': 'key='+API_KEY
 },
 body: JSON.stringify({
  notification: {
    title: message
  },
  to : '/topics/'+username
  })
  }, function(error, response, body) {
  if (error) { console.error(error); }
  else if (response.statusCode >= 400) { 
  console.error('HTTP Error: '+response.statusCode+' - ' 
  +response.statusMessage); 
     }
    else {n
    onSuccess();
   }
  }); 
  }

  // start listening
  listenForNotificationRequests();

我已使用node.js命令行将此代码成功部署到服务器。 但这并没有显示在控制台上,也没有显示我添加到调试中的日志 并且代码似乎不起作用。我已经完成了我提到的链接中给出的所有内容。我可以使用一些关于如何修复我的代码的帮助

2 个答案:

答案 0 :(得分:0)

我不知道这有多大差异,但在Firebase管理设置页面https://firebase.google.com/docs/admin/setup中,提到对于云功能,以下行足以进行初始化: - < / p>

var firebase = require('firebase-admin');
firebase.initializeApp(functions.config().firebase);

因此,如果您按照本书的说法进行操作,则可以将代码中的初始化行替换为上面的行,然后再次尝试运行。

答案 1 :(得分:0)

我没有导出我的函数 listenForNotificationRequests(),而是在脚本结束时只调用了一次。 这就是它没有出现在 Firebase 控制台上的原因。

我通过简单地导出这样的函数来解决这个问题

exports.sendFollowerNotification = listenForNotificationRequests;