Quilt version requires: QSL and GroovyDuvet
Forge version requires: GML
WhatsUp is a tool for datapacks that allows servers to query a provided web endpoint at a given frequency, and execute
functions (the normal .mcfunction type) based on the results returned by that endpoint.
WhatsUp defines both listeners and predicates. listeners are defined at data/<namespace>/whatsup/listeners/<name>.json,
and take the following structure:
endpoint - The URL to be queried by the listenerfrequency - An integer representing how many seconds should pass between queries of the endpointactions - A list of actions to do based on the returned result of the endpoint. Each takes the following form:
predicate - The resource location of a predicate to check against the endpoint's resultfunction - The resource location of a function to execute if the predicate passeslevels - (Optional; defaults to ["overworld"]) A list of dimensions to run the provided function inthen - (Optional) a list of locations of other listeners to chain after this listenerstorage - (Optional) a map of property names to resource locations specifying command data storage that the predicate has access toPredicates are stored at data/<namespace>/whatsup/predicates/<name>.groovy, and are groovy scripts. The groovy environment
the predicates run in has access to the context variable, which has the following properties:
text - The unprocessed response textjson - The a Map of the response parsed as JSON, or null if the response is not a JSON objectstorage - Contains a property for every command data storage specified in the action; data storages can be queried and mutated.
This context object is also available as the delegate of the script, so a leading context. to access these properties is optional.An example datapack can be found on the GitHub releases.
The mod also provides the /whatsup command for easily testing datapacks; this can be used to run any listener immediately.

Allows datapacks to query external APIs and run functions based on the result