All files / kernel-test/src/vats remote-receiver-vat.ts

0% Statements 0/13
0% Branches 0/8
0% Functions 0/3
0% Lines 0/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51                                                                                                     
import { E } from '@endo/eventual-send';
import { makeDefaultExo } from '@metamask/kernel-utils/exo';
 
import type { TestPowers } from '../test-powers.ts';
 
/**
 * Build function for vat that receives remote messages from other kernels.
 *
 * @param vatPowers - Special powers granted to this vat.
 * @param vatPowers.logger - The logger for the vat.
 * @param parameters - Initialization parameters from the vat's config object.
 * @param parameters.name - The name of the vat.
 * @param _baggage - Root of vat's persistent state (not used here).
 * @returns The root object for the new vat.
 */
// eslint-disable-next-line @typescript-eslint/explicit-function-return-type
export function buildRootObject(
  { logger }: TestPowers,
  parameters: { name?: string } = {},
  _baggage: unknown = null,
) {
  const name = parameters?.name ?? 'RemoteReceiver';
  logger.log(`buildRootObject "${name}"`);
 
  let issuerService: unknown;
 
  return makeDefaultExo('remoteReceiverRoot', {
    async bootstrap(
      vats: { receiver?: unknown },
      services: { ocapURLIssuerService?: unknown },
    ) {
      logger.log(`vat ${name} is bootstrap`);
      issuerService = services.ocapURLIssuerService;
 
      if (issuerService && vats.receiver) {
        const url = await E(issuerService).issue(vats.receiver);
        logger.log(`url for receiver: ${url}`);
        return { message: `${name} bootstrap complete`, ocapURL: url };
      }
 
      return { message: `${name} bootstrap complete` };
    },
 
    hello(from: string) {
      const message = `${name} says hello back to ${from}`;
      logger.log(message);
      return message;
    },
  });
}