From ef86842fcc484ff3b86818cc67de338f63ccd3d3 Mon Sep 17 00:00:00 2001 From: Dan Connolly Date: Wed, 24 Jul 2024 15:47:40 -0500 Subject: [PATCH] chore: flesh out unbondExample --- .../src/examples/unbondExample.contract.js | 8 +++- .../src/examples/unbondExample.flows.js | 38 +++++++++++-------- 2 files changed, 29 insertions(+), 17 deletions(-) diff --git a/packages/orchestration/src/examples/unbondExample.contract.js b/packages/orchestration/src/examples/unbondExample.contract.js index be724e5ae52b..77bf648db8b6 100644 --- a/packages/orchestration/src/examples/unbondExample.contract.js +++ b/packages/orchestration/src/examples/unbondExample.contract.js @@ -1,4 +1,5 @@ import { M } from '@endo/patterns'; +import { makeStateRecord } from '@agoric/async-flow'; import { withOrchestration } from '../utils/start-helper.js'; import * as flows from './unbondExample.flows.js'; @@ -28,9 +29,14 @@ import * as flows from './unbondExample.flows.js'; * @param {OrchestrationTools} tools */ const contract = async (zcf, privateArgs, zone, { orchestrate }) => { + const contractState = makeStateRecord( + /** @type {{ account: OrchestrationAccount | undefined }} */ { + account: undefined, + }, + ); const unbondAndLiquidStake = orchestrate( 'LSTTia', - { zcf }, + { zcf, contractState }, flows.unbondAndLiquidStake, ); diff --git a/packages/orchestration/src/examples/unbondExample.flows.js b/packages/orchestration/src/examples/unbondExample.flows.js index 77ad91d050a8..133ed5a240cb 100644 --- a/packages/orchestration/src/examples/unbondExample.flows.js +++ b/packages/orchestration/src/examples/unbondExample.flows.js @@ -1,39 +1,45 @@ /** - * @import {Orchestrator, OrchestrationFlow} from '../types.js' + * @import {Orchestrator, OrchestrationFlow, OrchestrationAccountI, LocalAccountMethods, StakingAccountQueries} from '../types.js' */ +import { NonNullish } from '@agoric/internal'; + /** * @satisfies {OrchestrationFlow} * @param {Orchestrator} orch * @param {object} ctx * @param {ZCF} ctx.zcf + * @param {{ account?: OrchestrationAccountI & StakingAccountQueries }} ctx.contractState * @param {ZCFSeat} _seat * @param {undefined} _offerArgs */ export const unbondAndLiquidStake = async ( orch, - { zcf }, + { zcf, contractState }, _seat, _offerArgs, ) => { console.log('zcf within the membrane', zcf); - // We would actually alreaady have the account from the orchestrator - // ??? could these be passed in? It would reduce the size of this handler, - // keeping it focused on long-running operations. - const omni = await orch.getChain('omniflixhub'); - const omniAccount = await omni.makeAccount(); - // TODO implement these - // const delegations = await celestiaAccount.getDelegations(); - // // wait for the undelegations to be complete (may take weeks) - // await celestiaAccount.undelegate(delegations); - // ??? should this be synchronous? depends on how names are resolved. + await null; + if (!contractState.account) { + const omni = await orch.getChain('omniflixhub'); + const omniAccount = await omni.makeAccount(); + contractState.account = omniAccount; + } + + const omniAccount = NonNullish(contractState.account); + const delegations = await omniAccount.getDelegations(); + + // wait for the undelegations to be complete (may take weeks) + await omniAccount.undelegate(delegations); + const stride = await orch.getChain('stride'); const strideAccount = await stride.makeAccount(); - // TODO the `TIA` string actually needs to be the Brand from AgoricNames - // const tiaAmt = await celestiaAccount.getBalance('TIA'); - // await celestiaAccount.transfer(tiaAmt, strideAccount.getAddress()); - // await strideAccount.liquidStake(tiaAmt); + const denom = 'uflix'; + const flixAmt = await omniAccount.getBalance(denom); + await omniAccount.transfer(flixAmt, strideAccount.getAddress()); + await strideAccount.liquidStake(flixAmt); console.log(omniAccount, strideAccount); };