Skip to content

A library to watch a Twitter profile for any updates to profile information

License

Notifications You must be signed in to change notification settings

conorsmith/Twersona

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

38 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Twersona

A library to watch a Twitter profile for any updates to profile information

This is very much a work in progress.

Installation

Install via Composer. You can use dev-master to get the latest release, but for a production application you should probably explicitly enter a tag eg v0.1.2. Then just make sure your composer.json file looks something like this:

{
    "require": {
        "conorsmith/twersona": "v0.2.0"
    }
}

minimum-stability

If you have set a minimum-stability in your composer.json file (eg a default Laravel composer.json file) you may experience issues attempting to install this package via Composer. One of the dependencies of this package is j7mbo/twitter-api-php, which has only a dev-master version available.

According to this Composer issue the only way to satisfy your minimum stability in this case is to explictly require the dependency in your composer.json file. In that case your file should look something like this:

{
    "require": {
        "conorsmith/twersona": "v0.2.0",
        "j7mbo/twitter-api-php": "dev-master"
    }
}

Setup

If you are using local file storage for caching (the default), ensure that the storage directory is writable.

chmod a+w vendor/conorsmith/twersona/storage/

Basic Usage

$factory = new Twersona\ProfileFactory(array(
    'oauth_access_token' => "...",
    'oauth_access_token_secret' => "...",
    'consumer_key' => "...",
    'consumer_secret' => "...",
));

$twitterProfile = $factory->buildProfile();

echo $twitterProfile->name;       // 'Conor Smith'
echo $twitterProfile->screenName; // 'conorsmith'
echo $twitterProfile->verified;   // false

You can also return a profile object with the exact keys used by the Twitter API, which are not camelCase.

$twitterProfile = $factory->buildFlatProfileWithExactKeys();

echo $twitterProfile->name;        // 'Conor Smith'
echo $twitterProfile->screen_name; // 'conorsmith'
echo $twitterProfile->verified;    // false

Profile Caching

Once the profile is retrieved it is cached. By default this caching is done using local file storage. This is done using the PHP League's Flysystem package, which means you can inject your own filesystem object using a different adapter to store the profile somewhere else.

use Dropbox\Client;
use League\Flysystem\Filesystem;
use League\Flysystem\Adapter\Local as Adapter;

$client = new Client($token, $appName);
$filesystem = new Filesystem(new Adapter($client, 'path/to/cache/dir'));

$factory = new Twersona\ProfileFactory($connConf, $filesystem);

You can change the default filename used for the profile cache, which is twitter-profile-cache, by passing in a third parameter to the constructor.

$factory = new Twersona\ProfileFactory($connConf, $filesystem, 'conorsmith-profile');

About

A library to watch a Twitter profile for any updates to profile information

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages