This module allows users to search for and sometimes create github/gitlab issues for a module or system within the foundry UI.
- Form will display a warning if the user is not up to date first.
- Any module or system with a compatible
bugs
url in the manifest will display a link to the module's github/gitlab issues list will be displayed. - For opted-in modules, a form within Foundry will submit a bug report after first searching that package's issue list for similar matches.
- Have a url to a github or gitlab repository issues page in the
bugs
field of your manifest. - Add
allowBugReporter: true
to your manifest json. In versions BEFORE 0.8.3 (broken in 0.8.2) of Foundry you can putallowBugReporter
at the root of the manifest, but starting with 0.8.3 it needs to be inside of theflags
field of the manifest.
0.8.3+
"bugs": "https://github.com/Ethck/legendary-training-wheels/issues",
"flags": {
"allowBugReporter": true
}
The following examples are remnants from the 0.7.X releases for how to make bug-reporter work, but they are kept to show the proper Github/lab links.
Github
"bugs": "https://github.com/Ethck/legendary-training-wheels/issues",
"allowBugReporter": true
Gitlab
"bugs": "https://gitlab.com/Ethck/testing/-/issues",
"allowBugReporter": true
As of Bug Reporter version 1.3.1 there is now an API that a developer can launch and pre-fill with data for bug reports.
The API can be accessed as follows:
game.modules.get("bug-reporter").api;
In the API you will find the following methods available for your use:
- allowBugReporter(modid)
- bugWorkflow(modid, title = "", details = "")
allowBugReporter takes a string of the module name and returns whether or not the module in question supports Bug Reporter.
bugWorkflow takes the modid and option title & details to generate a bug report that will be prefilled with the details of the bug that you provide. These details can be formatted however you desire, but it will be wrapped inside of
Example:
game.modules.get("bug-reporter").api.bugWorkflow("bug-reporter", "Testing the API", "Here are my auto-generated details, perhaps even an error message");
Why are you leveraging an arbitrary, unofficial field on the Manifest instead of providing an API for modules to register themselves?
There is no functional difference between a package which has bug reporter opt-in and one which doesn't. Thus we decided to use a manifest field rather than ask packages to register via API. Some packages might not even register JS at all, such a mechanism would dramatically increase the friction for opting into this service, where a simple manifest field does not.
Being able to report a bug to a compendium package or a css package makes just as much sense as one with JS.
The module looks at all activated modules and the system which have both allowBugReporter: true
and a bugs
field which meets the following criteria in the manifest:
- is a Github or Gitlab repo
- ends in
/issues
If both of these are met, the form is submittable to our API endpoint which first runs some sanity checks against malicious intent before submitting the issue via Github's/Gitlab's API. All of the bugs submitted will come from the leagueoffoundryvttdevs
account on Github, or from the leagueoffvttdevs
account on Gitlab.
Huge thanks to Moo Man for their work on the Bug Reporter for their WFRP4e FVTT system. This work is inspired by Moo Man's work.