Skip to content

Commit

Permalink
feat(cosmic-swingset): add being block check and transaction
Browse files Browse the repository at this point in the history
  • Loading branch information
mhofman committed Oct 4, 2023
1 parent b9a5cb4 commit bfd03d1
Showing 1 changed file with 33 additions and 0 deletions.
33 changes: 33 additions & 0 deletions packages/cosmic-swingset/src/launch-chain.js
Original file line number Diff line number Diff line change
Expand Up @@ -497,6 +497,9 @@ export async function launch({
}

let savedHeight = Number(kvStore.get(getHostKey('height')) || 0);
let savedBeginHeight = Number(
kvStore.get(getHostKey('beginHeight')) || savedHeight,
);
let runTime = 0;
let chainTime;
let saveTime = 0;
Expand Down Expand Up @@ -711,6 +714,11 @@ export async function launch({
throw decohered;
}

function saveBeginHeight(blockHeight) {
savedBeginHeight = blockHeight;
kvStore.set(getHostKey('beginHeight'), `${savedBeginHeight}`);
}

async function afterCommit(blockHeight, blockTime) {
await waitUntilQuiescent()
.then(afterCommitCallback)
Expand Down Expand Up @@ -749,6 +757,9 @@ export async function launch({
type: 'cosmic-swingset-bootstrap-block-start',
blockTime,
});
// Start a block transaction, but without changing state
// for the upcoming begin block check
saveBeginHeight(0);
await processAction(action.type, async () =>
bootstrapBlock(blockHeight, blockTime, bootstrapBlockParams),
);
Expand Down Expand Up @@ -780,6 +791,10 @@ export async function launch({
return undefined;
}

// Start a block transaction, but without changing state
// for the upcoming begin block check
saveBeginHeight(savedBeginHeight);

controller.writeSlogObject({
type: 'cosmic-swingset-upgrade-start',
blockHeight,
Expand Down Expand Up @@ -910,6 +925,17 @@ export async function launch({
blockManagerConsole.info('block', blockHeight, 'begin');
runTime = 0;

if (blockNeedsExecution(blockHeight)) {
if (savedBeginHeight === blockHeight) {
decohered = Error(
`Inconsistent committed state. Block ${blockHeight} had already began execution`,
);
throw decohered;
}
// Start a block transaction, recording which block height is executed
saveBeginHeight(blockHeight);
}

controller.writeSlogObject({
type: 'cosmic-swingset-begin-block',
blockHeight,
Expand Down Expand Up @@ -947,6 +973,13 @@ export async function launch({
throw e;
}
} else {
if (blockHeight !== savedBeginHeight) {
decohered = Error(
`Inconsistent committed state. Trying to end block ${blockHeight}, expected began block ${savedBeginHeight}`,
);
throw decohered;
}

// And now we actually process the queued actions down here, during
// END_BLOCK, but still reentrancy-protected.

Expand Down

0 comments on commit bfd03d1

Please sign in to comment.