🐦 Access Twitter data without an API key
This module provides command line interfaces to scrape: profiles, timelines, connections, likes, search and conversations.
It also exposes both streams and a promise returning function to help accessing Twitter in your own applications.
Real-time firehoses can be created using the companion module monitor-head-stream
.
- Get Twitter data without being required to configure an API key.
- Twitter can't constrain access as easily as they can to an API or an individual API key. Any constraints introduced would apply to their public site. A scraper can be fixed; you are no longer beholden to Twitter.
- Grab timelines, whole conversations, profiles, connections, likes, etc.
- Automatically pages to fetch all tweets.
- Provides metadata on how tweet replies are linked together. e.g.
isReplyToId
$ scrape-twitter profile sebinsua
# ...
$ scrape-twitter timeline nouswaves
# ...
This command requires a valid login. It will check for the following environment variables: TWITTER_USERNAME
, TWITTER_PASSWORD
, TWITTER_KDT
. But can also pick these up from a dotenv
file at the path ~/.scrape-twitter
. The first time you login you will be asked to store the TWITTER_KDT
- this is used by Twitter to recognise your device.
$ scrape-twitter likes sebinsua
# ...
This command also requires a valid login.
$ scrape-twitter connections sebinsua --type=following
# ...
$ scrape-twitter conversation ctbeiser 691766715835924484
# ...
$ scrape-twitter search --query "from:afoolswisdom motivation" --type latest
# ...
$ scrape-twitter list nouswaves list
# ...
JSON interface plays nicely with CLI tools like jq
, coreutils/gshuf
and terminal-notifier
For example, a MOTD-like script might contain:
scrape-twitter search --query="from:afoolswisdom knowledge" | jq -r '.[].text' | gshuf -n 1 | terminal-notifier -title "Knowledge (MOTD)"
With yarn
:
yarn global add scrape-twitter
With npm
:
npm install -g scrape-twitter
Create a ReadableStream<Tweet>
for the timeline of a username
.
Create a ReadableStream<Tweet>
for the likes of a username
.
Create a ReadableStream<UserConnection>
for the connections of a username
.
Create a ReadableStream<Tweet>
for the conversation that belongs to a username
and tweet id
.
Create a ReadableStream<Tweet>
for the thread that belongs to a tweet id
.
Create a ReadableStream<Tweet>
for the tweets that match a query
and type
.
Create a ReadableStream<Tweet>
for the username
's list
.
Get a Promise<UserProfile>
for a particular username
.