diff --git a/packages/cactus-core-api/src/main/typescript/plugin/plugin-registry.ts b/packages/cactus-core-api/src/main/typescript/plugin/plugin-registry.ts index 875c2e542b..833f2a5821 100644 --- a/packages/cactus-core-api/src/main/typescript/plugin/plugin-registry.ts +++ b/packages/cactus-core-api/src/main/typescript/plugin/plugin-registry.ts @@ -1,6 +1,7 @@ import { Optional } from "typescript-optional"; import { ICactusPlugin, isICactusPlugin } from "../plugin/i-cactus-plugin"; import { PluginAspect } from "../plugin/plugin-aspect"; +import { IPluginKeychain } from "./keychain/i-plugin-keychain"; /** * This interface describes the constructor options object that can be used to provide configuration parameters to @@ -80,6 +81,21 @@ export class PluginRegistry { return Optional.ofNullable(plugin as T); } + public findOneByKeychainId(keychainId: string): T { + const fnTag = "PluginRegistry#findOneByKeychainId()"; + if (typeof keychainId !== "string" || keychainId.trim().length < 1) { + throw new Error(`${fnTag} need keychainId arg as non-blank string.`); + } + + const plugin = this.findManyByAspect( + PluginAspect.KEYCHAIN + ).find((keychainPlugin) => keychainPlugin.getKeychainId() === keychainId); + + return Optional.ofNullable(plugin as T).orElseThrow( + () => new Error(`${fnTag} No keychain found for ID ${keychainId}`) + ); + } + public findManyByAspect(aspect: PluginAspect): T[] { return this.getPlugins().filter((p) => p.getAspect() === aspect) as T[]; } diff --git a/packages/cactus-core-api/src/test/typescript/unit/plugin-registry.test.ts b/packages/cactus-core-api/src/test/typescript/unit/plugin-registry.test.ts new file mode 100644 index 0000000000..4aee8b16c0 --- /dev/null +++ b/packages/cactus-core-api/src/test/typescript/unit/plugin-registry.test.ts @@ -0,0 +1,54 @@ +import test, { Test } from "tape"; +import { v4 as uuidv4 } from "uuid"; + +import { + ICactusPlugin, + IPluginKeychain, + PluginAspect, + PluginRegistry, +} from "../../../main/typescript/public-api"; + +test("PluginRegistry", (tMain: Test) => { + test("findOneByKeychainId() finds plugin by keychain ID", (t: Test) => { + const keychainId = uuidv4(); + + const mockKeychainPlugin = { + getKeychainId: () => keychainId, + getAspect: () => PluginAspect.KEYCHAIN, + } as IPluginKeychain; + + const pluginRegistry = new PluginRegistry({ + plugins: [ + mockKeychainPlugin, + { + getAspect: () => PluginAspect.CONSORTIUM, + } as ICactusPlugin, + { + getAspect: () => PluginAspect.KV_STORAGE, + } as ICactusPlugin, + { + getAspect: () => PluginAspect.LEDGER_CONNECTOR, + } as ICactusPlugin, + ], + }); + + t.doesNotThrow(() => pluginRegistry.findOneByKeychainId(keychainId)); + const keychainPlugin = pluginRegistry.findOneByKeychainId(keychainId); + t.equal(keychainPlugin, mockKeychainPlugin, "Finds same object OK"); + + t.throws( + () => pluginRegistry.findOneByKeychainId(""), + /need keychainId arg as non-blank string/, + "Check for keychain ID blankness OK" + ); + t.throws( + () => pluginRegistry.findOneByKeychainId("x"), + /No keychain found for ID/, + "Throws for keychain not found OK" + ); + + t.end(); + }); + + tMain.end(); +});