@agoric/builders 0.1.1-orchestration-dev-096c4e8.0 → 0.1.1-other-dev-3eb1a1d.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.
- package/index.js +0 -2
- package/package.json +33 -31
- package/scripts/fast-usdc/init-fast-usdc.js +242 -0
- package/scripts/inter-protocol/add-STARS.js +8 -7
- package/scripts/inter-protocol/add-collateral-core.js +12 -8
- package/scripts/inter-protocol/init-core.js +6 -5
- package/scripts/inter-protocol/invite-committee-core.js +5 -4
- package/scripts/inter-protocol/manual-price-feed.js +4 -0
- package/scripts/inter-protocol/price-feed-core.js +5 -5
- package/scripts/inter-protocol/replace-electorate-core.js +163 -0
- package/scripts/inter-protocol/replace-feeDistributor.js +28 -0
- package/scripts/inter-protocol/updatePriceFeeds.js +118 -0
- package/scripts/orchestration/init-basic-flows.js +27 -0
- package/scripts/orchestration/init-stakeAtom.js +24 -0
- package/scripts/orchestration/init-stakeBld.js +24 -0
- package/scripts/orchestration/init-stakeOsmo.js +24 -0
- package/scripts/orchestration/write-chain-info.js +14 -0
- package/scripts/pegasus/init-core.js +4 -3
- package/scripts/smart-wallet/build-game1-start.js +5 -4
- package/scripts/smart-wallet/build-wallet-factory2-upgrade.js +4 -3
- package/scripts/smart-wallet/build-walletFactory-upgrade.js +4 -3
- package/scripts/testing/add-LEMONS.js +24 -0
- package/scripts/testing/add-OLIVES.js +23 -0
- package/scripts/testing/append-chain-info.js +48 -0
- package/scripts/testing/fix-buggy-sendAnywhere.js +143 -0
- package/scripts/testing/replace-feeDistributor-short.js +27 -0
- package/scripts/testing/restart-basic-flows.js +101 -0
- package/scripts/testing/restart-send-anywhere.js +101 -0
- package/scripts/testing/restart-stakeAtom.js +91 -0
- package/scripts/testing/restart-valueVow.js +82 -0
- package/scripts/testing/start-auto-stake-it.js +128 -0
- package/scripts/testing/start-buggy-sendAnywhere.js +143 -0
- package/scripts/testing/start-query-flows.js +135 -0
- package/scripts/testing/start-send-anywhere.js +136 -0
- package/scripts/testing/start-valueVow.js +93 -0
- package/scripts/testing/tweak-chain-info.js +51 -0
- package/scripts/vats/add-auction.js +31 -0
- package/scripts/vats/init-core.js +4 -3
- package/scripts/vats/init-localchain.js +4 -3
- package/scripts/vats/init-network.js +4 -3
- package/scripts/vats/init-orchestration.js +21 -0
- package/scripts/vats/init-transfer.js +19 -0
- package/scripts/vats/priceFeedSupport.js +90 -0
- package/scripts/vats/probe-zcf-bundle.js +4 -3
- package/scripts/vats/replace-provisioning.js +4 -3
- package/scripts/vats/replace-zoe.js +4 -3
- package/scripts/vats/restart-vats.js +4 -3
- package/scripts/vats/revive-kread.js +14 -0
- package/scripts/vats/test-localchain.js +4 -3
- package/scripts/vats/test-vtransfer.js +19 -0
- package/scripts/vats/updateAtomPriceFeed.js +22 -0
- package/scripts/vats/updateStAtomPriceFeed.js +22 -0
- package/scripts/vats/updateStOsmoPriceFeed.js +22 -0
- package/scripts/vats/updateStTiaPriceFeed.js +22 -0
- package/scripts/vats/updateStkAtomPriceFeed.js +22 -0
- package/scripts/vats/upgrade-bank.js +19 -0
- package/scripts/vats/upgrade-orch-core.js +24 -0
- package/scripts/vats/upgrade-provisionPool.js +21 -0
- package/scripts/vats/upgrade-zcf.js +19 -0
- package/scripts/vats/upgrade-zoe.js +4 -3
- package/scripts/vats/upgradeScaledPriceAuthorities.js +23 -0
- package/scripts/vats/upgradeVaults.js +24 -0
- package/tsconfig.json +0 -2
- package/scripts/inter-protocol/deploy-contracts.js +0 -110
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
/* global process */
|
|
2
|
+
|
|
3
|
+
import { DEFAULT_CONTRACT_TERMS } from '../inter-protocol/price-feed-core.js';
|
|
4
|
+
|
|
5
|
+
const { Fail } = assert;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* modified copy of ../inter-protocol/price-feed-core.js
|
|
9
|
+
*
|
|
10
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
11
|
+
*/
|
|
12
|
+
export const strictPriceFeedProposalBuilder = async (
|
|
13
|
+
{ publishRef, install },
|
|
14
|
+
options,
|
|
15
|
+
) => {
|
|
16
|
+
const {
|
|
17
|
+
AGORIC_INSTANCE_NAME,
|
|
18
|
+
IN_BRAND_LOOKUP,
|
|
19
|
+
IN_BRAND_NAME = IN_BRAND_LOOKUP[IN_BRAND_LOOKUP.length - 1],
|
|
20
|
+
ORACLE_ADDRESSES,
|
|
21
|
+
} = options;
|
|
22
|
+
|
|
23
|
+
const oracleAddresses = ORACLE_ADDRESSES;
|
|
24
|
+
Array.isArray(oracleAddresses) ||
|
|
25
|
+
Fail`ORACLE_ADDRESSES array is required; got ${oracleAddresses}`;
|
|
26
|
+
|
|
27
|
+
AGORIC_INSTANCE_NAME ||
|
|
28
|
+
Fail`AGORIC_INSTANCE_NAME is required; got ${AGORIC_INSTANCE_NAME}`;
|
|
29
|
+
|
|
30
|
+
Array.isArray(IN_BRAND_LOOKUP) ||
|
|
31
|
+
Fail`IN_BRAND_NAME array is required; got ${IN_BRAND_LOOKUP}`;
|
|
32
|
+
|
|
33
|
+
return harden({
|
|
34
|
+
sourceSpec: '@agoric/inter-protocol/src/proposals/price-feed-proposal.js',
|
|
35
|
+
getManifestCall: [
|
|
36
|
+
'getManifestForPriceFeed',
|
|
37
|
+
{
|
|
38
|
+
AGORIC_INSTANCE_NAME,
|
|
39
|
+
contractTerms: DEFAULT_CONTRACT_TERMS,
|
|
40
|
+
oracleAddresses,
|
|
41
|
+
IN_BRAND_NAME,
|
|
42
|
+
IN_BRAND_DECIMALS: 6,
|
|
43
|
+
OUT_BRAND_DECIMALS: 4,
|
|
44
|
+
OUT_BRAND_NAME: 'USD',
|
|
45
|
+
priceAggregatorRef: publishRef(
|
|
46
|
+
install(
|
|
47
|
+
'@agoric/inter-protocol/src/price/fluxAggregatorContract.js',
|
|
48
|
+
'../bundles/bundle-fluxAggregatorKit.js',
|
|
49
|
+
),
|
|
50
|
+
),
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
});
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* @deprecated use `strictPriceFeedProposalBuilder` and specify arguments instead
|
|
58
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
59
|
+
*/
|
|
60
|
+
export const deprecatedPriceFeedProposalBuilder = async (powers, options) => {
|
|
61
|
+
console.warn(
|
|
62
|
+
'deprecated ambient `priceFeedProposalBuilder`; use `strictPriceFeedProposalBuilder` instead',
|
|
63
|
+
);
|
|
64
|
+
|
|
65
|
+
const DEFAULT_ORACLE_ADDRESSES = [
|
|
66
|
+
// XXX These are the oracle addresses. They must be provided before the chain
|
|
67
|
+
// is running, which means they must be known ahead of time.
|
|
68
|
+
// see https://github.com/Agoric/agoric-3-proposals/issues/5
|
|
69
|
+
'agoric1lu9hh5vgx05hmlpfu47hukershgdxctk6l5s05',
|
|
70
|
+
'agoric15lpnq2mjsdhtztf6khp7mrsq66hyrssspy92pd',
|
|
71
|
+
'agoric1mwm224epc4l3pjcz7qsxnudcuktpynwkmnfqfp',
|
|
72
|
+
];
|
|
73
|
+
|
|
74
|
+
const { GOV1ADDR, GOV2ADDR, GOV3ADDR } = process.env;
|
|
75
|
+
const governanceAddressEnv = [GOV1ADDR, GOV2ADDR, GOV3ADDR].filter(x => x);
|
|
76
|
+
const ORACLE_ADDRESSES = governanceAddressEnv.length
|
|
77
|
+
? governanceAddressEnv
|
|
78
|
+
: DEFAULT_ORACLE_ADDRESSES;
|
|
79
|
+
|
|
80
|
+
return strictPriceFeedProposalBuilder(powers, {
|
|
81
|
+
...options,
|
|
82
|
+
ORACLE_ADDRESSES,
|
|
83
|
+
});
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* @deprecated use `strictPriceFeedProposalBuilder` and specify arguments instead
|
|
88
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
89
|
+
*/
|
|
90
|
+
export const priceFeedProposalBuilder = deprecatedPriceFeedProposalBuilder;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
2
|
|
|
3
|
-
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
4
|
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
5
|
harden({
|
|
6
6
|
sourceSpec: '@agoric/vats/src/proposals/probeZcfBundle.js',
|
|
@@ -16,7 +16,8 @@ export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
|
16
16
|
],
|
|
17
17
|
});
|
|
18
18
|
|
|
19
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
19
20
|
export default async (homeP, endowments) => {
|
|
20
|
-
const {
|
|
21
|
-
await
|
|
21
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
22
|
+
await writeCoreEval('probeZcfBundle', defaultProposalBuilder);
|
|
22
23
|
};
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
4
4
|
import { getManifestForProvisioning } from '@agoric/vats/src/proposals/namesByAddress-fix-proposal.js';
|
|
5
5
|
|
|
6
|
-
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').
|
|
6
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
7
7
|
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
8
8
|
harden({
|
|
9
9
|
sourceSpec: '@agoric/vats/src/proposals/namesByAddress-fix-proposal.js',
|
|
@@ -17,7 +17,8 @@ export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
|
17
17
|
],
|
|
18
18
|
});
|
|
19
19
|
|
|
20
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
20
21
|
export default async (homeP, endowments) => {
|
|
21
|
-
const {
|
|
22
|
-
await
|
|
22
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
23
|
+
await writeCoreEval('gov-provisioning', defaultProposalBuilder);
|
|
23
24
|
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
2
|
|
|
3
|
-
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
4
|
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
5
|
harden({
|
|
6
6
|
sourceSpec: '@agoric/vats/src/proposals/zcf-proposal.js',
|
|
@@ -13,7 +13,8 @@ export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
|
13
13
|
],
|
|
14
14
|
});
|
|
15
15
|
|
|
16
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
16
17
|
export default async (homeP, endowments) => {
|
|
17
|
-
const {
|
|
18
|
-
await
|
|
18
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
19
|
+
await writeCoreEval('replace-zcf', defaultProposalBuilder);
|
|
19
20
|
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
2
|
|
|
3
|
-
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
4
|
export const defaultProposalBuilder = async () => {
|
|
5
5
|
// An includelist isn't necessary because the collections are known to be complete (tested in test-vaults-upgrade.js)
|
|
6
6
|
const skip = [
|
|
@@ -19,7 +19,8 @@ export const defaultProposalBuilder = async () => {
|
|
|
19
19
|
});
|
|
20
20
|
};
|
|
21
21
|
|
|
22
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
22
23
|
export default async (homeP, endowments) => {
|
|
23
|
-
const {
|
|
24
|
-
await
|
|
24
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
25
|
+
await writeCoreEval('restart-vats', defaultProposalBuilder);
|
|
25
26
|
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async () =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/vats/src/proposals/kread-proposal.js',
|
|
7
|
+
getManifestCall: ['getManifestForKread'],
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
11
|
+
export default async (homeP, endowments) => {
|
|
12
|
+
const { writeCoreProposal } = await makeHelpers(homeP, endowments);
|
|
13
|
+
await writeCoreProposal('revive-kread', defaultProposalBuilder);
|
|
14
|
+
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
2
|
|
|
3
|
-
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
4
|
export const defaultProposalBuilder = async _powers =>
|
|
5
5
|
harden({
|
|
6
6
|
sourceSpec: '@agoric/vats/src/proposals/localchain-test.js',
|
|
@@ -12,7 +12,8 @@ export const defaultProposalBuilder = async _powers =>
|
|
|
12
12
|
],
|
|
13
13
|
});
|
|
14
14
|
|
|
15
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
15
16
|
export default async (homeP, endowments) => {
|
|
16
|
-
const {
|
|
17
|
-
await
|
|
17
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
18
|
+
await writeCoreEval('test-localchain', defaultProposalBuilder);
|
|
18
19
|
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async _powers =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/vats/src/proposals/vtransfer-echoer.js',
|
|
7
|
+
getManifestCall: [
|
|
8
|
+
'getManifestForVtransferEchoer',
|
|
9
|
+
{
|
|
10
|
+
target: 'agoric1vtransfertest',
|
|
11
|
+
},
|
|
12
|
+
],
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
16
|
+
export default async (homeP, endowments) => {
|
|
17
|
+
const { writeCoreProposal } = await makeHelpers(homeP, endowments);
|
|
18
|
+
await writeCoreProposal('test-vtransfer', defaultProposalBuilder);
|
|
19
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
import { priceFeedProposalBuilder } from './priceFeedSupport.js';
|
|
3
|
+
|
|
4
|
+
const OPTIONS = {
|
|
5
|
+
AGORIC_INSTANCE_NAME: 'ATOM-USD price feed',
|
|
6
|
+
IN_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'ATOM'],
|
|
7
|
+
OUT_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'USD'],
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
12
|
+
*/
|
|
13
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) => {
|
|
14
|
+
return priceFeedProposalBuilder({ publishRef, install }, OPTIONS);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
18
|
+
export default async (homeP, endowments) => {
|
|
19
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
20
|
+
|
|
21
|
+
await writeCoreEval('atomPriceFeed', defaultProposalBuilder);
|
|
22
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
import { priceFeedProposalBuilder } from './priceFeedSupport.js';
|
|
3
|
+
|
|
4
|
+
const OPTIONS = {
|
|
5
|
+
AGORIC_INSTANCE_NAME: 'stATOM-USD price feed',
|
|
6
|
+
IN_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'stATOM'],
|
|
7
|
+
OUT_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'USD'],
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
12
|
+
*/
|
|
13
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) => {
|
|
14
|
+
return priceFeedProposalBuilder({ publishRef, install }, OPTIONS);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
18
|
+
export default async (homeP, endowments) => {
|
|
19
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
20
|
+
|
|
21
|
+
await writeCoreEval('stAtomPriceFeed', defaultProposalBuilder);
|
|
22
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
import { priceFeedProposalBuilder } from './priceFeedSupport.js';
|
|
3
|
+
|
|
4
|
+
const OPTIONS = {
|
|
5
|
+
AGORIC_INSTANCE_NAME: 'stOSMO-USD price feed',
|
|
6
|
+
IN_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'stOSMO'],
|
|
7
|
+
OUT_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'USD'],
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
12
|
+
*/
|
|
13
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) => {
|
|
14
|
+
return priceFeedProposalBuilder({ publishRef, install }, OPTIONS);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
18
|
+
export default async (homeP, endowments) => {
|
|
19
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
20
|
+
|
|
21
|
+
await writeCoreEval('stOsmoPriceFeed', defaultProposalBuilder);
|
|
22
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
import { priceFeedProposalBuilder } from './priceFeedSupport.js';
|
|
3
|
+
|
|
4
|
+
const OPTIONS = {
|
|
5
|
+
AGORIC_INSTANCE_NAME: 'stTIA-USD price feed',
|
|
6
|
+
IN_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'stTIA'],
|
|
7
|
+
OUT_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'USD'],
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
12
|
+
*/
|
|
13
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) => {
|
|
14
|
+
return priceFeedProposalBuilder({ publishRef, install }, OPTIONS);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
18
|
+
export default async (homeP, endowments) => {
|
|
19
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
20
|
+
|
|
21
|
+
await writeCoreEval('stTiaPriceFeed', defaultProposalBuilder);
|
|
22
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
import { priceFeedProposalBuilder } from './priceFeedSupport.js';
|
|
3
|
+
|
|
4
|
+
const OPTIONS = {
|
|
5
|
+
AGORIC_INSTANCE_NAME: 'stkATOM-USD price feed',
|
|
6
|
+
IN_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'stkATOM'],
|
|
7
|
+
OUT_BRAND_LOOKUP: ['agoricNames', 'oracleBrand', 'USD'],
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder}
|
|
12
|
+
*/
|
|
13
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) => {
|
|
14
|
+
return priceFeedProposalBuilder({ publishRef, install }, OPTIONS);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
18
|
+
export default async (homeP, endowments) => {
|
|
19
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
20
|
+
|
|
21
|
+
await writeCoreEval('stkATOMPriceFeed', defaultProposalBuilder);
|
|
22
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/vats/src/proposals/upgrade-bank-proposal.js',
|
|
7
|
+
getManifestCall: [
|
|
8
|
+
'getManifestForUpgradingBank',
|
|
9
|
+
{
|
|
10
|
+
bankRef: publishRef(install('@agoric/vats/src/vat-bank.js')),
|
|
11
|
+
},
|
|
12
|
+
],
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
16
|
+
export default async (homeP, endowments) => {
|
|
17
|
+
const { writeCoreProposal } = await makeHelpers(homeP, endowments);
|
|
18
|
+
await writeCoreProposal('upgrade-bank', defaultProposalBuilder);
|
|
19
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/vats/src/proposals/upgrade-orch-core-proposal.js',
|
|
7
|
+
getManifestCall: [
|
|
8
|
+
'getManifestForUpgradingOrchCore',
|
|
9
|
+
{
|
|
10
|
+
bundleRefs: {
|
|
11
|
+
ibc: publishRef(install('@agoric/vats/src/vat-ibc.js')),
|
|
12
|
+
network: publishRef(install('@agoric/vats/src/vat-network.js')),
|
|
13
|
+
localchain: publishRef(install('@agoric/vats/src/vat-localchain.js')),
|
|
14
|
+
transfer: publishRef(install('@agoric/vats/src/vat-transfer.js')),
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
],
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
21
|
+
export default async (homeP, endowments) => {
|
|
22
|
+
const { writeCoreProposal } = await makeHelpers(homeP, endowments);
|
|
23
|
+
await writeCoreProposal('upgrade-network', defaultProposalBuilder);
|
|
24
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/vats/src/proposals/upgrade-provisionPool-proposal.js',
|
|
7
|
+
getManifestCall: [
|
|
8
|
+
'getManifestForUpgradingProvisionPool',
|
|
9
|
+
{
|
|
10
|
+
provisionPoolRef: publishRef(
|
|
11
|
+
install('@agoric/inter-protocol/src/provisionPool.js'),
|
|
12
|
+
),
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
18
|
+
export default async (homeP, endowments) => {
|
|
19
|
+
const { writeCoreProposal } = await makeHelpers(homeP, endowments);
|
|
20
|
+
await writeCoreProposal('upgrade-provision-pool', defaultProposalBuilder);
|
|
21
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/vats/src/proposals/zcf-only-proposal.js',
|
|
7
|
+
getManifestCall: [
|
|
8
|
+
'getManifestForUpgradingZcf',
|
|
9
|
+
{
|
|
10
|
+
zcfRef: publishRef(install('@agoric/zoe/src/contractFacet/vatRoot.js')),
|
|
11
|
+
},
|
|
12
|
+
],
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
16
|
+
export default async (homeP, endowments) => {
|
|
17
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
18
|
+
await writeCoreEval('upgrade-zcf', defaultProposalBuilder);
|
|
19
|
+
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
2
|
|
|
3
|
-
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
4
|
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
5
|
harden({
|
|
6
6
|
sourceSpec: '@agoric/vats/src/proposals/upgrade-zoe-proposal.js',
|
|
@@ -12,7 +12,8 @@ export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
|
12
12
|
],
|
|
13
13
|
});
|
|
14
14
|
|
|
15
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
15
16
|
export default async (homeP, endowments) => {
|
|
16
|
-
const {
|
|
17
|
-
await
|
|
17
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
18
|
+
await writeCoreEval('upgrade-zoe', defaultProposalBuilder);
|
|
18
19
|
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec:
|
|
7
|
+
'@agoric/inter-protocol/src/proposals/upgrade-scaledPriceAuthorities.js',
|
|
8
|
+
getManifestCall: [
|
|
9
|
+
'getManifestForUpgradeScaledPriceAuthorities',
|
|
10
|
+
{
|
|
11
|
+
scaledPARef: publishRef(
|
|
12
|
+
install('@agoric/zoe/src/contracts/scaledPriceAuthority.js'),
|
|
13
|
+
),
|
|
14
|
+
},
|
|
15
|
+
],
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
19
|
+
export default async (homeP, endowments) => {
|
|
20
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
21
|
+
|
|
22
|
+
await writeCoreEval('upgradeScaledPriceAuthorities', defaultProposalBuilder);
|
|
23
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
2
|
+
|
|
3
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').CoreEvalBuilder} */
|
|
4
|
+
export const defaultProposalBuilder = async ({ publishRef, install }) =>
|
|
5
|
+
harden({
|
|
6
|
+
sourceSpec: '@agoric/inter-protocol/src/proposals/upgrade-vaults.js',
|
|
7
|
+
getManifestCall: [
|
|
8
|
+
'getManifestForUpgradeVaults',
|
|
9
|
+
{
|
|
10
|
+
VaultFactoryRef: publishRef(
|
|
11
|
+
install(
|
|
12
|
+
'@agoric/inter-protocol/src/vaultFactory/vaultFactory.js',
|
|
13
|
+
'../bundles/bundle-vaultFactory.js',
|
|
14
|
+
),
|
|
15
|
+
),
|
|
16
|
+
},
|
|
17
|
+
],
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').DeployScriptFunction} */
|
|
21
|
+
export default async (homeP, endowments) => {
|
|
22
|
+
const { writeCoreEval } = await makeHelpers(homeP, endowments);
|
|
23
|
+
await writeCoreEval('upgrade-vaults', defaultProposalBuilder);
|
|
24
|
+
};
|
package/tsconfig.json
CHANGED
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import url from 'url';
|
|
3
|
-
import { makeHelpers } from '@agoric/deploy-script-support';
|
|
4
|
-
import { E } from '@endo/eventual-send';
|
|
5
|
-
import { getCopyMapEntries, makeCopyMap } from '@agoric/store';
|
|
6
|
-
|
|
7
|
-
// TODO: CLI options to choose contracts
|
|
8
|
-
const contractRefs = [
|
|
9
|
-
'../../governance/bundles/bundle-contractGovernor.js',
|
|
10
|
-
'../../governance/bundles/bundle-committee.js',
|
|
11
|
-
'../../governance/bundles/bundle-binaryVoteCounter.js',
|
|
12
|
-
'../bundles/bundle-vaultFactory.js',
|
|
13
|
-
'../bundles/bundle-reserve.js',
|
|
14
|
-
'../bundles/bundle-psm.js',
|
|
15
|
-
'../bundles/bundle-auctioneer.js',
|
|
16
|
-
'../../vats/bundles/bundle-mintHolder.js',
|
|
17
|
-
];
|
|
18
|
-
const contractRoots = contractRefs.map(ref =>
|
|
19
|
-
url.fileURLToPath(new URL(ref, import.meta.url)),
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
/** @type {<T>(store: any, key: string, make: () => T) => Promise<T>} */
|
|
23
|
-
const provideWhen = async (store, key, make) => {
|
|
24
|
-
const found = await E(store).get(key);
|
|
25
|
-
if (found) {
|
|
26
|
-
return found;
|
|
27
|
-
}
|
|
28
|
-
const value = make();
|
|
29
|
-
await E(store).set(key, value);
|
|
30
|
-
return value;
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
export default async (homeP, endowments) => {
|
|
34
|
-
const home = await homeP;
|
|
35
|
-
const { zoe, scratch, board } = home;
|
|
36
|
-
|
|
37
|
-
const { installInPieces, getBundlerMaker } = await makeHelpers(
|
|
38
|
-
homeP,
|
|
39
|
-
endowments,
|
|
40
|
-
);
|
|
41
|
-
const bundler = E(getBundlerMaker({ log: console.log })).makeBundler({
|
|
42
|
-
zoe,
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
console.log('getting installCache...');
|
|
46
|
-
/**
|
|
47
|
-
* @type {CopyMap<
|
|
48
|
-
* string,
|
|
49
|
-
* { installation: Installation; boardId: string; path?: string }
|
|
50
|
-
* >}
|
|
51
|
-
*/
|
|
52
|
-
const initial = await provideWhen(scratch, 'installCache', () =>
|
|
53
|
-
makeCopyMap([]),
|
|
54
|
-
);
|
|
55
|
-
console.log('initially:', initial.payload.keys.length, 'entries');
|
|
56
|
-
|
|
57
|
-
// ISSUE: getCopyMapEntries of CopyMap<K, V> loses K, V.
|
|
58
|
-
/**
|
|
59
|
-
* @type {Map<
|
|
60
|
-
* string,
|
|
61
|
-
* { installation: Installation; boardId: string; path?: string }
|
|
62
|
-
* >}
|
|
63
|
-
*/
|
|
64
|
-
const working = new Map(getCopyMapEntries(initial));
|
|
65
|
-
|
|
66
|
-
let added = 0;
|
|
67
|
-
|
|
68
|
-
/** @type {EndoZipBase64Bundle[]} */
|
|
69
|
-
const bundles = await Promise.all(
|
|
70
|
-
contractRoots.map(path => import(path).then(m => m.default)),
|
|
71
|
-
);
|
|
72
|
-
|
|
73
|
-
let ix = 0;
|
|
74
|
-
for await (const bundle of bundles) {
|
|
75
|
-
const sha512 = bundle.endoZipBase64Sha512;
|
|
76
|
-
if (working.has(bundle.endoZipBase64Sha512)) {
|
|
77
|
-
console.log('hit:', { path: contractRefs[ix], sha512 });
|
|
78
|
-
} else {
|
|
79
|
-
console.log('miss:', {
|
|
80
|
-
path: contractRefs[ix],
|
|
81
|
-
length: bundle.endoZipBase64.length,
|
|
82
|
-
sha512,
|
|
83
|
-
});
|
|
84
|
-
const installation = await installInPieces(bundle, bundler, {
|
|
85
|
-
persist: true,
|
|
86
|
-
});
|
|
87
|
-
const boardId = await E(board).getId(installation);
|
|
88
|
-
working.set(sha512, { installation, boardId, path: contractRefs[ix] });
|
|
89
|
-
added += 1;
|
|
90
|
-
}
|
|
91
|
-
ix += 1;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
const final = makeCopyMap(working);
|
|
95
|
-
assert.equal(final.payload.keys.length, working.size);
|
|
96
|
-
await (added > 0 && E(home.scratch).set('installCache', final));
|
|
97
|
-
console.log({
|
|
98
|
-
initial: initial.payload.keys.length,
|
|
99
|
-
added,
|
|
100
|
-
total: working.size,
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
const items = [...working.entries()]
|
|
104
|
-
.map(([sha512, { boardId, path }]) => ({ sha512, boardId, path }))
|
|
105
|
-
.sort();
|
|
106
|
-
const boardId = await E(board).getId(JSON.stringify(items));
|
|
107
|
-
console.log({
|
|
108
|
-
boardId,
|
|
109
|
-
});
|
|
110
|
-
};
|