UNPKG

twitter-stream-channels

Version:

Manage multiple filters on the same Twitter stream

82 lines (63 loc) 2.2 kB
//example of using streams, using directly the twit library (via getApiClient) - with the mock //this time stopping and restarting the stream var TwitterStreamChannels = require('../../main').getMockedClass(); var credentials = require('../../twitter.credentials.json');//not necessary - since using mock credentials.singleRun = false;//to loop indefinitly on the mocked tweets var client = new TwitterStreamChannels(credentials); var connected = false; var stream = client.getApiClient().stream('statuses/filter', {track: ['any,word,in,the,mock,data']}); stream.on('connect', function() { console.log('> attempting to connect to twitter'); }); stream.on('connected', function() { if(connected === false){ console.log('> twitter emit : connected'); connected = true; } }); stream.on('disconnect', function() { console.log('> twitter emit : disconnect'); connected = false; }); stream.on('tweet', function(tweet) { console.log(tweet.$index,tweet.text); }); stream.on('reconnect', function (request, response, connectInterval) { console.log('> waiting to reconnect in '+connectInterval+'ms'); }); setTimeout(function() { stream.stop(); console.log('> stopped stream'); }, 3000); setTimeout(function() { console.log('>> restarting stream for 5 seconds'); stream.start(); }, 8000); setTimeout(function() { console.log('>> stopped stream after 5 seconds'); stream.stop(); }, 13000); setTimeout(function() { stream = client.getApiClient().stream('statuses/filter', {track: ['javascript']}); stream.on('connect', function() { console.log('>>> attempting to connect to twitter'); }); stream.on('connected', function() { console.log('>>> twitter emit : connected'); }); stream.on('disconnect', function() { console.log('>>> twitter emit : disconnect'); process.exit(); }); stream.on('tweet', function(tweet) { console.log(tweet.$index,tweet.text); }); stream.on('reconnect', function (request, response, connectInterval) { console.log('>>> waiting to reconnect in '+connectInterval+'ms'); }); }, 18000); setTimeout(function() { stream.stop(); console.log('>>> stopped stream'); process.exit(); }, 43000);