mirror of
https://github.com/cerc-io/watcher-ts
synced 2025-01-08 12:28:05 +00:00
Mark entities as removed on store remove host API call (#484)
This commit is contained in:
parent
8c44fbbe6d
commit
e6b957e921
@ -282,8 +282,9 @@ export class Entity {
|
||||
// Add subgraph entity specific columns.
|
||||
entityObject = this._addSubgraphColumns(subgraphTypeDefs, entityObject, def);
|
||||
|
||||
// Add is_pruned column.
|
||||
entityObject.columns.push({
|
||||
// Add is_pruned, is_removed columns.
|
||||
entityObject.columns.push(
|
||||
{
|
||||
name: 'isPruned',
|
||||
pgType: 'boolean',
|
||||
tsType: 'boolean',
|
||||
@ -294,7 +295,20 @@ export class Entity {
|
||||
value: false
|
||||
}
|
||||
]
|
||||
});
|
||||
},
|
||||
{
|
||||
name: 'isRemoved',
|
||||
pgType: 'boolean',
|
||||
tsType: 'boolean',
|
||||
columnType: 'Column',
|
||||
columnOptions: [
|
||||
{
|
||||
option: 'default',
|
||||
value: false
|
||||
}
|
||||
]
|
||||
}
|
||||
);
|
||||
|
||||
// Add decimalTransformer column option if required.
|
||||
this._addDecimalTransformerOption(entityObject);
|
||||
|
@ -142,8 +142,6 @@ export class Indexer implements IndexerInterface {
|
||||
this._storageLayoutMap = new Map();
|
||||
this._contractMap = new Map();
|
||||
this.eventSignaturesMap = new Map();
|
||||
let contractInterface: ethers.utils.Interface;
|
||||
let eventSignatures: string[];
|
||||
{{#each contracts as | contract |}}
|
||||
|
||||
const { abi: {{contract.contractName}}ABI{{#if contract.contractStorageLayout}}, storageLayout: {{contract.contractName}}StorageLayout{{/if}} } = {{contract.contractName}}Artifacts;
|
||||
@ -153,15 +151,13 @@ export class Indexer implements IndexerInterface {
|
||||
assert({{contract.contractName}}ABI);
|
||||
this._abiMap.set(KIND_{{capitalize contract.contractName}}, {{contract.contractName}}ABI);
|
||||
|
||||
// eslint-disable-next-line prefer-const
|
||||
contractInterface = new ethers.utils.Interface({{contract.contractName}}ABI);
|
||||
this._contractMap.set(KIND_{{capitalize contract.contractName}}, contractInterface);
|
||||
const {{contract.contractName}}ContractInterface = new ethers.utils.Interface({{contract.contractName}}ABI);
|
||||
this._contractMap.set(KIND_{{capitalize contract.contractName}}, {{contract.contractName}}ContractInterface);
|
||||
|
||||
// eslint-disable-next-line prefer-const
|
||||
eventSignatures = Object.values(contractInterface.events).map(value => {
|
||||
return contractInterface.getEventTopic(value);
|
||||
const {{contract.contractName}}EventSignatures = Object.values({{contract.contractName}}ContractInterface.events).map(value => {
|
||||
return {{contract.contractName}}ContractInterface.getEventTopic(value);
|
||||
});
|
||||
this.eventSignaturesMap.set(KIND_{{capitalize contract.contractName}}, eventSignatures);
|
||||
this.eventSignaturesMap.set(KIND_{{capitalize contract.contractName}}, {{contract.contractName}}EventSignatures);
|
||||
{{#if contract.contractStorageLayout}}
|
||||
|
||||
assert({{contract.contractName}}StorageLayout);
|
||||
|
@ -79,7 +79,7 @@ export const instantiate = async (
|
||||
assert(context.block);
|
||||
const entityData = await database.getEntity(entityName, entityId, context.block.blockHash);
|
||||
|
||||
if (!entityData) {
|
||||
if (!entityData || entityData.isRemoved) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@ -112,6 +112,25 @@ export const instantiate = async (
|
||||
indexer.updateSubgraphState(context.contractAddress, diffData);
|
||||
}
|
||||
},
|
||||
'store.remove': async (entity: number, id: number) => {
|
||||
const entityName = __getString(entity);
|
||||
const entityId = __getString(id);
|
||||
|
||||
assert(context.block);
|
||||
const entityData = await database.getEntity(entityName, entityId, context.block.blockHash);
|
||||
|
||||
if (!entityData || entityData.isRemoved) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Add an additional entry at block with isRemoved set to true
|
||||
entityData.blockHash = context.block.blockHash;
|
||||
entityData.blockNumber = context.block.blockNumber;
|
||||
entityData.isRemoved = true;
|
||||
|
||||
const dbEntity = await database.saveEntity(entityName, entityData);
|
||||
database.cacheUpdatedEntityByName(entityName, dbEntity);
|
||||
},
|
||||
|
||||
'log.log': (level: number, msg: number) => {
|
||||
log('log %s | %s', Level[level], __getString(msg));
|
||||
|
@ -935,8 +935,8 @@ export class GraphDatabase {
|
||||
const entityValuePromises = entityFields.filter(field => {
|
||||
const { propertyName } = field;
|
||||
|
||||
// Filter out blockHash and blockNumber from entity fields to fill the entityInstance (wasm).
|
||||
if (propertyName === 'blockHash' || propertyName === 'blockNumber') {
|
||||
// Filter out custom fields from entity to fill the entityInstance (wasm).
|
||||
if (['isPruned', 'isRemoved', 'blockHash', 'blockNumber'].includes(propertyName)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -1013,7 +1013,7 @@ export class GraphDatabase {
|
||||
const entityValuePromises = entityFields.map(async (field: any) => {
|
||||
const { propertyName } = field;
|
||||
|
||||
if (propertyName === 'isPruned') {
|
||||
if (['isPruned', 'isRemoved'].includes(propertyName)) {
|
||||
return undefined;
|
||||
}
|
||||
|
||||
|
@ -638,7 +638,7 @@ export const parseEntityValue = async (instanceExports: any, valuePtr: number):
|
||||
}
|
||||
};
|
||||
|
||||
export const formatEntityValue = async (instanceExports: any, type: string, value: any, isArray: boolean): Promise<any> => {
|
||||
const formatEntityValue = async (instanceExports: any, type: string, value: any, isArray: boolean): Promise<any> => {
|
||||
let valueToFormat = value;
|
||||
let typeName = type;
|
||||
if (isArray) {
|
||||
|
Loading…
Reference in New Issue
Block a user