2017 © Pedro Peláez
 

library laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

image

spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  • Thursday, March 29, 2018
  • by Spatie
  • Repository
  • 5 Watchers
  • 91 Stars
  • 10,388 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 14 Forks
  • 2 Open issues
  • 6 Versions
  • 18 % Grown

The README.md

Easily work with the Twitter Streaming API in a Laravel app

Latest Version on Packagist Software License Total Downloads, (*1)

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., (*2)

TwitterStreamingApi::publicStream()
->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., (*3)

Support us

, (*4)

We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products., (*5)

We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall., (*6)

Installation

You can install the package via composer:, (*7)

``` bash composer require spatie/laravel-twitter-streaming-api, (*8)


The config file must be published with this command: ```bash php artisan vendor:publish --provider="Spatie\LaravelTwitterStreamingApi\TwitterStreamingApiServiceProvider" --tag="config"

It will be published in config/laravel-twitter-streaming-api.php, (*9)

return [

    /*
     * To work with Twitter's Streaming API you'll need some credentials.
     *
     * If you don't have credentials yet, head over to https://developers.twitter.com/
     */

    'handle' => env('TWITTER_HANDLE'),

    'api_key' => env('TWITTER_API_KEY'),

    'api_secret_key' => env('TWITTER_API_SECRET_KEY'),

    'bearer_token' => env('TWITTER_BEARER_TOKEN'),
];

Getting credentials

In order to use this package you'll need to get some credentials from Twitter. Head over to the Developer Portal on Twitter to create an application., (*10)

Once you've created your application, click on the Keys and tokens tab to retrieve your bearer_token, api_key and api_secret_key., (*11)

Keys and tokens tab on Twitter, (*12)

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., (*13)

In the example below a facade is used. If you don't like facades you can replace them with, (*14)

app(Spatie\LaravelTwitterStreamingApi\TwitterStreamingApi::class)

The public stream

The public stream can be used to listen for specific words that are being tweeted., (*15)

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., (*16)

use TwitterStreamingApi;

TwitterStreamingApi::publicStream()
->whenHears('#laravel', function(array $tweet) {
    echo "{$tweet['user']['screen_name']} tweeted {$tweet['text']}";
})
->startListening();

The user stream

use TwitterStreamingApi;

TwitterStreamingApi::userStream()
->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., (*17)

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., (*18)

Changelog

Please see CHANGELOG for more information what has changed recently., (*19)

Testing

bash $ composer test, (*20)

Contributing

Please see CONTRIBUTING for details., (*21)

Security

If you've found a bug regarding security please mail security@spatie.be instead of using the issue tracker., (*22)

Credits

License

The MIT License (MIT). Please see License File for more information., (*23)

The Versions

29/03 2018

dev-master

9999999-dev https://github.com/spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

spatie laravel-twitter-streaming-api

30/10 2017

1.1.0

1.1.0.0 https://github.com/spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

spatie laravel-twitter-streaming-api

13/03 2017

1.0.1

1.0.1.0 https://github.com/spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

spatie laravel-twitter-streaming-api

14/01 2017

1.0.0

1.0.0.0 https://github.com/spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

spatie laravel-twitter-streaming-api

14/01 2017

0.0.2

0.0.2.0 https://github.com/spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

spatie laravel-twitter-streaming-api

14/01 2017

0.0.1

0.0.1.0 https://github.com/spatie/laravel-twitter-streaming-api

Easily work with the Twitter Streaming API in a Laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

spatie laravel-twitter-streaming-api