The main API used to interact with Streamr.

Hierarchy

  • StreamrClient

Important

  • Creates a new stream.

    Parameters

    • propsOrStreamIdOrPath: string | Partial<StreamMetadata> & {
          id: string;
      }

      the stream id to be used for the new stream, and optionally, any associated metadata

    Returns Promise<Stream>

  • Gets a stream, creating one if it does not exist.

    Parameters

    • props: {
          id: string;
          partitions?: number;
      }

      the stream id to get or create. Field partitions is only used if creating the stream.

      • id: string
      • Optional partitions?: number

    Returns Promise<Stream>

  • Gets a stream.

    Returns

    rejects if the stream is not found

    Parameters

    • streamIdOrPath: string

    Returns Promise<Stream>

  • Returns a list of subscriptions matching the given criteria.

    Parameters

    • Optional streamDefinition: StreamDefinition

      leave as undefined to get all subscriptions

    Returns Promise<Subscription<unknown>[]>

  • Publishes a message to a stream partition in the network.

    Returns

    the published message (note: the field content is encrypted if the stream is private)

    Type Parameters

    • T

    Parameters

    • streamDefinition: StreamDefinition

      the stream or stream partition to publish the message to

    • content: T

      the content (the payload) of the message

    • Optional metadata: PublishMetadata

      provide additional metadata to be included in the message or to control the publishing process

    Returns Promise<Message>

  • Performs a resend of stored historical data.

    Returns

    a MessageStream that provides an alternative way of iterating messages. Rejects if the stream is not stored (i.e. is not assigned to a storage node).

    Type Parameters

    • T

    Parameters

    • streamDefinition: StreamDefinition

      the stream partition for which data should be resent

    • options: ResendOptions

      defines the kind of resend that should be performed

    • Optional onMessage: MessageListener<T, unknown>

      callback will be invoked for each message retrieved

    Returns Promise<MessageStream<T>>

  • Subscribes to a stream partition in the network.

    Returns

    a Subscription that can be used to manage the subscription etc.

    Type Parameters

    • T

    Parameters

    • options: Object

      the stream or stream partition to subscribe to, additionally a resend can be performed by providing resend options

    • Optional onMessage: MessageListener<T, unknown>

      callback will be invoked for each message received in subscription

    Returns Promise<Subscription<T>>

  • Unsubscribes from streams or stream partitions in the network.

    Remarks

    no-op if subscription does not exist

    Parameters

    • Optional streamDefinitionOrSubscription: StreamDefinition | Subscription<unknown>

      leave as undefined to unsubscribe from all existing subscriptions.

    Returns Promise<unknown>

Other

  • Parameters

    • config: Partial<Omit<StrictStreamrClientConfig, "network" | "contracts" | "decryption"> & {
          contracts: Partial<{
              ethereumNetworks: Record<string, EthereumNetworkConfig>;
              mainChainRPCs: ChainConnectionInfo;
              maxConcurrentCalls: number;
              storageNodeRegistryChainAddress: string;
              streamRegistryChainAddress: string;
              streamRegistryChainRPCs: ChainConnectionInfo;
              streamStorageRegistryChainAddress: string;
              theGraphUrl: string;
          }>;
          decryption: Partial<{
              keyRequestTimeout: number;
              maxKeyRequestsPerSecond: number;
          }>;
          network: Partial<Omit<NetworkNodeConfig, "trackers" | "metricsContext"> & {
              trackers: TrackerRegistryContract | TrackerRegistryRecord[];
          }>;
      }> = {}

    Returns StreamrClient

id: string
generateEthereumAccount: (() => {
    address: string;
    privateKey: string;
}) = _generateEthereumAccount

