Documentation

@daml/ledger

Client side API implementation for a Daml based ledgers. This library implements the JSON API for a Daml ledger.

The best way to get you started quickly is to use the create-daml-app template:

daml new --template=create-daml-app my-project-name

and to read the Quickstart Guide.

We recommend to use the React framework and the @daml/react library to build frontends for Daml applications. If you choose a different Javascript based framework, please take a look at the source of @daml/react and it's usage of the @daml/ledger library.

The main export of @daml/ledger is the Ledger class. It's constructor takes an authentication token used to communicate with the JSON API, an HTTP base URL and a websocket base URL.

An instance of the Ledger class provides the following methods to communicate with a Daml ledger. Please consult the documentation for their exact signatures.

Create a new contract of the given template with given arguments.

Archive a contract identified by its contract id.

Archive a contract identified by its contract key.

Exercise a choice on a contract identified by its contract id.

Exercise a choice on a contract identified by its contract key.

Create a new contract and, within the same transaction, immediately exercise a choice on it. Primarily meant for consuming choices, but that's not a requirement.

Retrieve contracts for a given template matching a given query. If no query is given, all contracts of that template visible for the submitting party are returned.

Deprecated: prefer streamQueries.

Retrieve a consolidated stream of events for a given template and optional query. The accumulated state is the current set of active contracts matching the query if one was given; if the function was called without a query argument, or the query argument was undefined, the accumulated state will instead contain all of the active contracts for the given template.

Retrieve a consolidated stream of events for a given template and queries. The accumulated state is the current set of active contracts matching at least one of the given queries, or all contracts for the given template if no query is given.

Fetch a contract identified by its contract id.

Fetch a contract identified by its contract key.

Deprecated: prefer streamFetchByKeys.

Retrieve a consolidated stream of CreateEvent's for a given template and contract key. The accumulated state is either the CreateEvent for the active contract matching the given key, or null if there is no currently-active contract for the given key.

Retrieve a consolidated stream of CreateEvent's for a given template and contract keys. The accumulated state is a vector of the same length as the given vector of keys, where each element is the CreateEvent for the current active contract of the corresponding key (element-wise), or null if there is no current active contract for that key.

Note: the given key objects will be compared for (deep) equality with the values returned by the API. As such, they have to be given in the "output" format of the JSON API. See the JSON API docs for details.

For a given list of party identifiers, return full information, or null if the party doesn't exist.

Return an array of PartyInfo for all parties on the ledger.

Allocate a new party.

Returns the current User implicitly described by the currently used JWT.

Fetch a list of all known package IDs.

Given a package ID, fetch the binary data for the corresponding DALF.

Upload a given byte array as a DAR to the ledger. Note that this requires a token with admin access.

https://github.com/digital-asset/daml/tree/main/language-support/ts/daml-ledger

Apache-2.0