/opensea-discord-bot

A TS script to hit the OpenSea API for collection sales and send messages to Discord

Primary LanguageTypeScript

Discord Bot for OpenSea

Need help? Join us on Discord!

Non-developers should also consider using Boto for their Discord sales bot needs.

This project includes a script that can be used to routinely hit the OpenSea API, check for recent sales on a collection, and post embeds into a Discord channel with information about the sale.

Please don't abuse the OpenSea API by running this more frequently than once per hour. Ideally you should request an API key from OpenSea, and in a perfect world you would instead use Webhooks from OpenSea.

Prerequisites

This script can easily be deployed to Heroku and run on a job schedule, so you'll need a free Heroku account from https://heroku.com. The script can be run locally or from any server that offers a NodeJS runtime.

You'll also need a Discord bot who has the ability to post in a channel in your Discord server.

First, you need a Discord server where you have permission to add a Bot. It's free and easy to create your own Discord server.

Once you have a server you can use, grab the channel ID following the instructions at this Discord support article. You'll enable developer mode, which will allow you to easily copy the channel ID from the Discord app - https://support.discord.com/hc/en-us/articles/206346498-Where-can-I-find-my-User-Server-Message-ID-.

Next, create a New Application on the Discord developer portal by clicking the button in the top right corner at https://discord.com/developers/applications.

Give your application a name.

Click into the Bot menu item. You can name your bot and give it an avatar, but the only requirement is that you copy the Bot token:

Discord bot token screenshot

Click into the OAuth2 menu item. Give your application the bot scope:

Discord scopes screenshot

Then, in the next section, give your bot the Send Messages permission under Text Permissions:

Discord bot permissions screenshot

Now you're ready to authenticate your bot to your server - copy the OAuth URL from the scopes box and open it in your browser. You'll be asked to give permission to the bot to enter your server.

Once the bot is in your server, ensure you have the following two values and you are ready to deploy or run your script:

  • botToken i.e SBI1MDI0NzUyNDQ3NzgyOTEz.YF36LQ.Sw-rczOfalK0lVzuW8vBjjcnsy0
  • channelId i.e. 814900494928445450

Run locally

You can run this script locally by pulling the repo to your local machine.

First, install the dependencies with npm or yarn.

Then copy the .env.example file to .env and replace the example values with your own. Or set them in your environment manually.

The contract address for the NFT collection:

CONTRACT_ADDRESS=0x196c4C7291D47BCDBbf37ab7ec9AE7ECB21Aef52

The collection slug as found in the OS URL https://opensea.io/collection/picassopunks:

COLLECTION_SLUG=picassopunks

The Id of the discord channel to post sales to:

DISCORD_CHANNEL_ID=123456789101112130

You can also send to multiple channels by adding multiple IDs:

DISCORD_CHANNEL_ID=123456789101112130;123456789101738273;123456783649182736

The token from the discord bot you created above:

DISCORD_BOT_TOKEN=SBI1MDI0NzUyNDQ3NzgyOTEz.YF36LQ.Sw-rczOfalK0lVzuW8vBjjcnsy0

Your OpenSEA API token:

OPENSEA_TOKEN=some-key-here

If you don't have one yet, request for an API token.

Then just run the code!

$ yarn ts-node ./checkSales.ts
// or
$ ts-node ./checkSales.ts

Deploy to Heroku

The easiest way to run this script on a chron scheduler is to deploy it to Heroku with this button:

Deploy

Heroku will require that you input the ENV vars that are necessary to run the script, and will run the checkSales.ts script after a successful deploy.

The scheduler add-on is included in the app.json but you still must schedule the script to run and we recommend running it hourly. This way the script will run every hour and will check the OpenSea API for sales in the last hour.

To set up the script to run on a schedule, once your Heroku app finishes deploying, click "Manage App", and then navigate to the Heroku Scheduler addon. Create a new job, run it every, and enter

yarn ts-node checkSales.ts

as the Run Command.