A Python package to communicate with a migas server.
migas
(mee-gahs) is a Python client to facilitate communication with a migas
server.
To start communicating with a migas
server, the client must first be setup.
import migas; migas.setup()
By default, migas-py
will communicate with the official hosted migas
server.
However it can easily be configured to communicate with any hosted migas
server.
import migas; migas.setup(endpoint='your-endpoint')
setup()
will populate the interal configuration, which is done at the process level.
migas
includes the following functions to communicate with the telemetry server:
Send a breadcrumb with usage information to the server. Usage information includes:
- application
- application version
- application status
The server will attempt to return version information about the project.
add_project example
>>> add_project('nipreps/migas-py', '0.0.1')
{'bad_versions': [],
'cached': True,
'latest_version': '0.0.4',
'message': '',
'success': True}
Check number of uses a project
has received from a start date, and optionally an end date.
If no end date is specified, the current datetime is used.
get_usage example
>>> get_usage('nipreps/migas-py', '2022-07-01')
{'hits': 7, 'message': '', 'unique': False, 'success': True}
migas
can controlled by the following environmental variables:
Envvar | Description | Value | Default |
---|---|---|---|
MIGAS_OPTOUT | Disable telemetry collection | Any | None |
MIGAS_TIMEOUT | Seconds to wait for server response | Number >= 0 | 5 |
MIGAS_LOG_LEVEL | Logger level | Logging levels | WARNING |
The internal configuration stores the following telemetry information:
- language and language version
- operating system
- run within a container
- run from continuous integration