From 46ea364221d2eec6f284b98d4621ae5647b68dda Mon Sep 17 00:00:00 2001 From: Abdul Azeem Date: Wed, 20 Nov 2024 14:21:58 +0300 Subject: [PATCH] feat: Implement removeOldestFilter to manage filtersMap size --- src/api.ts | 10 ++++------ src/utils.ts | 19 +++++++++++++++++++ 2 files changed, 23 insertions(+), 6 deletions(-) diff --git a/src/api.ts b/src/api.ts index a301ddb3..e8b394e8 100755 --- a/src/api.ts +++ b/src/api.ts @@ -27,6 +27,7 @@ import { getSyncTime, removeFromNodeList, sanitizeIpAndPort, + removeOldestFilter, } from './utils' import crypto from 'crypto' import { logEventEmitter } from './logger' @@ -2800,8 +2801,7 @@ export const methods = { type: Types.FilterTypes.block, } if (filtersMap.size >= config.maxEntriesAllowed) { - filtersMap.clear() - console.log(`filtersMap cleared after ${config.maxEntriesAllowed} entries`) + removeOldestFilter(filtersMap) } filtersMap.set(filterId.toString(), internalFilter) @@ -2838,8 +2838,7 @@ export const methods = { type: Types.FilterTypes.pendingTransaction, } if (filtersMap.size >= config.maxEntriesAllowed) { - filtersMap.clear() - console.log(`filtersMap cleared after ${config.maxEntriesAllowed} entries`) + removeOldestFilter(filtersMap) } filtersMap.set(filterId.toString(), internalFilter) @@ -2943,8 +2942,7 @@ export const methods = { type: Types.FilterTypes.log, } if (filtersMap.size >= config.maxEntriesAllowed) { - filtersMap.clear() - console.log(`filtersMap cleared after ${config.maxEntriesAllowed} entries`) + removeOldestFilter(filtersMap) } filtersMap.set(filterId.toString(), internalFilter) diff --git a/src/utils.ts b/src/utils.ts index 38fda413..a60d10e0 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -29,6 +29,7 @@ import { OriginalTxData, AccountTypesData, Account2, + InternalFilter } from './types' import Sntp from '@hapi/sntp' import { randomBytes, createHash } from 'crypto' @@ -1838,6 +1839,24 @@ export function sanitizeIpAndPort(ipPort: string): { isValid: boolean; error?: s return { isValid: true } } +export function removeOldestFilter(filtersMap: Map): void { + let oldestKey: string | undefined; + let oldestTimestamp = Infinity; + + // Iterate through the map to find the oldest entry + for (const [key, value] of filtersMap) { + if (value.filter.lastQueriedTimestamp < oldestTimestamp) { + oldestTimestamp = value.filter.lastQueriedTimestamp; + oldestKey = key; + } + } + + // Remove the oldest entry + if (oldestKey !== undefined) { + filtersMap.delete(oldestKey); + } +} + class Semaphore { private queue: (() => void)[] = [] private value: number