Skip to content

Commit

Permalink
feat: parameterize fusdc with chainInfo and assetInfo
Browse files Browse the repository at this point in the history
  • Loading branch information
0xpatrickdev committed Nov 26, 2024
1 parent 176069b commit 72e019b
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 9 deletions.
29 changes: 28 additions & 1 deletion packages/builders/scripts/fast-usdc/init-fast-usdc.js
Original file line number Diff line number Diff line change
Expand Up @@ -124,11 +124,17 @@ const options = {
default:
'ibc/FE98AAD68F02F03565E9FA39A5E627946699B2B07115889ED812D8BA639576A9',
},
chainInfo: { type: 'string' },
assetInfo: { type: 'string' },
};
const oraclesUsage = 'use --oracle name:address ...';

const feedPolicyUsage = 'use --feedPolicy <policy> ...';

const chainInfoUsage = 'use --chainInfo chainName:CosmosChainInfo ...';
const assetInfoUsage =
'use --assetInfo denom:DenomInfo & {brandKey?: string} ...';

/**
* @typedef {{
* flatFee: string;
Expand All @@ -139,6 +145,8 @@ const feedPolicyUsage = 'use --feedPolicy <policy> ...';
* oracle?: string[];
* usdcDenom: string;
* feedPolicy?: string;
* chainInfo: string;
* assetInfo: string;
* }} FastUSDCOpts
*/

