carloscgo / laravel-twitter-streaming
Easily work with the Twitter Streaming API in a Laravel app
Requires
- php: ^7.0
- illuminate/support: ^5.3
- spatie/twitter-streaming-api: ^1.0.1
Requires (Dev)
- orchestra/testbench: ^3.3
- phpunit/phpunit: 5.*|6.*|7.*
This package is not auto-updated.
Last update: 2024-11-10 06:38:41 UTC
README
Twitter provides a streaming API with which you can do interesting things such as listening for tweets that contain specific strings or actions a user might take (e.g. liking a tweet, following someone,...). This package makes it very easy to work with the API.
TwitterStreaming::publicStream($business_id) ->whenHears('#laravel', function(array $tweet) { echo "{$tweet['user']['screen_name']} tweeted {$tweet['text']}"; }) ->startListening();
Here's an example Laravel application with the package pre-installed. It contains an artisan command to kick off the listening process.
Installation
You can install the package via composer:
composer require carloscgo/laravel-twitter-streaming
You must install this service provider.
// config/app.php 'providers' => [ ... CarlosCGO\LaravelTwitterStreaming\TwitterStreamingServiceProvider::class, ];
This package also comes with a facade, which provides an easy way to call the class.
// config/app.php 'aliases' => [ ... 'TwitterStreaming' => CarlosCGO\LaravelTwitterStreaming\TwitterStreamingFacade::class, ];
The config file must be published with this command:
php artisan vendor:publish --provider="CarlosCGO\LaravelTwitterStreaming\TwitterStreamingServiceProvider" --tag="config"
It will be published in config/laravel-twitter-streaming.php
return [ /** * To work with Twitter's Streaming API you'll need some credentials. * * If you don't have credentials yet, head over to https://apps.twitter.com/ */ 'table' => env('TWITTER_CONFIG_TABLE'), 'where_field_business' => env('TWITTER_FIELD_BUSINESS'), ];
Getting credentials
In order to use this package you'll need to get some credentials from Twitter. Head over to the Application management on Twitter to create an application.
Once you've created your application, click on the Keys and access tokens
tab to retrieve your consumer_key
, consumer_secret
, access_token
and access_token_secret
.
Usage
Currently, this package works with the public stream and the user stream. Both the PublicStream
and UserStream
classes provide a startListening
function that kicks of the listening process. Unless you cancel it your PHP process will execute that function forever. No code after the function will be run.
In the example below a facade is used. If you don't like facades you can replace them with
app(CarlosCGO\LaravelTwitterStreaming\TwitterStreaming::class)
The public stream
The public stream can be used to listen for specific words that are being tweeted.
The first parameter of whenHears
must be a string or an array containing the word or words you want to listen for. The second parameter should be a callable that will be executed when one of your words is used on Twitter.
use TwitterStreaming; TwitterStreaming::publicStream($business_id) ->whenHears('#laravel', function(array $tweet) { echo "{$tweet['user']['screen_name']} tweeted {$tweet['text']}"; }) ->startListening();
The user stream
use TwitterStreaming; TwitterStreaming::userStream($business_id) ->onEvent(function(array $event) { if ($event['event'] === 'favorite') { echo "Our tweet {$event['target_object']['text']} got favorited by {$event['source']['screen_name']}"; } }) ->startListening();
Suggestion on how to run in a production environment
When using this in production you could opt to create an artisan command to listen for incoming events from Twitter. You can use Supervisord to make sure that command is running all the time.
A word to the wise
These APIs work in realtime, so they could report a lot of activity. If you need to do some heavy work processing that activity it's best to put that work in a queue to keep your listening process fast.
Changelog
Please see CHANGELOG for more information what has changed recently.
Testing
$ composer test
Contributing
Please see CONTRIBUTING for details.
License
The MIT License (MIT). Please see License File for more information.