0.6.1 • Published 3 years ago

@ceramicnetwork/rpc-window v0.6.1

Weekly downloads
-
License
(Apache-2.0 OR MI...
Repository
github
Last release
3 years ago

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