Expand Down Expand Up @@ -180,7 +188,15 @@ export default async (homeP, endowments) => {
/** @type {{ values: FastUSDCOpts }} */
// @ts-expect-error ensured by options
const {
values: { oracle: oracleArgs, net, usdcDenom, feedPolicy, ...fees },
values: {
oracle: oracleArgs,
net,
usdcDenom,
feedPolicy,
chainInfo,
assetInfo,
...fees
},
} = parseArgs({ args: scriptArgs, options });

const parseFeedPolicy = () => {
Expand Down Expand Up @@ -226,6 +242,15 @@ export default async (homeP, endowments) => {
};
};

const parseChainInfo = () => {
if (!chainInfo) throw Error(chainInfoUsage);
return JSON.parse(chainInfo);
};
const parseAssetInfo = () => {
if (!assetInfo) throw Error(assetInfoUsage);
return JSON.parse(assetInfo);
};

/** @type {FastUSDCConfig} */
const config = harden({
oracles: parseOracleArgs(),
Expand All @@ -234,6 +259,8 @@ export default async (homeP, endowments) => {
},
feeConfig: parseFeeConfigArgs(),
feedPolicy: parseFeedPolicy(),
chainInfo: parseChainInfo(),
assetInfo: parseAssetInfo(),
});

await writeCoreEval('start-fast-usdc', utils =>
Expand Down
24 changes: 21 additions & 3 deletions packages/fast-usdc/src/fast-usdc.contract.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,10 @@ import {
} from '@agoric/internal';
import { observeIteration, subscribeEach } from '@agoric/notifier';
import {
CosmosChainInfoShape,
DenomDetailShape,
OrchestrationPowersShape,
registerChainsAndAssets,
withOrchestration,
} from '@agoric/orchestration';
import { provideSingleton } from '@agoric/zoe/src/contractSupport/durability.js';
Expand All @@ -27,9 +30,8 @@ import * as flows from './fast-usdc.flows.js';
const trace = makeTracer('FastUsdc');

/**
* @import {Denom} from '@agoric/orchestration';
* @import {HostInterface} from '@agoric/async-flow';
* @import {OrchestrationAccount} from '@agoric/orchestration';
* @import {CosmosChainInfo, Denom, DenomDetail, OrchestrationAccount} from '@agoric/orchestration';
* @import {OrchestrationPowers, OrchestrationTools} from '@agoric/orchestration/src/utils/start-helper.js';
* @import {Vow} from '@agoric/vow';
* @import {Zone} from '@agoric/zone';
Expand All @@ -53,6 +55,8 @@ export const meta = {
...OrchestrationPowersShape,
feeConfig: FeeConfigShape,
marshaller: M.remotable(),
chainInfo: M.recordOf(M.string(), CosmosChainInfoShape),
assetInfo: M.recordOf(M.string(), DenomDetailShape),
},
};
harden(meta);
Expand All @@ -62,6 +66,8 @@ harden(meta);
* @param {OrchestrationPowers & {
* marshaller: Marshaller;
* feeConfig: FeeConfig;
* chainInfo: Record<string, CosmosChainInfo>;
* assetInfo: Record<Denom, DenomDetail & { brandKey?: string}>;
* }} privateArgs
* @param {Zone} zone
* @param {OrchestrationTools} tools
Expand All @@ -82,7 +88,7 @@ export const contract = async (zcf, privateArgs, zone, tools) => {

const { USDC } = terms.brands;
const { withdrawToSeat } = tools.zoeTools;
const { chainHub, orchestrateAll, vowTools } = tools;
const { baggage, chainHub, orchestrateAll, vowTools } = tools;
const makeSettler = prepareSettler(zone, {
statusManager,
USDC,
Expand Down Expand Up @@ -212,6 +218,18 @@ export const contract = async (zcf, privateArgs, zone, tools) => {
makeLiquidityPoolKit(shareMint, privateArgs.storageNode),
);

/** Chain, connection, and asset info can only be registered once */
const firstIncarnationKey = 'firstIncarnationKey';
if (!baggage.has(firstIncarnationKey)) {
baggage.init(firstIncarnationKey, true);
registerChainsAndAssets(
chainHub,
terms.brands,
privateArgs.chainInfo,
privateArgs.assetInfo,
);
}

const feedKit = zone.makeOnce('Feed Kit', () => makeFeedKit());

const poolAccountV = zone.makeOnce('PoolAccount', () => makeLocalAccount());
Expand Down
19 changes: 14 additions & 5 deletions packages/fast-usdc/src/fast-usdc.start.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { deeplyFulfilledObject, makeTracer, objectMap } from '@agoric/internal';
import { CosmosChainInfoShape, DenomDetailShape } from '@agoric/orchestration';
import { Fail } from '@endo/errors';
import { E } from '@endo/far';
import { makeMarshal } from '@endo/marshal';
Expand All @@ -13,6 +14,7 @@ import { fromExternalConfig } from './utils/config-marshal.js';
/**
* @import {DepositFacet} from '@agoric/ertp/src/types.js'
* @import {TypedPattern} from '@agoric/internal'
* @import {CosmosChainInfo, Denom, DenomDetail} from '@agoric/orchestration';
* @import {Instance, StartParams} from '@agoric/zoe/src/zoeService/utils'
* @import {Board} from '@agoric/vats'
* @import {ManifestBundleRef} from '@agoric/deploy-script-support/src/externalTypes.js'
Expand All @@ -33,6 +35,8 @@ const contractName = 'fastUsdc';
* oracles: Record<string, string>;
* feeConfig: FeeConfig;
* feedPolicy: FeedPolicy & Passable;
* chainInfo: Record<string, CosmosChainInfo & Passable>;
* assetInfo: Record<Denom, DenomDetail & {brandKey?: string}>;
* }} FastUSDCConfig
*/
/** @type {TypedPattern<FastUSDCConfig>} */
Expand All @@ -41,6 +45,8 @@ export const FastUSDCConfigShape = M.splitRecord({
oracles: M.recordOf(M.string(), M.string()),
feeConfig: FeeConfigShape,
feedPolicy: FeedPolicyShape,
chainInfo: M.recordOf(M.string(), CosmosChainInfoShape),
assetInfo: M.recordOf(M.string(), DenomDetailShape),
});

/**
Expand Down Expand Up @@ -149,11 +155,12 @@ export const startFastUSDC = async (
USDC: await E(USDCissuer).getBrand(),
});

const { terms, oracles, feeConfig, feedPolicy } = fromExternalConfig(
config?.options, // just in case config is missing somehow
brands,
FastUSDCConfigShape,
);
const { terms, oracles, feeConfig, feedPolicy, chainInfo, assetInfo } =
fromExternalConfig(
config?.options, // just in case config is missing somehow
brands,
FastUSDCConfigShape,
);
trace('using terms', terms);
trace('using fee config', feeConfig);

Expand Down Expand Up @@ -187,6 +194,8 @@ export const startFastUSDC = async (
storageNode,
timerService,
marshaller,
chainInfo,
assetInfo,
}),
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ Generated by [AVA](https://avajs.dev).
Recorder_kindHandle: 'Alleged: kind',
},
},
firstIncarnationKey: true,
orchestration: {
'Cosmos Orchestration Account Holder_kindHandle': 'Alleged: kind',
'Local Orchestration Account Kit_kindHandle': 'Alleged: kind',
Expand Down
Binary file modified packages/fast-usdc/test/snapshots/fast-usdc.contract.test.ts.snap
Binary file not shown.
2 changes: 2 additions & 0 deletions packages/fast-usdc/test/supports.ts
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,8 @@ export const commonSetup = async (t: ExecutionContext<any>) => {
marshaller,
timerService: timer,
feeConfig: makeTestFeeConfig(usdc),
chainInfo: {},
assetInfo: {},
},
facadeServices: {
agoricNames,
Expand Down

0 comments on commit 72e019b

Please sign in to comment.