Welcome to the new Golem Cloud Docs! 👋
Documentation
Python Language Guide
Promises

Working with Golem Promises in Python

Golem promises provide a way for Golem workers to wait on an external condition. The worker creates the promise and somehow sends its identifier to the external system responsible for completing the promise. Then the worker can await the promise, being suspended until the external system completes the promise using Golem's REST API.

It is also possible to complete a promise from within a Golem worker using the Golem SDK.

When a promise is completed, an arbitrary byte array can be attached to it as a payload - this data is returned to the awaiting worker when is continues execution.

In Python the promise API can be used by directly importing and using the Golem runtime API.

Adding as a dependency

To use Golem's runtime API, add all the WIT files from https://github.com/golemcloud/golem-wit/tree/main/wit/deps (opens in a new tab) in the project's wit/deps directory, and then importing this interface to the component's world:

world example {
    import golem:api/host@1.1.0;
    // ...
}

The golem-cli new examples for Python automatically create the wit/deps directory for you, except the c-actor-minimal one.

Creating a promise

To create a promise simply call the create_promise function:

from py_example.imports.host import create_promise
 
promise_id = create_promise()

The returned value, PromiseId, is defined as the following:

@dataclass
class Uuid:
    """
    UUID
    """
    high_bits: int
    low_bits: int
 
@dataclass
class ComponentId:
    """
    Represents a Golem component
    """
    uuid: Uuid
 
@dataclass
class WorkerId:
    """
    Represents a Golem worker
    """
    component_id: ComponentId
    worker_name: str
 
@dataclass
class PromiseId:
    """
    A promise ID is a value that can be passed to an external Golem API to complete that promise
    from an arbitrary external source, while Golem workers can await for this completion.
    """
    worker_id: WorkerId
    oplog_idx: int

Deleting a promise

If a promise is no longer used, it has to be deleted with

delete_promise(promise_id);

Awaiting a promise

To await a promise, use the await_promise function:

payload = await_promise(promise_id)

The resulting payload is a byte array (bytes) containig the data attached to the promise on completion.

Completing a promise from within a worker

To complete a promise from within a worker, use the complete_promise function:

complete_promise(promise_id, str.encode("hello world"))

Completing a promise from an external source

To see how to use the promise ID to complete a promise through the external REST API, check the REST API documentation.