针对崩解的Firebase云功能未触发

时间:2018-03-19 16:29:01

标签: javascript firebase google-cloud-functions crashlytics

因此,我们有一个项目,其中设置了Crashlytics和分析并且当前正在运行。但是,我无法为此处的三个触发器成功实现云功能:Crashlytics Events

在使用其他云功能进行测试时,例如在数据库上有读/写操作时,函数可以正确执行。在将函数文件夹部署到firebase时,我没有得到任何关于触发器的错误,代码与Github上的示例非常相似。我确保SDK是最新的,并且我已经在函数文件夹中为任何依赖项运行了npm install。

这是JS文件:



   
'use strict';

const functions = require('firebase-functions');
const rp = require('request-promise');
const admin = require('firebase-admin');
admin.initializeApp(functions.config().firebase);

// Helper function that posts to Slack about the new issue
const notifySlack = (slackMessage) => {
  // See https://api.slack.com/docs/message-formatting on how
  // to customize the message payload
  return rp({
    method: 'POST',
    uri: functions.config().slack.webhook_url,
    body: {
      text: slackMessage,
    },
    json: true,
  });
};

exports.postOnNewIssue = functions.crashlytics.issue().onNewDetected((event) => {
  const data = event.data;

  const issueId = data.issueId;
  const issueTitle = data.issueTitle;
  const appName = data.appInfo.appName;
  const appPlatform = data.appInfo.appPlatform;
  const latestAppVersion = data.appInfo.latestAppVersion;

  const slackMessage = `<!here|here> There is a new issue - ${issueTitle} (${issueId}) ` +
      `in ${appName}, version ${latestAppVersion} on ${appPlatform}`;

  return notifySlack(slackMessage).then(() => {
    return console.log(`Posted new issue ${issueId} successfully to Slack`);
  });
});

exports.postOnRegressedIssue = functions.crashlytics.issue().onRegressed((event) => {
  const data = event.data;

  const issueId = data.issueId;
  const issueTitle = data.issueTitle;
  const appName = data.appInfo.appName;
  const appPlatform = data.appInfo.appPlatform;
  const latestAppVersion = data.appInfo.latestAppVersion;
  const resolvedTime = data.resolvedTime;

  const slackMessage = `<!here|here> There is a regressed issue ${issueTitle} (${issueId}) ` +
      `in ${appName}, version ${latestAppVersion} on ${appPlatform}. This issue was previously ` +
      `resolved at ${new Date(resolvedTime).toString()}`;

  return notifySlack(slackMessage).then(() => {
    return console.log(`Posted regressed issue ${issueId} successfully to Slack`);
  });
});

exports.postOnVelocityAlert = functions.crashlytics.issue().onVelocityAlert((event) => {
  const data = event.data;

  const issueId = data.issueId;
  const issueTitle = data.issueTitle;
  const appName = data.appInfo.appName;
  const appPlatform = data.appInfo.appPlatform;
  const latestAppVersion = data.appInfo.latestAppVersion;
  const crashPercentage = data.velocityAlert.crashPercentage;

  const slackMessage = `<!here|here> There is an issue ${issueTitle} (${issueId}) ` +
      `in ${appName}, version ${latestAppVersion} on ${appPlatform} that is causing ` +
      `${parseFloat(crashPercentage).toFixed(2)}% of all sessions to crash.`;

  return notifySlack(slackMessage)/then(() => {
    console.log(`Posted velocity alert ${issueId} successfully to Slack`);
  });
});
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:0)

当我尝试部署 Crashlytics 事件时,收到以下错误消息。

⚠  functions: failed to update function crashlyticsOnRegressed
HTTP Error: 400, The request has errors
⚠  functions: failed to update function crashlyticsOnNew
HTTP Error: 400, The request has errors
⚠  functions: failed to update function crashlyticsOnVelocityAlert
HTTP Error: 400, The request has errors

果然,Cloud Function documentation 不再列出 Crashlytics,它曾经在 Crashlytics triggers 部分下。也许 Google 不再支持它。