Package Documentation

Storm Package: synapse-twitter

The following Commands are available from this package. This documentation is generated for version 1.9.0 of the package.

Storm Commands

This package implements the following Storm Commands.

twitter.feed.adduser

Add a user to the list of Twitter accounts being monitored.

As input takes an inet:web:acct or a username specified with --user.

Once an account is added, the twitter.feed.pull command can be used to retrieve
any new tweets since the last pull.

By default, will pull as many tweets as possible during the initial pull. This can
be adjusted by specifying --start-from when adding an account to set a different
starting position.

Note: The Twitter API limits the history available to the most recent 3200
tweets. Setting the starting point back further will not bypass this restriction.

Examples:

  // Add the account 'fakeuser'
  twitter.feed.adduser --user fakeuser

  // Add the account 'fakeuser' and 13820182 as the tweet to start from
  inet:web:acct=(twitter.com, fakeuser) | twitter.feed.adduser --start-from 13820182


Usage: twitter.feed.adduser [options]

Options:

  --help                      : Display the command usage.
  --debug                     : Show verbose debug output.
  --start-from <start_from>   : The tweet id to start ingesting from. (default: 1)
  --user <user>               : Twitter handle to add to the accounts being monitored

twitter.feed.deluser

Remove a web account from the list of accounts being monitored

Examples:

  inet:webaccount | twitter.feed.deluser


Usage: twitter.feed.deluser [options]

Options:

  --help                      : Display the command usage.
  --user <user>               : Twitter handle to delete from the accounts being monitored
  --debug                     : Show verbose debug output.

twitter.feed.list

List the accounts being monitored.

Examples:

  twitter.feed.list


Usage: twitter.feed.list [options]

Options:

  --help                      : Display the command usage.

twitter.feed.pull

Pull new tweets from the Twitter accounts being monitored.

As input can take an inet:web:acct, a username specified with --user, or --all
to update all feeds currently configured.

Before pulling the feed for a user, configure them using twitter.feed.adduser.

Examples:

  // Pull new tweets for "fakeuser"
  twitter.feed.pull --user fakeuser

  // Pull new tweets for "fakeuser"
  inet:web:acct=(twitter.com, fakeuser) | twitter.feed.pull

  // Pull new tweets for all configured accounts
  twitter.feed.pull --all


Usage: twitter.feed.pull [options]

Options:

  --help                      : Display the command usage.
  --user <user>               : Twitter handle to pull tweets for and update offset tracking
  --all                       : Pull tweets for all accounts added to the list of feed accounts
  --auto-enroll               : Automatically add any inet:web:acct not already being watched into the feed list.
  --skip-scrape               : Do not automatically scrape ingested tweet text for possible nodes.
  --debug                     : Show verbose debug output.
  --size <size>               : Limit the number of results ingested to the given size (per-node).
  --yield                     : Yield the newly created nodes.

twitter.limits

Print out the current rate-limit status.

Examples:

  twitter.limits


Usage: twitter.limits [options]

Options:

  --help                      : Display the command usage.

twitter.search.tweets

Search for tweets using the v2 Twitter tweets/search/recent endpoint.

As input it takes a query string and creates inet:web:post nodes from the search
results.

Note: The Twitter API limits the tweets available to the most recent week of tweets,
and that queries must be less than 512 characters long. For more information on
Twitter's search query syntax, see their documentation at
https://developer.twitter.com/en/docs/twitter-api/tweets/search/integrate/build-a-query

// find the tweets related to the search "foobar"
twitter.search.tweets "foobar"


Usage: twitter.search.tweets [options] <query>

Options:

  --help                      : Display the command usage.
  --skip-scrape               : Do not automatically scrape ingested tweet text for possible nodes.
  --debug                     : Show verbose debug output.
  --yield                     : Yield the newly created nodes.
  --size <size>               : Limit the number of results ingested to the given size (per-node).

Arguments:

  <query>                     : The search query to run against the Twitter API to search for tweets

twitter.search.users

Query the Twitter v1.1 API to search for users.

// find all the users that are relate to the query invisi
twitter.search.users "invisi"


Usage: twitter.search.users [options] <query>

Options:

  --help                      : Display the command usage.
  --debug                     : Show verbose debug output.
  --size <size>               : Limit the number of results ingested to the given size (per-node).
  --yield                     : Yield the newly created nodes.

Arguments:

  <query>                     : The search query to run against the Twitter API to search for users

twitter.setup.apikey

Set the Twitter API key. The value given should be the Bearer Token for interacting with the v2 API.


Usage: twitter.setup.apikey [options] <apikey>

