Skip to content

A Discord bot for tracking Animal Crossing: New Horizons turnip prices and fossil collections

License

Notifications You must be signed in to change notification settings

theastropath/turbot

Repository files navigation

Turbot

build pypi python codecov black mit

A Discord bot for everything Animal Crossing: New Horizons.

📱 Using Turbot

Once you've connected the bot to your server, you can interact with it over Discord via the following commands in any of the authorized channels.

  • !about: Get information about Turbot
  • !help: Provides detailed help about all of the following commands
  • !export: Send a DM with all the data Turbot has associated with you

💸 Turnips

predictions

These commands help users buy low and sell high in the stalk market.

  • !best: Look for the current best sell or buy
  • !buy: Save a buy price
  • !clear: Clear your price data
  • !graph: Graph price data
  • !history: Get price history
  • !lastweek: Get graph for last week's price data
  • !oops: Undo the last price data
  • !predict: Predict your price data for the rest of the week
  • !reset: Reset all users' data
  • !sell: Save a sell price

ℹ️ User Preferences

user-info

These commands allow users to set their preferences. These preferences are used to make other commands more relevant, for example by converting times to the user's preferred timezone.

  • !info: Get a user's information
  • !pref: Set a user preference; use command to get a list of available options

📮 Collectables

collecting

When a community of users tracks collectables and trades them between each other, everyone finishes collecting everything in the game so much more quickly than they would on their own. Turbot supports collecting:

  • 🦴 Fossils
  • 🐞 Bugs
  • 🐟 Fish
  • 🖼️ Art
  • 🎶 Songs

📈 Managing your Collection

  • !collect: Mark something as collected
  • !collected: Show the things you've collected so far
  • !count: Count the number of collected things you have
  • !needed: Find out what collectables are needed by you and others
  • !search: Search for someone who needs something you're looking to give away
  • !uncollect: Remove something from your collection
  • !uncollected: Get a list of things that you haven't collected yet

🤔 Helper Utilities

Some collections require additional support such as the !art command that helps users tell fake art from real art. The !bugs and !fish commands tell users when and where to catch those critters. These commands also know what you've already collected and will tailor their responses to the user.

  • !art: Get information on an art piece
  • !bugs: Get information on bugs
  • !fish: Get information on fish
  • !new: Get information on newly available fish and bugs

👑 Administration

  • !authorize: Configure which channels Turbot can operate in

🤖 Running Turbot

First install turbot using pip:

pip install turbot

Then you must configure two things:

  1. Your Discord bot token.
  2. The list of channels you want turbot to monitor. (Default: All channels)

To provide your Discord bot token either set an environment variable named TURBOT_TOKEN to the token or paste it into a file named token.txt.

For the list of channels you can provide channel names on the command line using any number of --channel "name" options. Alternatively you can create a file named channels.txt where each line of the file is a channel name. You can also specify them via the environment variable TURBOT_CHANNELS as a semicolon delimited string, for example: export TURBOT_CHANNELS="some;channels;here". You can also leave this unspecified and Turbot will operate within all channels, then you can specify a smaller set of channels using the !authorize command.

By default Turbot will use sqlite3 as its database. You can however choose to use another database by providing a SQLAlchemy Connection URL. This can be done via the --database-url command line option or the environment variable TURBOT_DB_URL. Note that, at the time of this writing, Turbot is only tested against sqlite3 and PostgreSQL.

More usage help can be found by running turbot --help.

⚛️ Heroku Support

Turbot supports deployment to Heroku out of the box. All you need is your Discord bot token and you're ready to go! Just click the Deploy to Heroku button, below.

Deploy

For more details see our documentation on Heroku support.

🐳 Docker Support

You can also run Turbot via docker. See our documentation on Docker Support for help.

❤️ Contributing

If you'd like to become a part of the Turbot development community please first know that we have a documented code of conduct and then see our documentation on how to contribute for details on how to get started.


MIT © TheAstropath, lexicalunit et al

About

A Discord bot for tracking Animal Crossing: New Horizons turnip prices and fossil collections

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages