Skip to main content

Daml Hub DIT File API Package

Project description

daml-dit-api

API definitions for DIT packages to be hosted in Daml Hub. This mainly contains the type definitions for the format of the dabl-meta.yaml file at the root of each DIT file.

DIT files are also used to contain integrations loaded and run by Daml Hub. This repository also contains documentation (in this README) describing the runtime environment that Daml Hub provides to integrations.

Package Metadata

At their core, DIT files are ZIP archives that follow a specific set of conventions regarding their content. The most important of these conventions is the presence of a YAML metadata file at the root of the archive and named dabl-meta.yaml. This metadata file contains catalog information describing the contents of the DIT, as well as any packaging details needed to successfully deploy a DIT file into Daml Hub. An example of a deployment instruction is a subdeployment. A subdeployment instructs Daml Hub to deploy a specific subfile within the DIT file. A DIT file that contains an embedded DAR file could use a subdeployment to ensure that the embedded DAR file is deployed to the ledger when the DIT is deployed. In this way, a DIT file composed of multiple artifacts (DARs, Bots, UI's, etc.) can be constructed to deploy a set of artifacts to a single ledger in a single action.

Integrations

Integrations are a special case of DIT file that are augmented with the ability to run as an executable within a Daml Hub cluster. This is done by packaging Python DAZL bot code into an executable ZIP using PEX and augmenting tha resulting file with the metadata and other resources needed to make it a correctly formed DIT file.

Logically speaking, Daml Hub integrations are DAZL bots packaged with information needed to fit them into the Daml Hub runtime and user interface. The major functional contrast between a Daml Hub integration and a Python Bot is that the integration has the external network access needed to connect to an outside system and the Python Bot does not. Due to the security implications of running within Daml Hub with external network access, integrations can only be deployed with the approval of DA staff.

Developing Integrations

The easiest way to develop an integration for Daml Hub is to use the framework library and ddit build tool. The integration framework presents a Python API closely related to the DAZL bot api and ensures that integrations follow the conventions required to integrate into Daml Hub.

Unless you know exactly what you are doing and why you are doing it, use the framework.

The Integration Runtime Environment

By convention, integrations accept a number of environment variables that specify key paramaters. Integrations built with the framework use defaults for these variables that connect to a default locally configured sandbox instance.

Variables provided by Daml Hub include the following:

Variable Default Purpose
DAML_LEDGER_URL http://localhost:6865 Address of local ledger gRPC API
DABL_HEALTH_PORT 8089 Port for HTTP endpoint. (Used for both liveness/readiness and webhooks)
DABL_JWKS_URL HTTP URL for JWKS Repository
DABL_INTEGRATION_METADATA_PATH 'int_args.yaml' Path to local metadata file
DABL_INTEGRATION_TYPE_ID Type ID for the specific integration within the DIT to run
DABL_LEDGER_PARTY Party identifier for network connection
DABL_LOG_LEVEL 0 Log verbosity level - 0 up to 50, inclusive.

(Note that for legacy reasons, the ledger URL is also available under the DABL_LEDGER_URL environment variable.)

Logging

DABL integrations use the default Python logging package, and the framework provides specific support for controlling log level at runtime. To integrate properly with this logic, it is important that integrations use the integration logger. This logger is switched from INFO level to DEBUG level at a DABL_LOG_LEVEL setting of 10 or above.

The preferred way of creating an integration logger is via the getIntegrationLogger function in the API package.

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

daml-dit-api-0.4.4.tar.gz (9.2 kB view details)

Uploaded Source

Built Distribution

daml_dit_api-0.4.4-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file daml-dit-api-0.4.4.tar.gz.

File metadata

  • Download URL: daml-dit-api-0.4.4.tar.gz
  • Upload date:
  • Size: 9.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.5 Darwin/20.5.0

File hashes

Hashes for daml-dit-api-0.4.4.tar.gz
Algorithm Hash digest
SHA256 266f1fff74e5a6e3f39e064fc061e0d82f1d983d25e126b3d3d8d01770410dcc
MD5 cfe9d2dbf280248ab747c73819e36b1e
BLAKE2b-256 61fe4f1041b15590e4aab31f05b87eaf911a9aac1e56b0cd75c88755006ca5f7

See more details on using hashes here.

File details

Details for the file daml_dit_api-0.4.4-py3-none-any.whl.

File metadata

  • Download URL: daml_dit_api-0.4.4-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.5 Darwin/20.5.0

File hashes

Hashes for daml_dit_api-0.4.4-py3-none-any.whl
Algorithm Hash digest
SHA256 3a086882ba8b5cab4c73568b189a2f049a337fe34da886ad55c7081b5a1f353d
MD5 95a94c1f0f601d15be7be9483b32440c
BLAKE2b-256 4686c56a5b93803f8345c91cbccdbce3224a4123b3f0279b808a401efe0f97c5

See more details on using hashes here.

Supported by

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