Options:

  --help                      : Display the command usage.
  --self                      : Set the key as a user variable. If not used, the key is set globally.

Arguments:

  <apikey>                    : The Twitter v2 API Bearer Token string.

twitter.setup.oauth

Set the Twitter OAuth keys to use for interacting with the v1.1 API.

Because the v2 API for Twitter is still in early access, certain portions of the
v1.1 API have not been ported over to the v2 API yet, such as the search functionality.
Use this command to set the oauth keys needed for the commands that interact with
the v1.1 API.

Currently only affects the twitter.search.users command.


Usage: twitter.setup.oauth [options] <consumerKey> <consumerSecret> <accessToken> <accessSecret>

Options:

  --help                      : Display the command usage.
  --self                      : Set the keys as user variables. If not used, the key is set globally.

Arguments:

  <consumerKey>               : The Twitter API OAuthv1 consumer key.
  <consumerSecret>            : The Twitter API OAuthv1 consumer secret.
  <accessToken>               : The Twitter API OAuthv1 access token.
  <accessSecret>              : The Twitter API OAuthv1 access secret.

twitter.tweets.byid

Pull down a specific tweet by tweet ID.

Examples:

  // Get the tweet with id 1456591769185959938
  twitter.tweets.byid 1456591769185959938


Usage: twitter.tweets.byid [options] <id>

Options:

  --help                      : Display the command usage.
  --debug                     : Show verbose debug output.
  --yield                     : Yield the newly created nodes.
  --skip-scrape               : Do not automatically scrape ingested tweet text for possible nodes.

Arguments:

  <id>                        : The ID of the tweet to fetch

twitter.user.followers

Get the accounts that are following a particular Twitter account.

Examples:

  // Pull followers for "fakeuser"
  twitter.user.followers --user fakeuser

  // Pull followers for "fakeuser" and yield out the created nodes
  inet:web:acct=(twitter.com, fakeuser) | twitter.user.followers --yield


Usage: twitter.user.followers [options]

Options:

  --help                      : Display the command usage.
  --user <user>               : Twitter handle to query for followers.
  --debug                     : Show verbose debug output.
  --size <size>               : Limit the number of results ingested to the given size (per-node).
  --yield                     : Yield the newly created nodes.

twitter.user.following

Get the accounts that a Twitter account is following

Examples:

  // Get the accounts "fakeuser" is following
  twitter.user.following --user fakeuser

  // Pull the list of accounts "fakeuser" is following and yield out the created nodes
  inet:web:acct=(twitter.com, fakeuser) | twitter.user.following --yield


Usage: twitter.user.following [options]

Options:

  --help                      : Display the command usage.
  --user <user>               : Twitter handle to query for who the account follows.
  --debug                     : Show verbose debug output.
  --size <size>               : Limit the number of results ingested to the given size (per-node).
  --yield                     : Yield the newly created nodes.

twitter.user.profile

Get profile information about a twitter user.

This will make new inet:web:acct nodes, or enrich existing ones

Examples:

  // Get the profile information for the user 'fakeuser' and make a node for the account
  twitter.user.profile --user fakeuser

  // Lift the existing 'fakeuser' inet:web:account node and
  inet:web:acct=(twitter.com, fakeuser) | twitter.user.profile


Usage: twitter.user.profile [options]

Options:

  --help                      : Display the command usage.
  --user <user>               : Twitter handle to retrieve the profile details for.
  --debug                     : Show verbose debug output.

twitter.user.tweets

Pull down the latest tweets for a user.

Note: The Twitter API limits the history available to the most recent 3200
tweets.

Examples:

  // Get the last 50 tweets for the "fakeuser" account
  twitter.user.tweets --user fakeuser --size 50

  // Get the last 50 tweets for the "fakeuser" account
  inet:web:acct=(twitter.com, fakeuser) | twitter.user.tweets --yield --size 50

  // Get the last 50 tweets for the "fakeuser" account, bypassing scraping the tweets for any other
  // possible indicators
  inet:web:acct=(twitter.com, fakeuser) | twitter.user.tweets --yield --size 50 --skip-scrape


Usage: twitter.user.tweets [options]

Options:

  --help                      : Display the command usage.
  --user <user>               : Twitter handle to retrieve tweets for.
  --debug                     : Show verbose debug output.
  --size <size>               : Limit the number of results ingested to the given size (per-node).
  --yield                     : Yield the newly created nodes.
  --skip-scrape               : Do not automatically scrape ingested tweet text for possible nodes.

Storm Modules

This package does not export any Storm APIs.