@agoric/vats 0.15.2-dev-35e67be.0 → 0.15.2-dev-872bb3b.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/index.js +1 -0
  2. package/package.json +17 -19
  3. package/scripts/build-bundles.js +6 -1
  4. package/src/bridge.d.ts +12 -3
  5. package/src/bridge.d.ts.map +1 -1
  6. package/src/core/boot-chain.d.ts +1 -1
  7. package/src/core/boot-chain.d.ts.map +1 -1
  8. package/src/core/startWalletFactory.d.ts +2 -2
  9. package/src/core/types.d.ts +5 -5
  10. package/src/core/types.d.ts.map +1 -1
  11. package/src/core/types.js +3 -1
  12. package/src/core/utils.d.ts +14 -14
  13. package/src/lib-board.d.ts +1 -1
  14. package/src/lib-board.d.ts.map +1 -1
  15. package/src/mintHolder.d.ts +1 -1
  16. package/src/mintHolder.d.ts.map +1 -1
  17. package/src/nameHub.d.ts +18 -2
  18. package/src/nameHub.d.ts.map +1 -1
  19. package/src/vat-agoricNames.d.ts +1 -1
  20. package/src/vat-agoricNames.d.ts.map +1 -1
  21. package/src/vat-bank.d.ts +4 -1
  22. package/src/vat-bank.d.ts.map +1 -1
  23. package/src/vat-board.d.ts +1 -1
  24. package/src/vat-board.d.ts.map +1 -1
  25. package/src/vat-bridge.d.ts +2 -30
  26. package/src/vat-bridge.d.ts.map +1 -1
  27. package/src/vat-mints.d.ts +2 -2
  28. package/src/vat-priceAuthority.d.ts +1 -1
  29. package/src/vat-priceAuthority.d.ts.map +1 -1
  30. package/src/vat-provisioning.d.ts +1 -1
  31. package/src/vat-provisioning.d.ts.map +1 -1
  32. package/src/virtual-purse.d.ts +31 -6
  33. package/src/virtual-purse.d.ts.map +1 -1
  34. package/tools/boot-test-utils.d.ts +0 -1
  35. package/tools/boot-test-utils.d.ts.map +1 -1
  36. package/tools/boot-test-utils.js +0 -7
  37. package/{jsconfig.build.json → tsconfig.build.json} +1 -1
  38. package/{jsconfig.json → tsconfig.json} +2 -0
  39. package/src/provisionPool.d.ts +0 -165
  40. package/src/provisionPool.d.ts.map +0 -1
  41. package/src/provisionPool.js +0 -117
  42. package/src/provisionPoolKit.d.ts +0 -379
  43. package/src/provisionPoolKit.d.ts.map +0 -1
  44. package/src/provisionPoolKit.js +0 -461
