tuai

Asynchronous request–response iframe messaging

Usage no npm install needed!

<script type="module">
  import tuai from 'https://cdn.skypack.dev/tuai';
</script>

README

tuai

Asynchronous request–response iframe messaging

About

The goal of Tuai is to facilitate asynchronous request–response iframe messaging.

Sender:

The sender sends messages to the iframe.

const response = await sender.send({ a: 5, b: 3 });
console.log("The sum of a and b is", response);

Receiver

The receiver, inside the iframe, listens to incoming messages.

receiver.addResponder(ctx => {
  return ctx.message.a + ctx.message.b;
});

Installation

NPM

npm install --save tuai

npm package link

CDN

<script src="https://unpkg.com/tuai@latest"></script>

Usage

Sender

import { Sender } from "tuai";
const sender = new Sender({
  querySelectors: ["#portal"],
  receiverOrigin: "https://receiver.fake"
});

querySelectors: array of selectors used to find the iframe of the receiver (delegated to Document.querySelector())

receiverOrigin: origin of the receiver

Receiver

import { Receiver } from "tuai";
const receiver = new Receiver();

API

Sender

sendMessage(message)

Sends a message (of any type) and returns a promise with the answer of the receiver.

const response = await sender.send("Hello, World!");
console.log(response);

Receiver

addResponder(responder)

Registers a responder that will respond to incomding messages.

receiver.addResponder(function(ctx) {
  return "Goodbye, World!";
});

A responder:

Must be a function or a promise:

  • Function: the return value (if present) will be sent as the answer.
  • Promise: the resolved (or rejected) value will be sent as the answer.

Has access to a ctx variable:

ctx.origin: the origin of sender, can (read: should) be used to verify the origin:

if (ctx.origin !== "https://sender.fake") {
  throw new Error("Do I know you?");
}

ctx.message: the message it is responding to:

if (!ctx.mesage.startsWith("Hello,")) {
  throw new Error("Don't be so rude!");
}

Git hooks

  • pre-commit: re-format staged files with Prettier

Scripts

# Build for production
npm run build

# Re-format files with Prettier
npm run prettier