Home

Awesome

Coopboost

Grow your twitter audience.

Deploy

First, create a Twitter application and grab the:

Then, deploy by clicking the below button.

Deploy

Add the above Twitter credentials to your Heroku app's environmental variables. You can do so by clicking on "manage app", then "settings", then "config variables".

If you'd like to manage the environmental variables using Heroku's CLI, then be sure to clone the repo locally with the Git URL. Then you can run the following commands:

$ heroku config:set TWITTER_CONSUMER_KEY=B9pthxxxx
$ heroku config:set TWITTER_CONSUMER_SECRET=HhMXxxxx
$ heroku config:set TWITTER_ACCESS_TOKEN_KEY=3629xxx
$ heroku config:set TWITTER_ACCESS_TOKEN_SECRET=U3HQovsxxxx

Finally, seed your database with some Twitter accounts whose followers you want, i.e. Twitter accounts who are like you. (This bot will follow those accounts' followers with the intention that they'll look at your profile and follow you back.)

$ heroku run node ./tasks/add-seeds.js segment,keen_io,startupljackson

And you're done!

BONUS: MUTING AND ADDING USERS TO A TWITTER LIST

If you want to add all the people you follow into a private list, go ahead and create one. After you do so, make sure to add the following variables into your Heroku environment variables:

TWITTER_SCREEN_NAME=andyjiang
TWITTER_LIST_NAME=coopboost

The bot will then add all of the users it follows into the coopboost list. Twitter's API requires your handle, as well, which is why we also have to provide it here.

How does it work?

The cron job is in ./clock.js and it determines when to initiate the bot(). Then, three things happen:

The cronjob in ./clock.js is set to kick off this process each hour on the hour starting from 10am to 4pm pacific time. Feel free to update this to your liking. If you want to find out when your twitter followers are most active, check out this free tool, Tweriod. If you need help constructing cronJobs, check out this nifty tool.

Manually triggering tasks

You can manually kick off tasks from the terminal.

Seeding database with accounts whose followers you want

$ heroku run node ./tasks/add-seeds.js segment,keen_io,startupljackson

The last parameter here are Twitter usernames delimited by commas. You can put as many as you want here. There are no notifications if all of these followers are added to the queue, so check back every once in a while to make sure the bot has followers to follow.

Adding followers

$ heroku run node ./tasks/add-followers.js

This will go through the database of seed accounts and add their followers to another database of accounts to follow.

Following

$ heroku run node ./tasks/follow.js

This will go through the database of accounts to follow and follow them.

Unfollowing

$ heroku run node ./tasks/unfollow.js

This will go through the database of accounts, find the accounts that were followed, check if they've followed back, and if not, unfollow them.

What next?

Questions or complaints?

Tweet at me @andyjiang.