@@ -1 +0,0 @@
1
- {"version":3,"file":"provisionPoolKit.d.ts","sourceRoot":"","sources":["provisionPoolKit.js"],"names":[],"mappings":"AA2DO,0EALkB,KAAK,IAAI,CAAC,KAAK,QAAQ,IAAI,CAAC,iBAC1C,MAAM,IAAI,0DAKP,0BAA0B;;;;GA+BvC;AAWM,iDARI,OAAO,kBAAkB,EAAE,OAAO,8CAClC;IACV,eAAmB,EAAE,OAAO,6CAA6C,EAAE,eAAe,CAAC;IAC3F,MAAU,EAAE,GAAG,CAAC;IAChB,QAAY,EAAE,OAAO,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7C,GAAO,EAAE,GAAG,CAAC;CACV;IAuVqB,SAAS,EAArB,KAAK;IACmB,WAAW,EAAnC,KAAK,WAAW,CAAC;;;QAzQtB,qCAAqC;4CAAzB,MAAM,EAAE;;YA+CpB,8BAA8B;kCAAlB,MAAM;;;;;;;;;;;;;;;;;;;;;;;;YAqBlB;;;eAGG;+BAFQ,MAAM,GACJ,OAAO;;QA9DpB,gDAAgD;6BAApC,0BAA0B;;;;;;QA6BtC;;;WAGG;uBAFQ,KAAK,YACL,WAAW;;;QAQtB,8BAA8B;8BAAlB,MAAM;;;;;;;;;;;;;;;;;;;;;;;;QAqBlB;;;WAGG;2BAFQ,MAAM,GACJ,OAAO;;;;;;;QAgDpB,mCAAmC;qCAAvB,KAAK,IAAI,CAAC;QA0BtB;;;WAGG;;;;QA2EH;;;;WAIG;oBAHQ,KAAK,OAAO,CAAC,UACb,MAAM,YACN,WAAW;;;;;;;;;QAjOtB,qCAAqC;4CAAzB,MAAM,EAAE;;YA+CpB,8BAA8B;kCAAlB,MAAM;;;;;;;;;;;;;;;;;;;;;;;;YAqBlB;;;eAGG;+BAFQ,MAAM,GACJ,OAAO;;QA9DpB,gDAAgD;6BAApC,0BAA0B;;;;;;QA6BtC;;;WAGG;uBAFQ,KAAK,YACL,WAAW;;;QAQtB,8BAA8B;8BAAlB,MAAM;;;;;;;;;;;;;;;;;;;;;;;;QAqBlB;;;WAGG;2BAFQ,MAAM,GACJ,OAAO;;;;;;;QAgDpB,mCAAmC;qCAAvB,KAAK,IAAI,CAAC;QA0BtB;;;WAGG;;;;QA2EH;;;;WAIG;oBAHQ,KAAK,OAAO,CAAC,UACb,MAAM,YACN,WAAW;;;;;;;IAwD7B;0BAlbY,OAAO,kCAAkC,EAAE,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAE5D;;iBAKU,KAAK,WAAW,CAAC;yBACjB,KAAK,OAAO,cAAc,EAAE,SAAS,CAAC;mBACtC,KACb,OAAW,0CAA0C,EAAE,wBAAwB,CAAC,cAAc,CAAC,CAC5F;;;;;;;;;;wBAMU,MAAM;;;;;yBACN,OAAO,KAAK,CAAC;;;;;0BAEb,OAAO,KAAK,CAAC;;;;;;mBAWd,OAAO,eAAe,EAAE,IAAI"}
@@ -1,461 +0,0 @@
1
- // @ts-check
2
- import { AmountMath, BrandShape } from '@agoric/ertp';
3
- import { UnguardedHelperI } from '@agoric/inter-protocol/src/typeGuards.js';
4
- import {
5
- observeIteration,
6
- observeNotifier,
7
- subscribeEach,
8
- } from '@agoric/notifier';
9
- import {
10
- M,
11
- makeScalarBigMapStore,
12
- makeScalarBigSetStore,
13
- prepareExoClassKit,
14
- } from '@agoric/vat-data';
15
- import {
16
- makeRecorderTopic,
17
- PublicTopicShape,
18
- } from '@agoric/zoe/src/contractSupport/topics.js';
19
- import { InstanceHandleShape } from '@agoric/zoe/src/typeGuards.js';
20
- import { E } from '@endo/far';
21
- import { deeplyFulfilled, Far } from '@endo/marshal';
22
- import { PowerFlags } from './walletFlags.js';
23
-
24
- const { details: X, quote: q, Fail } = assert;
25
-
26
- /**
27
- * @typedef {import('@agoric/zoe/src/zoeService/utils').Instance<
28
- * import('@agoric/inter-protocol/src/psm/psm.js').start
29
- * >} PsmInstance
30
- */
31
-
32
- /**
33
- * @typedef {object} ProvisionPoolKitReferences
34
- * @property {ERef<BankManager>} bankManager
35
- * @property {ERef<import('@agoric/vats').NameAdmin>} namesByAddressAdmin
36
- * @property {ERef<
37
- * import('@agoric/vats/src/core/startWalletFactory').WalletFactoryStartResult['creatorFacet']
38
- * >} walletFactory
39
- */
40
-
41
- /**
42
- * @typedef {object} MetricsNotification Metrics naming scheme is that nouns are
43
- * present values and past-participles are accumulative.
44
- * @property {bigint} walletsProvisioned count of new wallets provisioned
45
- * @property {Amount<'nat'>} totalMintedProvided running sum of Minted provided
46
- * to new wallets
47
- * @property {Amount<'nat'>} totalMintedConverted running sum of Minted ever
48
- * received by the contract from PSM
49
- */
50
-
51
- /**
52
- * Given attenuated access to the funding purse, handle requests to provision
53
- * smart wallets.
54
- *
55
- * @param {(depositBank: ERef<Bank>) => Promise<void>} sendInitialPayment
56
- * @param {() => void} onProvisioned
57
- *
58
- * @typedef {import('./vat-bank.js').Bank} Bank
59
- */
60
- export const makeBridgeProvisionTool = (sendInitialPayment, onProvisioned) => {
61
- /** @param {ProvisionPoolKitReferences} refs */
62
- const makeBridgeHandler = ({
63
- bankManager,
64
- namesByAddressAdmin,
65
- walletFactory,
66
- }) =>
67
- Far('provisioningHandler', {
68
- fromBridge: async obj => {
69
- obj.type === 'PLEASE_PROVISION' ||
70
- Fail`Unrecognized request ${obj.type}`;
71
- console.info('PLEASE_PROVISION', obj);
72
- const { address, powerFlags } = obj;
73
- powerFlags.includes(PowerFlags.SMART_WALLET) ||
74
- Fail`missing SMART_WALLET in powerFlags`;
75
-
76
- const bank = E(bankManager).getBankForAddress(address);
77
- // only proceed if we can provide funds
78
- await sendInitialPayment(bank);
79
-
80
- const [_, created] = await E(walletFactory).provideSmartWallet(
81
- address,
82
- bank,
83
- namesByAddressAdmin,
84
- );
85
- if (created) {
86
- onProvisioned();
87
- }
88
- console.info(created ? 'provisioned' : 're-provisioned', address);
89
- },
90
- });
91
- return makeBridgeHandler;
92
- };
93
-
94
- /**
95
- * @param {import('@agoric/vat-data').Baggage} baggage
96
- * @param {{
97
- * makeRecorderKit: import('@agoric/zoe/src/contractSupport/recorder.js').MakeRecorderKit;
98
- * params: any;
99
- * poolBank: import('@endo/far').ERef<Bank>;
100
- * zcf: ZCF;
101
- * }} powers
102
- */
103
- export const prepareProvisionPoolKit = (
104
- baggage,
105
- { makeRecorderKit, params, poolBank, zcf },
106
- ) => {
107
- const zoe = zcf.getZoeService();
108
-
109
- const makeProvisionPoolKitInternal = prepareExoClassKit(
110
- baggage,
111
- 'ProvisionPoolKit',
112
- {
113
- machine: M.interface('ProvisionPoolKit machine', {
114
- addRevivableAddresses: M.call(M.arrayOf(M.string())).returns(),
115
- getWalletReviver: M.call().returns(
116
- M.remotable('ProvisionPoolKit wallet reviver'),
117
- ),
118
- setReferences: M.callWhen({
119
- bankManager: M.eref(M.remotable('bankManager')),
120
- namesByAddressAdmin: M.eref(M.remotable('nameAdmin')),
121
- walletFactory: M.eref(M.remotable('walletFactory')),
122
- }).returns(),
123
- makeHandler: M.call().returns(M.remotable('BridgeHandler')),
124
- initPSM: M.call(BrandShape, InstanceHandleShape).returns(),
125
- }),
126
- walletReviver: M.interface('ProvisionPoolKit wallet reviver', {
127
- reviveWallet: M.callWhen(M.string()).returns(
128
- M.remotable('SmartWallet'),
129
- ),
130
- ackWallet: M.call(M.string()).returns(M.boolean()),
131
- }),
132
- helper: UnguardedHelperI,
133
- public: M.interface('ProvisionPoolKit public', {
134
- getPublicTopics: M.call().returns({ metrics: PublicTopicShape }),
135
- }),
136
- },
137
- /**
138
- * @param {object} opts
139
- * @param {Purse<'nat'>} opts.fundPurse
140
- * @param {Brand} opts.poolBrand
141
- * @param {StorageNode} opts.metricsNode
142
- */
143
- ({ fundPurse, poolBrand, metricsNode }) => {
144
- /** @type {import('@agoric/zoe/src/contractSupport/recorder.js').RecorderKit<MetricsNotification>} */
145
- const metricsRecorderKit = makeRecorderKit(metricsNode);
146
-
147
- /** @type {MapStore<Brand, PsmInstance>} */
148
- const brandToPSM = makeScalarBigMapStore('brandToPSM', { durable: true });
149
- const revivableAddresses = makeScalarBigSetStore('revivableAddresses', {
150
- durable: true,
151
- keyShape: M.string(),
152
- });
153
-
154
- /**
155
- * to be set by `setReferences`
156
- *
157
- * @type {Partial<ProvisionPoolKitReferences>}
158
- */
159
- const references = {
160
- bankManager: undefined,
161
- namesByAddressAdmin: undefined,
162
- walletFactory: undefined,
163
- };
164
-
165
- return {
166
- brandToPSM,
167
- fundPurse,
168
- metricsRecorderKit,
169
- poolBrand,
170
- walletsProvisioned: 0n,
171
- totalMintedProvided: AmountMath.makeEmpty(poolBrand),
172
- totalMintedConverted: AmountMath.makeEmpty(poolBrand),
173
- revivableAddresses,
174
- ...references,
175
- };
176
- },
177
- {
178
- // aka "limitedCreatorFacet"
179
- machine: {
180
- /** @param {string[]} oldAddresses */
181
- addRevivableAddresses(oldAddresses) {
182
- console.log('revivableAddresses count', oldAddresses.length);
183
- this.state.revivableAddresses.addAll(oldAddresses);
184
- },
185
- getWalletReviver() {
186
- return this.facets.walletReviver;
187
- },
188
- /** @param {ProvisionPoolKitReferences} erefs */
189
- async setReferences(erefs) {
190
- const { bankManager, namesByAddressAdmin, walletFactory } = erefs;
191
- const obj = harden({
192
- bankManager,
193
- namesByAddressAdmin,
194
- walletFactory,
195
- });
196
- const refs = await deeplyFulfilled(obj);
197
- Object.assign(this.state, refs);
198
- },
199
- makeHandler() {
200
- const { bankManager, namesByAddressAdmin, walletFactory } =
201
- this.state;
202
- if (!bankManager || !namesByAddressAdmin || !walletFactory) {
203
- throw Fail`must set references before handling requests`;
204
- }
205
- const { helper } = this.facets;
206
- // a bit obtuse but leave for backwards compatibility with tests
207
- const innerMaker = makeBridgeProvisionTool(
208
- bank => helper.sendInitialPayment(bank),
209
- () => helper.onProvisioned(),
210
- );
211
- return innerMaker({
212
- bankManager,
213
- namesByAddressAdmin,
214
- walletFactory,
215
- });
216
- },
217
- /**
218
- * @param {Brand} brand
219
- * @param {PsmInstance} instance
220
- */
221
- initPSM(brand, instance) {
222
- const { brandToPSM } = this.state;
223
- brandToPSM.init(brand, instance);
224
- },
225
- },
226
- walletReviver: {
227
- /** @param {string} address */
228
- async reviveWallet(address) {
229
- const {
230
- revivableAddresses,
231
- bankManager,
232
- namesByAddressAdmin,
233
- walletFactory,
234
- } = this.state;
235
- if (!bankManager || !namesByAddressAdmin || !walletFactory) {
236
- throw Fail`must set references before handling requests`;
237
- }
238
- revivableAddresses.has(address) ||
239
- Fail`non-revivable address ${address}`;
240
- const bank = E(bankManager).getBankForAddress(address);
241
- const [wallet, _created] = await E(walletFactory).provideSmartWallet(
242
- address,
243
- bank,
244
- namesByAddressAdmin,
245
- );
246
- return wallet;
247
- },
248
- /**
249
- * @param {string} address
250
- * @returns {boolean} isRevive
251
- */
252
- ackWallet(address) {
253
- const { revivableAddresses } = this.state;
254
- if (!revivableAddresses.has(address)) {
255
- return false;
256
- }
257
- revivableAddresses.delete(address);
258
- return true;
259
- },
260
- },
261
- helper: {
262
- publishMetrics() {
263
- const {
264
- metricsRecorderKit,
265
- walletsProvisioned,
266
- totalMintedConverted,
267
- totalMintedProvided,
268
- } = this.state;
269
- void metricsRecorderKit.recorder.write(
270
- harden({
271
- walletsProvisioned,
272
- totalMintedProvided,
273
- totalMintedConverted,
274
- }),
275
- );
276
- },
277
- onTrade(converted) {
278
- const { state, facets } = this;
279
- state.totalMintedConverted = AmountMath.add(
280
- state.totalMintedConverted,
281
- converted,
282
- );
283
- facets.helper.publishMetrics();
284
- },
285
- onSendFunds(provided) {
286
- const { state, facets } = this;
287
- state.totalMintedProvided = AmountMath.add(
288
- state.totalMintedProvided,
289
- provided,
290
- );
291
- facets.helper.publishMetrics();
292
- },
293
- onProvisioned() {
294
- const { state, facets } = this;
295
- state.walletsProvisioned += 1n;
296
- facets.helper.publishMetrics();
297
- },
298
- /** @param {ERef<Bank>} destBank */
299
- async sendInitialPayment(destBank) {
300
- const {
301
- facets: { helper },
302
- state: { fundPurse, poolBrand },
303
- } = this;
304
- const perAccountInitialAmount = /** @type {Amount<'nat'>} */ (
305
- params.getPerAccountInitialAmount()
306
- );
307
- const initialPmt = await E(fundPurse).withdraw(
308
- perAccountInitialAmount,
309
- );
310
-
311
- const destPurse = E(destBank).getPurse(poolBrand);
312
- return E(destPurse)
313
- .deposit(initialPmt)
314
- .then(amt => {
315
- helper.onSendFunds(perAccountInitialAmount);
316
- console.log('provisionPool sent', amt);
317
- })
318
- .catch(reason => {
319
- console.error(X`initial deposit failed: ${q(reason)}`);
320
- void E(fundPurse).deposit(initialPmt);
321
- throw reason;
322
- });
323
- },
324
- /**
325
- * @param {object} [options]
326
- * @param {MetricsNotification} [options.metrics]
327
- */
328
- start({ metrics } = {}) {
329
- const {
330
- state: { brandToPSM, poolBrand },
331
- facets: { helper },
332
- } = this;
333
-
334
- // Must match. poolBrand is from durable state and the param is from
335
- // the contract, so it technically can change between incarnations.
336
- // That would be a severe bug.
337
- AmountMath.coerce(poolBrand, params.getPerAccountInitialAmount());
338
-
339
- void observeIteration(
340
- subscribeEach(E(poolBank).getAssetSubscription()),
341
- {
342
- updateState: async desc => {
343
- console.log('provisionPool notified of new asset', desc.brand);
344
- await zcf.saveIssuer(desc.issuer, desc.issuerName);
345
- /** @type {ERef<Purse>} */
346
- // @ts-expect-error vbank purse is close enough for our use.
347
- const exchangePurse = E(poolBank).getPurse(desc.brand);
348
- void observeNotifier(
349
- E(exchangePurse).getCurrentAmountNotifier(),
350
- {
351
- updateState: async amount => {
352
- console.log('provisionPool balance update', amount);
353
- if (
354
- AmountMath.isEmpty(amount) ||
355
- amount.brand === poolBrand
356
- ) {
357
- return;
358
- }
359
- if (!brandToPSM.has(desc.brand)) {
360
- console.error(
361
- 'funds arrived but no PSM instance',
362
- desc.brand,
363
- );
364
- return;
365
- }
366
- const instance = brandToPSM.get(desc.brand);
367
- const payment = E(exchangePurse).withdraw(amount);
368
- await helper
369
- .swap(payment, amount, instance)
370
- .catch(async reason => {
371
- console.error(X`swap failed: ${reason}`);
372
- const resolvedPayment = await payment;
373
- return E(exchangePurse).deposit(resolvedPayment);
374
- });
375
- },
376
- fail: reason => console.error(reason),
377
- },
378
- );
379
- },
380
- },
381
- );
382
-
383
- if (metrics) {
384
- // Restore state.
385
- // we publishMetrics() below
386
- const {
387
- walletsProvisioned,
388
- totalMintedProvided,
389
- totalMintedConverted,
390
- } = metrics;
391
- assert.typeof(walletsProvisioned, 'bigint');
392
- AmountMath.coerce(poolBrand, totalMintedProvided);
393
- AmountMath.coerce(poolBrand, totalMintedConverted);
394
- Object.assign(this.state, {
395
- walletsProvisioned,
396
- totalMintedProvided,
397
- totalMintedConverted,
398
- });
399
- helper.publishMetrics();
400
- }
401
- },
402
- /**
403
- * @param {ERef<Payment>} payIn
404
- * @param {Amount} amount
405
- * @param {PsmInstance} instance
406
- */
407
- async swap(payIn, amount, instance) {
408
- const {
409
- facets: { helper },
410
- state: { fundPurse },
411
- } = this;
412
- const psmPub = E(zoe).getPublicFacet(instance);
413
- const proposal = harden({ give: { In: amount } });
414
- const invitation = E(psmPub).makeWantMintedInvitation();
415
- const seat = E(zoe).offer(invitation, proposal, { In: payIn });
416
- const payout = await E(seat).getPayout('Out');
417
- const rxd = await E(fundPurse).deposit(payout);
418
- helper.onTrade(rxd);
419
- return rxd;
420
- },
421
- },
422
- public: {
423
- getPublicTopics() {
424
- return {
425
- metrics: makeRecorderTopic(
426
- 'Provision Pool metrics',
427
- this.state.metricsRecorderKit,
428
- ),
429
- };
430
- },
431
- },
432
- },
433
- {
434
- finish: ({ facets }) => {
435
- facets.helper.publishMetrics();
436
- },
437
- },
438
- );
439
-
440
- /**
441
- * Prepare synchronous values before passing to real Exo maker
442
- *
443
- * @param {object} opts
444
- * @param {Brand} opts.poolBrand
445
- * @param {ERef<StorageNode>} opts.storageNode
446
- */
447
- const makeProvisionPoolKit = async ({ poolBrand, storageNode }) => {
448
- /** @type {Purse<'nat'>} */
449
- // @ts-expect-error vbank purse is close enough for our use.
450
- const fundPurse = await E(poolBank).getPurse(poolBrand);
451
- const metricsNode = await E(storageNode).makeChildNode('metrics');
452
-
453
- return makeProvisionPoolKitInternal({
454
- fundPurse,
455
- poolBrand,
456
- metricsNode,
457
- });
458
- };
459
-
460
- return makeProvisionPoolKit;
461
- };