Skip to content

Latest commit

 

History

History
50 lines (34 loc) · 2.59 KB

File metadata and controls

50 lines (34 loc) · 2.59 KB

subscribe( ... )

  • Returning non-void in the callback function passed to the Sdk.payload.subscribe() method
  • Manually calling <PayloadSubscription>.resolve() on the object returned by the Sdk.payload.subscribe() method

The subscription will be closed by either:

Status updates can be processed by providing a callback function to the Sdk.payload.subscribe() method. Alternatively, the (by the Sdk.payload.subscribe() method) returned raw websocket can be used to listen for WebSocket onmessage events.

More information about the status update events & sample event data: status-updates

  • The payload is opened by a XUMM App user (webpage)
  • The payload is opened by a XUMM App user (in the app)
  • Payload expiration updates (remaining time in seconds)
  • The payload was resolved by rejecting
  • The payload was resolved by accepting (signing)

To subscribe to live payload status updates, the XUMM SDK can setup a WebSocket connection and monitor live status events. Emitted events include:

Payload subscriptions: live updates

If a callback function is not provided, the subscription will stay active until the <PayloadSubscription>.resolve() method is called manually, eg. based on handling <PayloadSubscription>.websocket.onmessage events.

When a callback function is provided, for every payload specific event the callback function will be called with <SubscriptionCallbackParams>.

The <SubscriptionCallbackParams>.data property contains parsed JSON containing event information.

Either by calling <SubscriptionCallbackParams>.resolve() or by returning a non-void value in the callback function the subscription will be ended, and the <PayloadSubscription>.resolved promise will resolve with the value returned or passed to the <SubscriptionCallbackParams>.resolve() method.

Resolving (by returning non-void in the callback or calling resolve() manually) closes the WebSocket client the XUMM SDK sets up 'under the hood'.

The <PayloadSubscription> object looks like this:

{
  payload: XummPayload,
  resolved: Promise<unknown> | undefined
  resolve: (resolveData?: unknown) => void
  websocket: WebSocket
}

Object

async Sdk.payload.subscribe (
  payload: string | XummPayload | CreatedPayload,
  callback?: onPayloadEvent
): Promise<PayloadSubscription>