From 331944ca937d75c6977430aed361d6ba08010057 Mon Sep 17 00:00:00 2001 From: "Mark S. Miller" Date: Sun, 10 Dec 2023 19:27:51 -0800 Subject: [PATCH] fix(zoe): Fix guards to accurately guard args --- packages/zoe/src/typeGuards.js | 17 ++++++++++------- .../zoe/src/zoeService/installationStorage.js | 8 ++++++-- 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/packages/zoe/src/typeGuards.js b/packages/zoe/src/typeGuards.js index 14af2f0a1edd..cbc330fa3749 100644 --- a/packages/zoe/src/typeGuards.js +++ b/packages/zoe/src/typeGuards.js @@ -276,10 +276,12 @@ export const ZoeStorageManagerIKit = harden({ getBundleIDFromInstallation: M.call(InstallationShape).returns( M.eref(M.string()), ), - installBundle: M.call(M.or(InstanceHandleShape, BundleShape)).returns( - M.promise(), - ), - installBundleID: M.call(M.string()).returns(M.promise()), + installBundle: M.call(M.or(InstanceHandleShape, BundleShape)) + .optional(M.string()) + .returns(M.promise()), + installBundleID: M.call(M.string()) + .optional(M.string()) + .returns(M.promise()), getPublicFacet: M.call(InstanceHandleShape).returns( M.eref(M.remotable('PublicFacet')), @@ -310,6 +312,7 @@ export const ZoeStorageManagerIKit = harden({ IssuerPKeywordRecordShape, M.or(InstanceHandleShape, BundleShape), M.or(BundleCapShape, BundleShape), + M.string(), ).returns(M.promise()), unwrapInstallation: M.callWhen(M.eref(InstallationShape)).returns( UnwrappedInstallationShape, @@ -321,10 +324,10 @@ export const ZoeStorageManagerIKit = harden({ }); export const ZoeServiceI = M.interface('ZoeService', { - install: M.call(M.any()).returns(M.promise()), - installBundleID: M.call(M.string()).returns(M.promise()), + install: M.call(M.any()).optional(M.string()).returns(M.promise()), + installBundleID: M.call(M.string()).optional(M.string()).returns(M.promise()), startInstance: M.call(M.eref(InstallationShape)) - .optional(IssuerPKeywordRecordShape, M.any(), M.any()) + .optional(IssuerPKeywordRecordShape, M.record(), M.record(), M.string()) .returns(M.promise()), offer: M.call(M.eref(InvitationShape)) .optional(ProposalShape, PaymentPKeywordRecordShape, M.any()) diff --git a/packages/zoe/src/zoeService/installationStorage.js b/packages/zoe/src/zoeService/installationStorage.js index 9b12197d706d..b06c5ed26cf8 100644 --- a/packages/zoe/src/zoeService/installationStorage.js +++ b/packages/zoe/src/zoeService/installationStorage.js @@ -84,8 +84,12 @@ export const makeInstallationStorage = (getBundleCapForID, zoeBaggage) => { InstanceHandleShape, M.recordOf(M.string(), M.string({ stringLengthLimit: Infinity })), ), - ).returns(M.promise()), - installBundleID: M.call(M.string()).returns(M.promise()), + ) + .optional(M.string()) + .returns(M.promise()), + installBundleID: M.call(M.string()) + .optional(M.string()) + .returns(M.promise()), unwrapInstallation: M.callWhen(M.await(InstallationShape)).returns( UnwrappedInstallationShape, ),