Skip to main content

Job decoding logic

Project description

Informatics Matters Data Manager Job Decoder

PyPI package (latest) Build Publish

A package that simplifies the decoding of encoded text strings and validation of Job Definitions and Manifests.

Given an encoded string the decode() method returns the decoded value or an error.

For example, given the following jinja2 encoded string '{{ foo }}, bar={{ bar }}, baz={{ baz }}' and variable map {'foo': 1, 'bar': 2, 'baz': 3} the decoder returns the string 'foo=1, bar=2, baz=3'.

The following encoding/decoding formats are supported: -

  • jinja2 (3.0)

The package also provides validate_job_schema() and validate_manifest_schema() functions, which can (should) be used to validate the Manifests and Job definitions against the built-in schemas.

If you have a Job Definition or Manifest file you can add a reference to the corresponding schema in this package to your file to help you identify schema violations prior to deployment. To do this you just need to add a line starting # yaml-language-server: at the top of your file. For example, you can link to the v2.3.0 Job Definition schema by adding the following line:

# yaml-language-server: $schema=https://raw.githubusercontent.com/InformaticsMatters/squonk2-data-manager-job-decoder/refs/tags/2.3.0/decoder/job-definition-schema.yaml

Installation (Python)

The Job decoder is published on PyPI and can be installed from there:

pip install im-data-manager-job-decoder

Once installed you can validate the definition (expected to be a dictionary formed from the definition YAML file) with:

>>> from decoder import decoder
>>> error: Optional[str] = decoder.validate_manifest_schema(manifest)
>>> error: Optional[str] = decoder.validate_job_schema(job_definition)

And you can decode encoded fields within the job definition. Here we’re decoding the job’s ‘command’ using a map of variables and their values:

>>> decoded, success = decoder.decode(definition['command'],
                                      variables,
                                      'command',
                                      decoder.TextEncoding.JINJA2_3_0)

A method also exists to generate a Data Manger Job documentation URL for the supported repository types. For example, to get the auto-generated documentation URL for a job definition hosted in a GitHub repository you can do this:

>>> doc_url: str = decoder.get_job_doc_url("github",
                                           collection
                                           job_id,
                                           job_definition,
                                           manifest_url)

We support github and gitlab as repository types.

Get in touch

  • Report bugs, suggest features or view the source code on GitHub.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

im_data_manager_job_decoder-2.6.0.tar.gz (17.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

im_data_manager_job_decoder-2.6.0-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file im_data_manager_job_decoder-2.6.0.tar.gz.

File metadata

File hashes

Hashes for im_data_manager_job_decoder-2.6.0.tar.gz
Algorithm Hash digest
SHA256 9d05db20e2263dc66c479d27534a894cde72ed6cdbf731fda1f1456bba44af46
MD5 527012060be3c88a66d65bf82ad21cba
BLAKE2b-256 e01b544af5299604dcb6cfea4d4b0654bac2f21bdbdf59b75c6f94684608bacc

See more details on using hashes here.

Provenance

The following attestation bundles were made for im_data_manager_job_decoder-2.6.0.tar.gz:

Publisher: publish.yaml on InformaticsMatters/squonk2-data-manager-job-decoder

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file im_data_manager_job_decoder-2.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for im_data_manager_job_decoder-2.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9d789cc1ef7dfbfe162457bd3f2b0f2783b7939c34bf4a726e5667ba129e1b94
MD5 f400790ceec1ffc1c4ef419fc879064b
BLAKE2b-256 2efa474cbf46c2c798505e7e88f5ef416b74297bd35c31fa2b93808a95ed898f

See more details on using hashes here.

Provenance

The following attestation bundles were made for im_data_manager_job_decoder-2.6.0-py3-none-any.whl:

Publisher: publish.yaml on InformaticsMatters/squonk2-data-manager-job-decoder

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page