simsim discord bot
Go to file
2021-01-28 20:08:31 -05:00
.github Added initial dockerfile 2021-01-01 14:23:18 -05:00
matteo_env got a web page with all current games' full display states available in json 2020-12-28 03:21:47 -05:00
simmadome fix deleted team error 2021-01-16 01:30:15 -05:00
sql scripts added handling for postseason constraints 2021-01-14 17:47:57 -05:00
templates Merge remote-tracking branch 'upstream/master' 2021-01-17 16:17:07 -05:00
.dockerignore Update Dockerfile for frontend build 2021-01-13 12:56:00 +01:00
.DS_Store organize things and switch to using /game/:id over /game?id= 2021-01-10 01:18:37 -05:00
.gitattributes Add .gitignore and .gitattributes. 2020-12-19 19:07:51 -05:00
.gitignore Merge remote-tracking branch 'upstream/master' 2021-01-17 16:17:07 -05:00
database.py Fixing team search 2021-01-17 16:44:31 -05:00
debug storage.py added ;saveteam, ;showteam, ;showplayer 2020-12-24 04:51:38 -05:00
Dockerfile Update Dockerfile for frontend build 2021-01-13 12:56:00 +01:00
games.py Merge remote-tracking branch 'upstream/master' 2021-01-17 16:17:07 -05:00
league_storage.py fixed bye string sneaking into league 2021-01-17 15:48:21 -05:00
leagues.py fixed bye string sneaking into league 2021-01-17 15:48:21 -05:00
LICENSE.md Rename LICENSE to LICENSE.md 2021-01-15 16:32:44 -05:00
main_controller.py Merge remote-tracking branch 'upstream/master' 2021-01-17 16:17:07 -05:00
Makefile React conversion DONE! 2021-01-08 00:29:39 -05:00
matteo_bak.db Fixes #9 2021-01-07 22:58:46 +00:00
onomancer.py fixed an unresolved import 2021-01-13 04:33:42 -05:00
README.md Removed test change 2021-01-28 20:08:31 -05:00
requirements.txt added requirements.txt 2020-12-31 13:37:00 -05:00
roman.py added m!roman [int]; returns error string or a number in roman numerals 2020-12-20 05:28:47 -05:00
the_draft.py Final tweaks 2021-01-06 17:42:33 -08:00
the_prestige.py Merge remote-tracking branch 'upstream/master' 2021-01-17 16:17:07 -05:00
the-prestige.pyproj lots of league database foundation 2021-01-13 04:23:48 -05:00
the-prestige.sln added introduction command, to be run by owner only 2020-12-20 00:16:36 -05:00

A simsim fork for the FredChat

This fork changes small things about the bot to better fit in in the FredChat discord. The official readme can be seen below and a summary of changes is viewable directly below this

  • Removes almost all references to Matteo as that is not the name of the bot user
  • Adds in new weather effects
  • Adds the help command as the bot's status
  • Shows a players vibes when requesting their stats
  • Updated the credit command to credit Sakimori and SIBR instead of the pfp artist as the original profile pic is not being used
  • Game history with weather can be viewed in the same style embed as showallteams
  • Merged in commits to utilize the website

matteo-the-prestige

simsim discord bot

blaseball, blaseball, is back! in an unofficial capacity. this project is completely unaffiliated with the game band.

we have custom players (generated by onomancer), custom teams, custom leagues, all set up in discord and watchable at https://simsim.sibr.dev!

if you would like to add matteo to your server to be able to set up teams and games, you can do so with this link: https://discord.com/api/oauth2/authorize?client_id=789956166796574740&permissions=388160&scope=bot

accepting pull requests, check the issues for to-dos.

commands: (everything here is case sensitive, and can be prefixed with either m; or m!)

team commands:

creation and deletion:

  • m;saveteam
    • saves a team to the database allowing it to be used for games. use this command at the top of a list with entries separated by new lines:
      • the first line of the list is your team's name.
      • the second line is the team's icon and slogan, generally this is an emoji followed by a space, followed by a short slogan.
      • the third line must be blank.
      • the next lines are your batters' names in the order you want them to appear in your lineup, lineups can contain any number of batters between 1 and 12.
      • then another blank line seperating your batters and your pitchers.
      • the final lines are the names of the pitchers in your rotation, rotations can contain any number of pitchers between 1 and 8.
    • if you did it correctly, you'll get a team embed with a prompt to confirm. hit the 👍 and your team will be saved!
  • m;deleteteam [teamname] (requires team ownership)
    • allows you to delete the team with the provided name. you'll get an embed with a confirmation to prevent accidental deletions. hit the 👍 and your team will be deleted.
  • m;import
    • imports an onomancer collection as a new team. you can use the new onomancer simsim setting to ensure compatibility. similarly to saveteam, you'll get a team embed with a prompt to confirm, hit the 👍 and your team will be saved!

editing (all of these commands require ownership and exact spelling of the team name):

  • m;addplayer batter/pitcher [team name] [player name]
    • adds a new player to the end of your team, either in the lineup or the rotation depending on which version you use. use addplayer batter or addplayer pitcher at the top of a list with entries separated by new lines:
      • the name of the team you want to add the player to.
      • the name of the player you want to add to the team.
  • m;moveplayer [team name] [player name] [new lineup/rotation position number]
    • moves a player within your lineup or rotation. if you want to instead move a player from your rotation to your lineup or vice versa, use m;swapsection instead. use this command at the top of a list with entries separated by new lines:
      • the name of the team you want to move the player on.
      • the name of the player you want to move.
      • the position you want to move them too, indexed with 1 being the first position of the lineup or rotation. all players below the specified position in the lineup or rotation will be pushed down.
  • m;swapsection [team name] [player name]
    • swaps a player from your lineup to the end of your rotation or your rotation to the end of your lineup. use this command at the top of a list with entries separated by new lines:
      • the name of the team you want to swap the player on.
      • the name of the player you want to swap.
  • m;removeplayer [team name] [player name]
    • removes a player from your team. if there are multiple copies of the same player on a team this will only delete the first one. use this command at the top of a list with entries separated by new lines:
      • the name of the team you want to remove the player from.
      • the name of the player you want to remove.

