@ceramicnetwork/rpc-iframe

RPC utilities using iframe

Usage no npm install needed!

<script type="module">
  import ceramicnetworkRpcIframe from 'https://cdn.skypack.dev/@ceramicnetwork/rpc-iframe';
</script>

README

iframe RPC

RPC utilities using iframe

Installation

npm install @ceramicnetwork/rpc-iframe

Usage

import { createClient, createServer } from '@ceramicnetwork/rpc-iframe'

type Methods = {
  foo: { result: string }
}

const methods = { foo: () => 'bar' }
const server = createServer<Methods>('test', methods).subscribe()

const client = createClient<Methods>('test', window)
await client.request('foo') // 'bar'

// Stop server when done
server.unsubscribe()

Types

ClientOptions

Uses UnwrapObservableOptions from @ceramicnetwork/transport-subject and PostMessageTransportOptions from @ceramicnetwork/transport-postmessage

type ClientOptions = UnwrapObservableOptions & PostMessageTransportOptions

IncomingRequest

Uses RPCMethods, RPCRequest, IncomingMessage from @ceramicnetwork/transport-postmessage and Wrapped from @ceramicnetwork/transport-subject

type IncomingRequest<
  Methods extends RPCMethods,
  Namespace extends string = string
> = IncomingMessage<Wrapped<RPCRequest<Methods, keyof Methods>, Namespace>>

ServerPayload

Uses RPCMethods, HandledPayload from @ceramicnetwork/rpc-postmessage and IncomingRequest

type ServerPayload<Methods extends RPCMethods, Namespace extends string> = HandledPayload<
  IncomingRequest<Methods, Namespace>,
  Methods,
  keyof Methods
>

APIs

createServer()

Type parameters

  1. Methods extends RPCMethods
  2. Namespace extends string = string

Arguments

  1. namespace: Namespace
  2. methods: HandlerMethods<IncomingRequest<Methods, Namespace>, Methods>

Returns Observable<ServerPayload<Methods, Namespace>>

createClient()

Type parameters

  1. Methods extends RPCMethods
  2. Namespace extends string = string

Arguments

  1. namespace: Namespace
  2. target: PostMessageTarget
  3. options?: ClientOptions

Returns RPCClient<Methods>

License

Apache-2.0 OR MIT