2

TwitterのRESTAPIと通信するために、Meteorでtwitを使用しようとしています。

単独で呼び出すと、/server/ディレクトリにあるserver.jsファイルなどで正常に機能します。たとえば、オブザーブ内からラップまたは呼び出したり、オブザーブからtwitの関数を呼び出す関数を呼び出したりすると、エラーが発生します。

たとえば、これは/server/server.js内で完全に正常に機能します。

T.post('statuses/update', { status: 'hello world!' }, function(err, reply) {
  console.log('error: ' + JSON.stringify(err,0,4));
  console.log('reply: ' + JSON.stringify(reply,0,4));
});

しかし、レコードが挿入されるたびにTwitterに電話をかけると言いたいとします。

var query = Posts.find({}, {fields: {}});

var handle = query.observe({
added: function(post, before_index){
    if(post.twitter_id_str === undefined || post.twitter_id_str === '' ||
        post.twitter_id_str === null) { 

        T.post('statuses/update', { status: 'hello world!' }, function(err, reply) {
          console.log('error: ' + JSON.stringify(err,0,4));
          console.log('reply: ' + JSON.stringify(reply,0,4));
          if(reply){
            // TODO update record with twitter id_str
                            //  BREAKS here - crash, restart
            console.log('incoming twitter string: ' + reply.id_str);
            Posts.update(
                {_id: post._id},
                {$set:{twitter_id_str:reply.id_str}}
            );
        }
});
    } else {
        console.log('remove me we have it: ' + post.twitter_id_str);
    }   
}
});

このエラーがスローされると、サーバーがクラッシュして再起動しますが、Breakにコメントした場所でコードロジックは実行されません。

app/packages/mongo-livedata/collection.js:215
        throw e;
          ^
Error: Meteor code must always run within a Fiber
    at [object Object].get (app/packages/meteor/dynamics_nodejs.js:14:15)
    at [object Object]._maybeBeginWrite (app/packages/mongo-livedata/mongo_driver.js:68:41)
    at [object Object].update (app/packages/mongo-livedata/mongo_driver.js:191:20)
    at [object Object].update (app/packages/mongo-livedata/collection.js:203:32)
    at app/server/server.js:39:13
    at /usr/lib/meteor/lib/node_modules/twit/lib/oarequest.js:85:16
    at passBackControl (/usr/lib/meteor/lib/node_modules/twit/node_modules/oauth/lib/oauth.js:359:11)
    at IncomingMessage.<anonymous> (/usr/lib/meteor/lib/node_modules/twit/node_modules/oauth/lib/oauth.js:378:9)
    at IncomingMessage.emit (events.js:88:20)
    at HTTPParser.onMessageComplete (http.js:137:23)
Exited with code: 1

要約すると、Twitterコードはそれ自体で正常に動作しますが、Meteorファイバー内では正常に動作しません。私はそれを別の関数に入れて、監視などの中からそれを呼び出してみました...無駄です。

推奨事項やアイデアはありますか?

4

1 に答える 1

4

ファイバーでtwitpostAPI呼び出しを行う必要があります。

Fiber(function(){... twit API呼び出し...})。run()

サーバーでCollection.insertを呼び出すときは、この関連する質問を参照してください:「Meteorコードは常にファイバー内で実行する必要があります」

于 2012-05-06T10:13:50.043 に答える