All files / service-matcher/src cluster-config.ts

100% Statements 4/4
100% Branches 1/1
100% Functions 1/1
100% Lines 4/4

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              1x               1x                                             3x 3x                      
import type { ClusterConfig } from '@metamask/ocap-kernel';
 
/**
 * The bootstrap vat name used in the matcher's cluster config. Exported
 * so that host-side code reading the bootstrap result can address the
 * right vat.
 */
export const MATCHER_VAT_NAME = 'matcher';
 
/**
 * Filename of the matcher vat bundle as produced by `yarn bundle-vat` in
 * this package (the ocap-kernel CLI writes the bundle next to the source
 * as `index.bundle`). A launcher supplies a `bundleBaseUrl` pointing at
 * the directory containing this file.
 */
export const MATCHER_BUNDLE_FILENAME = 'index.bundle';
 
/**
 * Shape of the matcher subcluster's bootstrap result.
 */
export type MatcherBootstrapResult = {
  matcherUrl: string;
};
 
/**
 * Build a `ClusterConfig` for launching the matcher subcluster.
 *
 * @param options - Configuration options.
 * @param options.bundleBaseUrl - Base URL (or filesystem path) where the
 * matcher vat bundle is reachable. The bundle filename is appended.
 * @param options.forceReset - Whether to reset the subcluster on launch.
 * Defaults to `false`.
 * @returns A ClusterConfig ready for `kernel.launchSubcluster(...)`.
 */
export function makeMatcherClusterConfig(options: {
  bundleBaseUrl: string;
  forceReset?: boolean;
}): ClusterConfig {
  const { bundleBaseUrl, forceReset = false } = options;
  return {
    bootstrap: MATCHER_VAT_NAME,
    forceReset,
    services: ['ocapURLIssuerService', 'ocapURLRedemptionService'],
    vats: {
      [MATCHER_VAT_NAME]: {
        bundleSpec: `${bundleBaseUrl}/${MATCHER_BUNDLE_FILENAME}`,
      },
    },
  };
}