Type declaration

    • (): {
          address: string;
          privateKey: string;
      }
    • Returns {
          address: string;
          privateKey: string;
      }

      • address: string
      • privateKey: string
  • Adds an encryption key for a given stream to the key store.

    Remarks

    Keys will be added to the store automatically by the client as encountered. This method can be used to manually add some known keys into the store.

    Parameters

    Returns Promise<void>

  • Assigns a stream to a storage node.

    Parameters

    • streamIdOrPath: string
    • storageNodeAddress: string

    Returns Promise<void>

  • Used to manually initialize the network stack and connect to the network.

    Remarks

    Connecting is handled automatically by the client. Generally this method need not be called by the user.

    Returns Promise<void>

  • Deletes a stream.

    Parameters

    • streamIdOrPath: string

    Returns Promise<void>

  • Destroys an instance of a StreamrClient by disconnecting from peers, clearing any pending tasks, and freeing up resources. This should be called once a user is done with the instance.

    Remarks

    As the name implies, the client instance (or any streams or subscriptions returned by it) should not be used after calling this method.

    Returns Promise<void>

  • Returns the list of all permissions in effect for a given stream.

    Parameters

    • streamIdOrPath: string

    Returns Promise<PermissionAssignment[]>

  • Gets the metadata of a storage node from the storage node registry.

    Returns

    rejects if the storage node is not found

    Parameters

    • nodeAddress: string

    Returns Promise<StorageNodeMetadata>

  • Gets a list of storage nodes.

    Parameters

    • Optional streamIdOrPath: string

      if a stream is given, returns the list of storage nodes the stream has been assigned to; leave as undefined to return all storage nodes

    Returns Promise<EthereumAddress[]>

  • Gets all streams assigned to a storage node.

    Returns

    a list of Stream as well as blockNumber of result (i.e. blockchain state)

    Parameters

    • storageNodeAddress: string

    Returns Promise<{
        blockNumber: number;
        streams: Stream[];
    }>

  • Gets all ethereum addresses that have PUBLISH permission to the stream.

    Parameters

    • streamIdOrPath: string

    Returns AsyncIterable<EthereumAddress>

  • Gets all ethereum addresses that have SUBSCRIBE permission to the stream.

    Parameters

    • streamIdOrPath: string

    Returns AsyncIterable<EthereumAddress>

  • Grants permissions on a given stream.

    Parameters

    Returns Promise<void>

  • Checks whether the given permission is in effect.

    Parameters

    Returns Promise<boolean>

  • Checks whether a stream is assigned to a storage node.

    Parameters

    • streamIdOrPath: string
    • storageNodeAddress: string

    Returns Promise<boolean>

  • Checks whether a given ethereum address has PUBLISH permission to a stream.

    Parameters

    • streamIdOrPath: string
    • userAddress: string

    Returns Promise<boolean>

  • Checks whether a given ethereum address has SUBSCRIBE permission to a stream.

    Parameters

    • streamIdOrPath: string
    • userAddress: string

    Returns Promise<boolean>

  • Unassigns a stream from a storage node.

    Parameters

    • streamIdOrPath: string
    • storageNodeAddress: string

    Returns Promise<void>

  • Revokes permissions on a given stream.

    Parameters

    Returns Promise<void>

  • Searches for streams based on given criteria.

    Parameters

    • term: undefined | string

      a search term that should be part of the stream id of a result

    • permissionFilter: undefined | SearchStreamsPermissionFilter

      permissions that should be in effect for a result

    Returns AsyncIterable<Stream>

  • Sets a list of permissions to be in effect.

    Remarks

    Can be used to set the permissions of multiple streams in one transaction. Great for doing bulk operations and saving gas costs. Notice that the behaviour is overwriting, therefore any existing permissions not defined will be removed (per stream).

    Parameters

    Returns Promise<void>

  • Sets the metadata of a storage node in the storage node registry.

    Remarks

    Acts on behalf of the wallet associated with the current StreamrClient instance.

    Parameters

    • metadata: undefined | StorageNodeMetadata

      if undefined, removes the storage node from the registry

    Returns Promise<void>

  • Updates the metadata of a stream.

    Parameters

    • props: Partial<StreamMetadata> & {
          id: string;
      }

      the stream id and the metadata fields to be updated

    Returns Promise<Stream>

  • Waits for a message to be stored by a storage node.

    Returns

    rejects if message was found in storage before timeout

    Parameters

    • message: Message

      the message to be awaited for

    • Optional options: {
          count?: number;
          interval?: number;
          messageMatchFn?: ((msgTarget: Message, msgGot: Message) => boolean);
          timeout?: number;
      }

      additional options for controlling waiting and message matching

      • Optional count?: number

        Controls size of internal resend used in polling.

      • Optional interval?: number

        Determines how often should storage node be polled.

      • Optional messageMatchFn?: ((msgTarget: Message, msgGot: Message) => boolean)
          • (msgTarget: Message, msgGot: Message): boolean
          • Used to set a custom message equality operator.

            Deprecated

            Parameters

            • msgTarget: Message

              message being waited for (i.e. message)

            • msgGot: Message

              candidate message polled from storage node

            Returns boolean

      • Optional timeout?: number

        Timeout after which to give up if message was not seen.

    Returns Promise<void>

Generated using TypeDoc