viewing and searching:

  • m;showteam [name]
    • shows the lineup, rotation, and slogan of any saved team in a discord embed with primary stat star ratings for all of the players. this command has fuzzy search so you don't need to type the full name of the team as long as you give enough to identify the team you're looking for.
  • m;searchteams [searchterm]
    • shows a paginated list of all teams whose names contain the given search term.
  • m;showallteams
    • shows a paginated list of all teams available for games which can be scrolled through.

game commands:

  • m;startgame --day # or -d #
    • starts a game with premade teams made using saveteam. provides a link to the website where you can watch the game.
    • the --day/-d is optional, if used it'll force the game to use the #th spot in each team's rotations. if this number is larger than the number of pitchers in one or both of the teams' rotations it'll wrap around. if it is not used pitchers will be chosen randomly from the teams' rotations.
    • use this command at the top of a list with entries separated by new lines:
      • the away team's name.
      • the home team's name.
      • optionally, the number of innings, which must be greater than 2 and less than 201. if not included it will default to 9.
    • this command has fuzzy search so you don't need to type the full name of the team as long as you give enough to identify the team you're looking for.
  • m;randomgame
    • starts a 9-inning game between 2 entirely random teams. embrace chaos!
  • m;starttournament --rounddelay #
    • starts a randomly seeded tournament with the provided teams, automatically adding byes as necessary. all series have a 5 minute break between games. the current format is: best of 5 until the finals which are best of 7.
    • the --rounddelay is optional, if used, # must be between 1 and 120 and it'll set the delay between rounds to be # minutes. if not included it will default to 10.
    • use this command at the top of a list with entries separated by new lines:
      • the name of the tournament.
      • the name of each participating team on its own line.

draft commands

  • m;startdraft
    • starts a draft with an arbitrary number of participants. use this command at the top of a list with entries separated by new lines:
      • for each participant's entry you need three lines:
        • their discord @
        • their team name
        • their team slogan
      • post this with all three of these things for all participants and the draft will begin.
    • the draft will begin once all participants have given a 👍 and will proceed in the order that participants were entered. each participant will select 12 hitters and 1 pitcher from a pool of 20 random players which will refresh automatically when it becomes small.
  • m;draft [name]
    • use this on your turn during a draft to pick your player.
    • you can also just use a 'd' instead of the full command.

league commands

  • all of these commands are for leagues that have already been started. to start a league, click the 'create a league' button on the website and fill out the info for your league there, then use the m;claimleague command in discord to set yourself as the owner.
  • commissioner commands (all of these except for m;claimleague require ownership of the specified league):
    • m;claimleague [leaguename]
      • sets yourself as the owner of an unclaimed league created on the website. make sure to do this as soon as possible since if someone does this before you, you will not have access to the league.
    • m;addleagueowner [leaguename]
      • use this command at the top of a list of @mentions, with entries separated by new lines, of people you want to have owner powers in your league.
    • m;startleague [leaguename] --queue #/-q # --noautopostseason
      • send this command with the number of games per hour you want on the next line, minimum 1 (one game every hour), maximum 12 (one game every 5 minutes, uses spillover rules).
      • starts the playing of league games at the pace specified, by default will play the entire season and the postseason unless an owner pauses the league with the m;pauseleague command.
      • if you use the --queue #/-q # flag, the league will only play # series' at a time before automatically pausing until you use this command again.
      • if you use the --noautopostseason flag, instead of starting automatically, the league will pause at the end of the regular season and not start the postseason until you use this command again.
    • m;pauseleague [leaguename]
      • pauses the specified league after the current series finishes until the league is started again with m;startleague.
  • general commands (all of these can be used by anyone):
    • m;leaguestandings [leaguename] --season #/-s #
      • displays the current standings for the specified league.
      • by default this will display the standings for the current season but if the --season #/-s # flag is set it will instead display the standings for the #th season instead for viewing historical standings.
    • m;leaguewildcard [leaguename]
      • displays the wild card standings for the specified league. if the league doesn't have wild cards, it will instead tell you that.
    • m;leagueschedule [leaguename]
      • displays the upcoming schedule for the specified league. shows the current series and the next three series after that for every team.

player commands:

  • m;showplayer [name]
    • displays any name's stars, there's a limit of 70 characters. that should be plenty. note: if you want to lookup a lot of different players you can do it on onomancer instead of spamming this command a bunch and clogging up discord: https://onomancer.sibr.dev/reflect
  • m;idolize [name]
    • records any name as your idol, mostly for fun.
  • m;showidol
    • displays your idol's name and stars in a discord embed.

other commands:

  • m;help [command]
    • shows instructions for a given command. if no command is provided, it will instead provide a list of all of the commands that instructions can be provided for.
  • m;credit
    • shows artist credit for matteo's avatar.
  • m;roman [number]
    • converts any natural number less than 4,000,000 into roman numerals, this one is just for fun.

patreon!

these folks are helping me a ton via patreon, and i cannot possibly thank them enough:

  • Ale Humano
  • Chris Denmark
  • Astrid Bek
  • Kameleon
  • Ryan Littleton
  • Evie Diver
  • iliana etaoin

Attribution

Twemoji is copyright 2020 Twitter, Inc and other contributors; code licensed under the MIT License, graphics licensed under CC-BY 4.0