Roll20 API Scripts
This repository is the collection of all the community-contributed API scripts that are available for use on Roll20.
Contributing
If you want to help improve an existing API script, just clone this repository, make your changes, and submit a pull request. If you would like to contribute a new script for the community to use, just clone this repository and create a new folder with the name of the script which matches the name in your script.json file. Optionally you can add a help.txt file with any instructions you want to include as well as any other files you feel will be helpful to the end user. Once everything is in the new folder send a pull request. If you have any questions or aren't familiar with Github or git in general, see Beginner's Guide to GitHub on the wiki. If you still need help, feel free to drop us a line at team@roll20.net or post a question on the forums and we can help you get set up.
Creating a script.json File
When you are ready to submit your script for public use, create a script.json
file in your script's folder (see the "_Example Script" folder in the root folder for an example). The file has the following fields:
name
: The name of the API script as it will appear on Roll20script
: The name of the javascript file, which must remain uniform throughout versionsversion
: The current version number of the API script (e.g.12.3
)previousversions
: All previous versions of the script in an array format (e.g.["0.5","0.1"]
)description
: A short explanation of the script and it's use that will appear along side the script on Roll20. It is important for this section to be filled out in detail, as it's the primary way users will get information about the purpose and use of the script. Included in the description section needs to be an example use or purpose, list and explanation of API Commands, and any other information necessary to operating the script.authors
: A simple string telling who contributed toward the script (e.g.Riley Dutton,Steve Koontz
)roll20userid
: A simple string telling the Roll20 User ID's of the authors (e.g.1
or45672,145678
). Used internally and won't be shown publicly on the site.patreon
: Place the URL for a Patreon campaign here, and it will appear under your script's description when selected via one-click. (e.g."https://www.patreon.com/<name>"
)tipeee
: Place the URL for a Tipeee here, and it will appear under your script's description when selected via one-click. (e.g."https://www.tipeee.com/<name>"
)useroptions
: An array of hashes that allow script authors to set pre-determined options for users to customize the functionality of the script. For more information check out the _Example folder's script.json for an example or see the Roll20 Wiki for more documentation.dependencies
: A list of other API scripts this script requires to function (e.g.My Kitchen
)modifies
: A list of the common Roll20 objects and properties the script reads and writes to. Custom objects and properties inside a namespace don't need to be included. (e.g.bar1_value: write
)conflicts
: A list of other API scripts this script is known to conflict with (e.g.Recipes
)
PLEASE VERIFY YOUR SCRIPT.JSON IS VALID JSON at http://jsonlint.com before you submit it!
After we have reviewed your script and approve it, we will merge in your changes which will make them available to everyone. If we reject your script, we will comment on your Github commit and let you know what changes need to be made before it can be accepted.
Update the Wiki
After making any changes to a script or adding a new one, it is important to include those changes with the Roll20 wiki at (https://wiki.roll20.net/API:Script_Index).
If you're making updates to an existing script, please find that script from the list and update:
- Author: Adding yourself as a contributor
- Version: To reflect your update
- Last Modified: To today's date
- Changelog: To reflect the new version and the changes you've made
- Optionally: Anything else such as the Description, Syntax, Installation and Configuration, or Script Use that may need altering or clarifying due to your changes.
If you're contributing a new script that has been accepted and merged in, please add a new page to the Wiki. The naming convention for scripts is "https://wiki.roll20.net/Script:Script_Name". Please format your listing from the existing style. You can find an example at (https://wiki.roll20.net/Script:Example).
After you've added the page, please go to the API Script Index (https://wiki.roll20.net/API:Script_Index) and add a link to your listing in the appropriate category.
Guidelines
Here are a few guidelines that you should follow when contributing API scripts for the community:
Be Clear and Concise
Community API scripts should be built from the ground up with the intention of sharing with others. The script's name should be a good indicator of what the script does and how it should be used. A script named "MkLtObjMvr-Dst" is likely to confuse, where a script named "Light Switch" is descriptive, clear, and does a good job of hinting at it's intended use.
Try to use short and descriptive function and variable names. Problematic names like "x1", "fe2", and "xbqne" are practically meaningless. Names like "incrementorForMainLoopWhichSpansFromTenToTwenty" are verbose. Aim for variable and function names that are meaningful but simple, such as "card_val" or "limitStr".
Make Your Script Accessible
Please take every effort to format your code in a traditional manner and present the script in a legible state. Leaving comments on the intended use of functions and code blocks can be very useful to future contributors.
Near the top of your script should be a comment providing the script's name, version number, the last time it was updated, and a short breakdown of the scripts intended use. In the breakdown should be included the script's description, syntax, and configuration options. It is important to add configurable elements near the top of the script in an easily demarcated area with comments on how those elements can or should be customized.
Limit Your Script's Footprint
Include namespaces for your functions and variables, to avoid potential conflicts with other authors. Placing your functions and variables inside a unique namespace to your script protects both it, the user, and other community scripts.
Do your best to limit what your script is manipulating at any given moment to achieve it's desired result. Add API "!" triggers to turn on and off your script's functionality. It is a safe practice to have your script disabled by default. Avoid functions that keep aggressive control and manipulation of objects whenever possible.
License
All of the code of the API scripts in this repository is released under the MIT license (see LICENSE file for details). If you contribute a new script or help improve an existing script, you agree that your contribution is released under the MIT License as well.