A module groups a set of triggers and actions sharing a same interest. Most of the time, a module is associated to a product vendor.
A module contains the following items:
- a manifest
manifest.json
- a pyproject file
- a
<module_name>_module
subdirectory holding the python code for triggers and actions. - a list of json file
- an entrypoint
main.py
The manifest holds the information about the module. It defines:
- The unique identifier of the module (field
uuid
) - The name of the module (field
name
) - A slug for the module (field
slug
). The value of this field should match the following regex[a-z-]\+
) - A little description of the module (field
description
) - The version number of the module (field
version
). This field should be updated each time a change is made in the module. This field follows the Semantic versioning. - A description of the configuration of the module with a JSON schema model
A module always hosts a pyproject file. This file describes the dependencies for the triggers and actions of the modules.
Actions and triggers are splitted in two parts:
- a code hosted in the subdirectory
<module_name>_module
- a json file that describes the action or the trigger.
See action.md and trigger.md for more information.
The entrypoint of the module is the file main.py
. This file declares the actions and the triggers to use for the module and associate the actions and the triggers with the description file
A module must be represented as a Python class, based on 'Module' from sekoia-automation-sdk, with its configuration as a pydantic model.