Node.js-Firebase Functions Database onCreate不触发

时间:2018-08-03 19:03:43

标签: javascript node.js firebase firebase-realtime-database google-cloud-functions

当我在实时数据库的updates / GmB71KB6lXbYOfGLKNkUgIdiLb42目录中创建一个孩子时,我试图触发Firebase Function,但是它没有触发。

当我将其放入Cloud Storage触发器中时,它可以工作,并且我的打印内容显示在日志中,但是当我将其放回到onCreate触发器中时,它再次停止工作。任何指针将不胜感激。

编辑:后续问题-如果我需要将我的触发器从实时数据库触发器更改为云存储触发器,则是前1-2行(functions.database.ref(...)。onCreate- > functions.storage.object()。onFinalize)我需要修改的所有内容?

编辑2:在进一步调查中,我发现如果将触发器类型更改为onDelete,onWrite或onUpdate,则会触发该触发器。当我尝试使用context.eventType找出onWrite的事件类型时,它会一直以未定义状态返回。

exports.kairosDatabaseTrigger = functions.database.ref('/updates/GmB71KB6lXbYOfGLKNkUgIdiLb42/')
.onCreate((snapshot) => {

    console.log("Starting kairos trigger")

    const content = snapshot.val;
    const photos = content.photoUrls;

    for(i = 0; i < photos.length; i++) {

        const tempPath = path.join(os.tmpdir(), path.basename(url));
        downloadIMG(photos[i], tempPath);

        base64str = base64_encode(tempPath);
        var options = {
            method: 'POST',
            uri: 'https://api.kairos.com/recognize',
            body: {
                'image': base64str,
                'gallery_name': 'gallerytest1'
            },
            headers: {
                'app_id': 'xxxxxx',
                'app_key': 'xxxxxxxxx'
            },
            json: true
        }

        request(options)
        .then(function(repos) { 
            console.log('API call succeeded');

            console.log(repos)

        })
        .catch(function (err) {
            // API call failed...
            console.log('API call failed');
        })

    }

});

1 个答案:

答案 0 :(得分:1)

只是发现发生了什么事。我正在寻找在updates / GmB71KB6lXbYOfGLKNkUgIdiLb42目录中发布的更新,因此我需要指定一个通配符来捕获节点本身。代替:

exports.kairosDatabaseTrigger = functions.database.ref('/updates/GmB71KB6lXbYOfGLKNkUgIdiLb42/').onCreate((snapshot) => {

应该是:

exports.kairosDatabaseTrigger = functions.database.ref('/updates/GmB71KB6lXbYOfGLKNkUgIdiLb42/{updateID}').onCreate((snapshot) => {