Dice Bot for Discord
Dice Maiden is a simple to use dice rolling bot perfect for any trpg sessions!
Follow the link to add the bot to your discord server :
https://discordapp.com/api/oauth2/authorize?client_id=572301609305112596&scope=bot&permissions=11264
This will authorize the bot for your server and you should see it in your default public channel. The bot will have permissions to read, send and manage messages.
NOTE: When you first add the bot to your server, it may show up as offline. This is normal! It can take some time for your server to be cached by the bot.
If you wish to host this yourself, utilize dice_maiden_lite.rb. Dice Maiden requires ruby version 2.3+. There are a handful of gems required as well which are listed in the Gemfile. You will also need to create a bot which can be done at the discord developer section
Below are examples of the dice roll syntax.
!roll 2d6 + 3d10
: Roll two six-sided dice and three ten-sided dice.
!roll 3d6 + 5
: Roll three six-sided dice and add five. Other supported static modifiers are add (+), subtract (-), multiply (*), and divide (/).
!roll 3d6 e6
: Roll three six-sided dice and explode on sixes. Some game systems call this 'open eneded' dice. If the number rolled is greater than or equal to the value given for this option, the die is rolled again and added to the total. If no number is given for this option, it is assumed to be the same as the number of sides on the die. Thus, '3d6 e' is the same as '3d6 e6'.
!roll 3d10 d1
: Roll three ten-sided dice and drop one die. The lowest value will be dropped first. NOTE: These dice are dropped before any dice are kept with the following k
command. Order of operations is : roll dice, drop dice, keep dice
!roll 3d10 k2
: Roll three ten-sided dice and keep two. The highest value rolled will be kept.
!roll 4d6 r2
: Roll four six-sided dice and reroll any that are equal to or less than two.
!roll 6d10 t7
: Roll six ten-sided dice and any that are seven or higher are counted as a success. The dice in the roll are not added together for a total. Any die that meets or exceeds the target number is added to a total of successes.
!roll 5d10 t8 f1
: f# denotes a failure number that each dice must match or be beneath in order to count against successes. These work as a sort of negative success and are totaled together as described above. In the example roll, roll five ten-sided dice and each dice that is 8 or higher is a success and subtract each one. The total may be negative. If the option is given a 0 value, that is the same as not having the option at all thus a normal sum of all dice in the roll is performed instead.
!roll 4d10 kl3
: Roll four ten-sided dice and keep the lowest three dice rolled. NOTE: This modifier will only work with comments and math modifiers
!roll purge 10
: Purge the last 10 messages from channel. The purge value can be between 2 to 100 messages and requires the user to have the "manage messages" or "administrator" role.
!roll 4d6 ! Hello World!
: Roll four six-sided dice and add comment to the roll.
!roll 6 4d6
: Roll 6 sets of four sixe-sided dice. A size of a set can be between 2 and 20.
!roll s 4d6
: Simplify roll output by not showing the tally.
!roll 4d6 ! unsort
or !roll ul 4d6
: Roll four six-sided dice and unsort the tally.
!roll help
: Displays basic usage instructions.
!roll donate
: Get donation information on how to help support the bot!
These commands can be combined. For example:
!roll 10d6 e6 k8 +4
: Roll ten six-sided dice , explode on sixes and keep eight of the highest rolls and add four.
The following examples outline how to change, reset, or check the prefix used by the bot.
!dm prefix foobar
: Change the bots prefix to !foobar. NOTE: A new prefix will have an ! added to the start of it. A prefix cannot be more than 10 characters, contain spaces, or be the following: "check" or "reset". The user must have the "manage messages" or "administrator" role
!dm prefix reset
: Reset the bots prefix to !roll
!dm prefix check
: Checks the bots current prefix
You can set the bot to display the actual roll executed as part of the bot response with this server-wide option. This is off by default. The user must have the "manage messages" or "administrator" role to make these changes.
!dm request show
: Show the roll requests in the output.
!dm request hide
: Hide the roll requests in the output.
Warhammer 40k Wrath and Glory example syntaxes:
!roll wng 4d6
: Roll four six-sided dice with a wrath dice.
!roll wng dn2 4d6
: Roll four six-sided dice with a wrath dice and a difficulty test of 2. The bot will append the test pass/fail status to the roll result!
!roll wng 4d6 !soak
or !roll wng 4d6 !exempt
or !roll wng 4d6 !dmg
: Roll four six-sided dice without a wrath dice.
Dark Heresy 2nd edition syntaxes:
!roll dh 4d10
: Roll four ten-sided dice for dark heresy 2nd edition. If your roll contains a natural 10, you will be prompted with a righteous fury notification!
Alias rolls are commands that are shorthand for a longer, more complex comand. They can also change what the dice faces appear as in most cases. Below is the complete list of aliases , with example rolls, currently supported by Dice Maiden. Have a game system that you want turned into an alias? Create an issue on github to get it added to this list!
4wod8
-> 4d10 f1 t8
World of darkness 4th edition. The first number is the number of dice to roll and the second is the toughness of the check. Exploding 10s will be added to this alias at a later date.
3df
-> 3d3 t3 f1
Fudge dice from the fate RPG system. The number represents total dice rolled. This alias also outputs the dice faces as +
/
/-
.
3wh4+
-> 3d6 t4
Warhammer Age of Sigmar/40k style rolls. The first number is the amount of dice rolled and the second number is the target number.
dd34
-> (1d3 * 10) + 1d4
Double digit rolls. Uses the first number for the first digit and the second number for the second digit. This is sometimes used in warhammer as a "d66".
age
-> 2d6 + 1d6
AGE system roll. The AGE system games use 3d6 for ability tests, with 1 of them typically being represented as a drama die, stunt die, dragon die etc. It is important that all three dice be rolled together but the drama die is able to be distinguished from the others. Example games include Fantasy Age, Dragon Age, Modern Age, Blue Rose, and The Expanse RPG.
+dX
-> 2dX d1
Advantage roll where X is the dice sides value. Roll two dice and keep the highest.
-dX
-> 2dX kl1
Disadvantage roll where X the dice sides value. Roll two dice and keep the lowest.
+d%
-> ((2d10kl1-1) *10) + 1d10
Advantage roll for a percentile dice in a roll-under system. Rolls two tens and keeps the lowest.
-d%
-> ((2d10k1-1) *10) + 1d10
Disadvantage roll for a percentile dice in a roll-under system. Rolls two tens and keeps the highest.
Found a bug? Have a feature request? Create an issue on github. Thanks!
You can also join the Discord Support server: https://discord.gg/4T3R5Cb
If you wish to support the bot and donate, you can do so via Patreon here or paypal via donate bot here!