@ceramicnetwork/rpc-window

RPC utilities using browser windows

Usage no npm install needed!

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

README

window RPC

RPC utilities using browser windows

Installation

npm install @ceramicnetwork/rpc-window

Usage

Server

import { createServer } from '@ceramicnetwork/rpc-window'

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

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

// Stop server when done
server.unsubscribe()

Client

import { createClient } from '@ceramicnetwork/rpc-window'

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

// Client is in a frame and the server is listening on the parent window
const client = createClient<Methods>('test', window.parent)
await client.request('foo') // 'bar'

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>
  3. target?: Window = window

Returns Observable<ServerPayload<Methods, Namespace>>

createClient()

Type parameters

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

Arguments

  1. namespace: Namespace
  2. target?: Window = window
  3. options?: ClientOptions

Returns RPCClient<Methods>

License

Apache-2.0 OR MIT