Skip to content

Commit

Permalink
Prioritize block hash over number in singular time travel queries (#462)
Browse files Browse the repository at this point in the history
* Keep return value for singular subgraph entity queries nullable

* Prioritize block hash over number in time travel queries

* Throw error when block with given hash doesn't exist in db
  • Loading branch information
prathamesh0 authored Nov 10, 2023
1 parent 6957239 commit 32d5cd1
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 9 deletions.
2 changes: 1 addition & 1 deletion packages/codegen/src/schema.ts
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,7 @@ export class Schema {
const queryObject: { [key: string]: any; } = {};
queryObject[queryName] = {
// Get type composer object for return type from the schema composer.
type: this._composer.getAnyTC(subgraphType).NonNull,
type: this._composer.getAnyTC(subgraphType),
args: {
id: 'ID!',
block: BlockHeight
Expand Down
10 changes: 9 additions & 1 deletion packages/util/src/database.ts
Original file line number Diff line number Diff line change
Expand Up @@ -515,7 +515,15 @@ export class Database {
`;

// Fetching blockHash for previous entity in frothy region.
const [{ block_hash: blockHash, block_number: blockNumber, id }] = await queryRunner.query(heirerchicalQuery, [data.blockHash, data.id, MAX_REORG_DEPTH]);
const result = await queryRunner.query(heirerchicalQuery, [data.blockHash, data.id, MAX_REORG_DEPTH]);

// Check if empty array returned
// (occurs when block at given hash doesn't exist in the db)
if (!result?.length) {
throw new Error('no block with that hash found');
}

const [{ block_hash: blockHash, block_number: blockNumber, id }] = result;

return { blockHash, blockNumber, id };
}
Expand Down
10 changes: 3 additions & 7 deletions packages/util/src/graph/database.ts
Original file line number Diff line number Diff line change
Expand Up @@ -222,18 +222,14 @@ export class GraphDatabase {
block: CanonicalBlockHeight = {},
selections: ReadonlyArray<SelectionNode> = []
): Promise<Entity | undefined> {
let { hash: blockHash, number: blockNumber } = block;
const { hash: blockHash, number: blockNumber } = block;
const repo = queryRunner.manager.getRepository<Entity>(entityType);
const whereOptions: any = { id };

if (blockNumber) {
whereOptions.blockNumber = LessThanOrEqual(blockNumber);
}

if (blockHash) {
whereOptions.blockHash = blockHash;
const block = await this._baseDatabase.getBlockProgress(queryRunner.manager.getRepository('block_progress'), blockHash);
blockNumber = block?.blockNumber;
} else if (blockNumber) {
whereOptions.blockNumber = LessThanOrEqual(blockNumber);
}

const findOptions = {
Expand Down

0 comments on commit 32d5cd1

Please sign in to comment.