From 9d75cc562e60dba18d719bdba5913f63c0660e94 Mon Sep 17 00:00:00 2001 From: JCNoguera Date: Thu, 18 Jan 2024 16:55:48 +0100 Subject: [PATCH 1/6] fix: use both node and permanode for client data fetch --- api/src/initServices.ts | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/api/src/initServices.ts b/api/src/initServices.ts index 4c643f32e..47764d29b 100644 --- a/api/src/initServices.ts +++ b/api/src/initServices.ts @@ -1,5 +1,5 @@ import { MqttClient as ChrysalisMqttClient } from "@iota/mqtt.js"; -import { Client as StardustClient } from "@iota/sdk"; +import { IClientOptions, Client as StardustClient } from "@iota/sdk"; import { ServiceFactory } from "./factories/serviceFactory"; import logger from "./logger"; import { IConfiguration } from "./models/configuration/IConfiguration"; @@ -141,10 +141,19 @@ function initChrysalisServices(networkConfig: INetwork): void { */ function initStardustServices(networkConfig: INetwork): void { logger.verbose(`Initializing Stardust services for ${networkConfig.network}`); - const stardustClient = new StardustClient({ + const stardustClientParams: IClientOptions = { nodes: [networkConfig.provider], brokerOptions: { useWs: true }, - }); + }; + + if (networkConfig.permaNodeEndpoint) { + // Use both the node and permaNode to fetch data correctly + // Reference: https://github.com/iotaledger/iota-sdk/issues/1808#issuecomment-1893331116 + stardustClientParams.permanodes = [networkConfig.permaNodeEndpoint]; + stardustClientParams.ignoreNodeHealth = true; + } + + const stardustClient = new StardustClient(stardustClientParams); ServiceFactory.register(`client-${networkConfig.network}`, () => stardustClient); if (networkConfig.permaNodeEndpoint) { From 8f321d7bcd3ca6a498b0a2e3f418f76b11f5ff89 Mon Sep 17 00:00:00 2001 From: JCNoguera Date: Fri, 19 Jan 2024 13:42:36 +0100 Subject: [PATCH 2/6] feat: create mqttClient inside the StardustFeed class --- api/src/initServices.ts | 26 +++++-------------- .../services/stardust/feed/stardustFeed.ts | 23 +++++++++------- 2 files changed, 20 insertions(+), 29 deletions(-) diff --git a/api/src/initServices.ts b/api/src/initServices.ts index 47764d29b..477f7b5b9 100644 --- a/api/src/initServices.ts +++ b/api/src/initServices.ts @@ -141,39 +141,27 @@ function initChrysalisServices(networkConfig: INetwork): void { */ function initStardustServices(networkConfig: INetwork): void { logger.verbose(`Initializing Stardust services for ${networkConfig.network}`); + const stardustClientParams: IClientOptions = { - nodes: [networkConfig.provider], - brokerOptions: { useWs: true }, + primaryNode: networkConfig.provider, }; if (networkConfig.permaNodeEndpoint) { - // Use both the node and permaNode to fetch data correctly - // Reference: https://github.com/iotaledger/iota-sdk/issues/1808#issuecomment-1893331116 - stardustClientParams.permanodes = [networkConfig.permaNodeEndpoint]; + stardustClientParams.nodes = [networkConfig.permaNodeEndpoint]; stardustClientParams.ignoreNodeHealth = true; - } - - const stardustClient = new StardustClient(stardustClientParams); - ServiceFactory.register(`client-${networkConfig.network}`, () => stardustClient); - - if (networkConfig.permaNodeEndpoint) { - // Client with permanode needs the ignoreNodeHealth as chronicle is considered "not healthy" by the sdk - // Related: https://github.com/iotaledger/inx-chronicle/issues/1302 - const stardustPermanodeClient = new StardustClient({ - nodes: [networkConfig.permaNodeEndpoint], - ignoreNodeHealth: true, - }); - ServiceFactory.register(`permanode-client-${networkConfig.network}`, () => stardustPermanodeClient); const chronicleService = new ChronicleService(networkConfig); ServiceFactory.register(`chronicle-${networkConfig.network}`, () => chronicleService); } + const stardustClient = new StardustClient(stardustClientParams); + ServiceFactory.register(`client-${networkConfig.network}`, () => stardustClient); + // eslint-disable-next-line no-void void NodeInfoService.build(networkConfig).then((nodeInfoService) => { ServiceFactory.register(`node-info-${networkConfig.network}`, () => nodeInfoService); - const stardustFeed = new StardustFeed(networkConfig.network); + const stardustFeed = new StardustFeed(networkConfig); ServiceFactory.register(`feed-${networkConfig.network}`, () => stardustFeed); }); diff --git a/api/src/services/stardust/feed/stardustFeed.ts b/api/src/services/stardust/feed/stardustFeed.ts index b4db7d0f8..e013b3c2e 100644 --- a/api/src/services/stardust/feed/stardustFeed.ts +++ b/api/src/services/stardust/feed/stardustFeed.ts @@ -5,6 +5,7 @@ import logger from "../../../logger"; import { IFeedItemMetadata } from "../../../models/api/stardust/feed/IFeedItemMetadata"; import { IFeedUpdate } from "../../../models/api/stardust/feed/IFeedUpdate"; import { ILatestMilestone } from "../../../models/api/stardust/milestone/ILatestMilestonesResponse"; +import { INetwork } from "../../../models/db/INetwork"; import { blockIdFromMilestonePayload } from "../../../utils/stardust/utils"; import { NodeInfoService } from "../nodeInfoService"; @@ -60,20 +61,22 @@ export class StardustFeed { /** * The network in context (from Init). */ - private readonly network: string; + private readonly networkId: string; /** * Creates a new instance of StardustFeed. - * @param networkId The network id. + * @param network The network config. */ - constructor(networkId: string) { + constructor(network: INetwork) { this.blockSubscribers = {}; this.milestoneSubscribers = {}; this.blockMetadataCache = new Map(); - this.network = networkId; - this._mqttClient = ServiceFactory.get(`client-${networkId}`); - const nodeInfoService = ServiceFactory.get(`node-info-${networkId}`); - + this.networkId = network.network; + this._mqttClient = new Client({ + nodes: [network.provider], + brokerOptions: { useWs: true }, + }); + const nodeInfoService = ServiceFactory.get(`node-info-${this.networkId}`); if (this._mqttClient && nodeInfoService) { const nodeInfo = nodeInfoService.getNodeInfo(); this.networkProtocolVersion = nodeInfo.protocolVersion; @@ -81,7 +84,7 @@ export class StardustFeed { this.setupCacheTrimJob(); this.connect(); } else { - throw new Error(`Failed to build stardustFeed instance for ${networkId}`); + throw new Error(`Failed to build stardustFeed instance for ${this.networkId}`); } } @@ -116,7 +119,7 @@ export class StardustFeed { * @param subscriptionId The id to unsubscribe. */ public unsubscribeBlocks(subscriptionId: string): void { - logger.debug(`[StardustFeed] Removing subscriber ${subscriptionId} from blocks (${this.network})`); + logger.debug(`[StardustFeed] Removing subscriber ${subscriptionId} from blocks (${this.networkId})`); delete this.blockSubscribers[subscriptionId]; } @@ -125,7 +128,7 @@ export class StardustFeed { * @param subscriptionId The id to unsubscribe. */ public unsubscribeMilestones(subscriptionId: string): void { - logger.debug(`[StardustFeed] Removing subscriber ${subscriptionId} from milestones (${this.network})`); + logger.debug(`[StardustFeed] Removing subscriber ${subscriptionId} from milestones (${this.networkId})`); delete this.milestoneSubscribers[subscriptionId]; } From 484b9a66663607e3cb48a5de364ffdf612226817 Mon Sep 17 00:00:00 2001 From: JCNoguera Date: Fri, 19 Jan 2024 13:44:54 +0100 Subject: [PATCH 3/6] chore: rename `tryFetchNodeThenPermanode` function --- api/src/utils/stardust/searchExecutor.ts | 10 ++-- .../utils/stardust/stardustTangleHelper.ts | 50 +++++++------------ 2 files changed, 22 insertions(+), 38 deletions(-) diff --git a/api/src/utils/stardust/searchExecutor.ts b/api/src/utils/stardust/searchExecutor.ts index 7fb1c33dc..499a48d52 100644 --- a/api/src/utils/stardust/searchExecutor.ts +++ b/api/src/utils/stardust/searchExecutor.ts @@ -31,7 +31,7 @@ export class SearchExecutor { if (searchQuery.did) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeThenPermanode(searchQuery.aliasId, "aliasOutputId", network) + StardustTangleHelper.tryFetchNodeData(searchQuery.aliasId, "aliasOutputId", network) .then((aliasOutputs) => { if (aliasOutputs) { promisesResult = { @@ -137,7 +137,7 @@ export class SearchExecutor { if (searchQuery.output) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeThenPermanode(searchQuery.output, "getOutput", network) + StardustTangleHelper.tryFetchNodeData(searchQuery.output, "getOutput", network) .then((output) => { if (output) { promisesResult = { output }; @@ -156,7 +156,7 @@ export class SearchExecutor { if (searchQuery.aliasId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeThenPermanode(searchQuery.aliasId, "aliasOutputId", network) + StardustTangleHelper.tryFetchNodeData(searchQuery.aliasId, "aliasOutputId", network) .then((aliasOutputs) => { if (aliasOutputs) { promisesResult = { @@ -177,7 +177,7 @@ export class SearchExecutor { if (searchQuery.nftId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeThenPermanode(searchQuery.nftId, "nftOutputId", network) + StardustTangleHelper.tryFetchNodeData(searchQuery.nftId, "nftOutputId", network) .then((nftOutputs) => { if (nftOutputs) { promisesResult = { @@ -198,7 +198,7 @@ export class SearchExecutor { if (searchQuery.foundryId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeThenPermanode(searchQuery.foundryId, "foundryOutputId", network) + StardustTangleHelper.tryFetchNodeData(searchQuery.foundryId, "foundryOutputId", network) .then((foundryOutput) => { if (foundryOutput) { promisesResult = { diff --git a/api/src/utils/stardust/stardustTangleHelper.ts b/api/src/utils/stardust/stardustTangleHelper.ts index 3d0b22dba..4e05326e4 100644 --- a/api/src/utils/stardust/stardustTangleHelper.ts +++ b/api/src/utils/stardust/stardustTangleHelper.ts @@ -88,7 +88,7 @@ export class StardustTangleHelper { */ public static async block(network: INetwork, blockId: string): Promise { blockId = HexHelper.addPrefix(blockId); - const block = await this.tryFetchNodeThenPermanode(blockId, "getBlock", network); + const block = await this.tryFetchNodeData(blockId, "getBlock", network); if (!block) { return { error: `Couldn't find block with id ${blockId}` }; @@ -114,7 +114,7 @@ export class StardustTangleHelper { */ public static async blockDetails(network: INetwork, blockId: string): Promise { blockId = HexHelper.addPrefix(blockId); - const metadata = await this.tryFetchNodeThenPermanode(blockId, "getBlockMetadata", network); + const metadata = await this.tryFetchNodeData(blockId, "getBlockMetadata", network); if (metadata) { return { @@ -131,7 +131,7 @@ export class StardustTangleHelper { */ public static async transactionIncludedBlock(network: INetwork, transactionId: string): Promise { transactionId = HexHelper.addPrefix(transactionId); - const block = await this.tryFetchNodeThenPermanode(transactionId, "getIncludedBlock", network); + const block = await this.tryFetchNodeData(transactionId, "getIncludedBlock", network); if (!block) { return { error: `Couldn't find block from transaction id ${transactionId}` }; @@ -155,7 +155,7 @@ export class StardustTangleHelper { * @returns The item details. */ public static async outputDetails(network: INetwork, outputId: string): Promise { - const outputResponse = await this.tryFetchNodeThenPermanode(outputId, "getOutput", network); + const outputResponse = await this.tryFetchNodeData(outputId, "getOutput", network); return outputResponse ? { output: outputResponse } : { message: "Output not found" }; } @@ -196,7 +196,7 @@ export class StardustTangleHelper { * @returns The milestone details. */ public static async milestoneDetailsById(network: INetwork, milestoneId: string): Promise { - const milestonePayload = await this.tryFetchNodeThenPermanode(milestoneId, "getMilestoneById", network); + const milestonePayload = await this.tryFetchNodeData(milestoneId, "getMilestoneById", network); if (milestonePayload) { const nodeInfoService = ServiceFactory.get(`node-info-${network.network}`); @@ -218,11 +218,7 @@ export class StardustTangleHelper { * @returns The milestone details. */ public static async milestoneDetailsByIndex(network: INetwork, milestoneIndex: number): Promise { - const milestonePayload = await this.tryFetchNodeThenPermanode( - milestoneIndex, - "getMilestoneByIndex", - network, - ); + const milestonePayload = await this.tryFetchNodeData(milestoneIndex, "getMilestoneByIndex", network); if (milestonePayload) { const nodeInfoService = ServiceFactory.get(`node-info-${network.network}`); @@ -250,7 +246,7 @@ export class StardustTangleHelper { let outputIds: string[] = []; do { - const outputIdsResponse = await this.tryFetchNodeThenPermanode( + const outputIdsResponse = await this.tryFetchNodeData( [{ address: addressBech32 }, { cursor: cursor ?? "" }], "basicOutputIds", network, @@ -278,7 +274,7 @@ export class StardustTangleHelper { let outputIds: string[] = []; do { - const outputIdsResponse = await this.tryFetchNodeThenPermanode( + const outputIdsResponse = await this.tryFetchNodeData( [{ stateController: addressBech32 }, { cursor: cursor ?? "" }], "aliasOutputIds", network, @@ -306,7 +302,7 @@ export class StardustTangleHelper { let outputIds: string[] = []; do { - const outputIdsResponse = await this.tryFetchNodeThenPermanode( + const outputIdsResponse = await this.tryFetchNodeData( [{ address: addressBech32 }, { cursor: cursor ?? "" }], "nftOutputIds", network, @@ -329,7 +325,7 @@ export class StardustTangleHelper { * @returns The alias details. */ public static async aliasDetails(network: INetwork, aliasId: string): Promise { - const aliasOutputId = await this.tryFetchNodeThenPermanode(aliasId, "aliasOutputId", network); + const aliasOutputId = await this.tryFetchNodeData(aliasId, "aliasOutputId", network); if (aliasOutputId) { const outputResponse = await this.outputDetails(network, aliasOutputId); @@ -348,7 +344,7 @@ export class StardustTangleHelper { */ public static async aliasFoundries(network: INetwork, aliasAddress: string): Promise { try { - const response = await this.tryFetchNodeThenPermanode( + const response = await this.tryFetchNodeData( [{ aliasAddress }], "foundryOutputIds", network, @@ -371,7 +367,7 @@ export class StardustTangleHelper { * @returns The foundry details. */ public static async foundryDetails(network: INetwork, foundryId: string): Promise { - const foundryOutputId = await this.tryFetchNodeThenPermanode(foundryId, "foundryOutputId", network); + const foundryOutputId = await this.tryFetchNodeData(foundryId, "foundryOutputId", network); if (foundryOutputId) { const outputResponse = await this.outputDetails(network, foundryOutputId); @@ -390,7 +386,7 @@ export class StardustTangleHelper { */ public static async nftDetails(network: INetwork, nftId: string): Promise { try { - const nftOutputId = await this.tryFetchNodeThenPermanode(nftId, "nftOutputId", network); + const nftOutputId = await this.tryFetchNodeData(nftId, "nftOutputId", network); if (nftOutputId) { const outputResponse = await this.outputDetails(network, nftOutputId); @@ -418,7 +414,7 @@ export class StardustTangleHelper { ): Promise { try { const params: NftQueryParameter[] = [{ tag: encodedTag }, { pageSize }, { cursor: cursor ?? "" }]; - const basicOutputIdsResponse: IOutputsResponse = await this.tryFetchNodeThenPermanode( + const basicOutputIdsResponse: IOutputsResponse = await this.tryFetchNodeData( params, "basicOutputIds", network, @@ -448,7 +444,7 @@ export class StardustTangleHelper { ): Promise { try { const params: NftQueryParameter[] = [{ tag: encodedTag }, { pageSize }, { cursor: cursor ?? "" }]; - const nftOutputIdsResponse: IOutputsResponse = await this.tryFetchNodeThenPermanode( + const nftOutputIdsResponse: IOutputsResponse = await this.tryFetchNodeData( params, "nftOutputIds", network, @@ -509,32 +505,20 @@ export class StardustTangleHelper { /** * Generic helper function to try fetching from node client. - * On failure (or not present), we try to fetch from permanode (if configured). + * On failure (or not present), SDK will try to fetch from permanode (if configured). * @param args The argument(s) to pass to the fetch calls. * @param methodName The function to call on the client. * @param network The network config in context. * @returns The results or null if call(s) failed. */ - public static async tryFetchNodeThenPermanode(args: A, methodName: ExtractedMethodNames, network: INetwork): Promise | null { - const { permaNodeEndpoint, disableApiFallback } = network; - const isFallbackEnabled = !disableApiFallback; + public static async tryFetchNodeData(args: A, methodName: ExtractedMethodNames, network: INetwork): Promise | null { const client = ServiceFactory.get(`client-${network.network}`); try { - // try fetch from node const result: Promise = client[methodName](args); return await result; } catch {} - if (permaNodeEndpoint && isFallbackEnabled) { - const permanodeClient = ServiceFactory.get(`permanode-client-${network.network}`); - try { - // try fetch from permanode (chronicle) - const result: Promise = permanodeClient[methodName](args); - return await result; - } catch {} - } - return null; } From 446ba1764026b34f7528da0a4942619111953883 Mon Sep 17 00:00:00 2001 From: JCNoguera Date: Fri, 19 Jan 2024 15:10:20 +0100 Subject: [PATCH 4/6] fix: wrap functions in try catch in `stardustTangleHelper` --- api/src/initServices.ts | 4 + .../routes/stardust/address/balance/get.ts | 3 +- .../stardust/address/outputs/alias/get.ts | 3 +- .../stardust/address/outputs/basic/get.ts | 3 +- .../stardust/address/outputs/nft/get.ts | 3 +- .../routes/stardust/alias/foundries/get.ts | 3 +- api/src/routes/stardust/alias/get.ts | 3 +- api/src/routes/stardust/block/get.ts | 3 +- api/src/routes/stardust/block/metadata/get.ts | 3 +- api/src/routes/stardust/foundry/get.ts | 3 +- api/src/routes/stardust/milestone/get.ts | 3 +- api/src/routes/stardust/nft/get.ts | 3 +- api/src/routes/stardust/output/get.ts | 3 +- api/src/routes/stardust/output/tagged/get.ts | 5 +- .../stardust/participation/events/get.ts | 3 +- api/src/routes/stardust/search.ts | 3 +- api/src/routes/stardust/transaction/get.ts | 3 +- api/src/utils/stardust/searchExecutor.ts | 45 ++- .../utils/stardust/stardustTangleHelper.ts | 346 ++++++++---------- 19 files changed, 217 insertions(+), 228 deletions(-) diff --git a/api/src/initServices.ts b/api/src/initServices.ts index 477f7b5b9..f78c07bc8 100644 --- a/api/src/initServices.ts +++ b/api/src/initServices.ts @@ -25,6 +25,7 @@ import { StardustFeed } from "./services/stardust/feed/stardustFeed"; import { InfluxDBService } from "./services/stardust/influx/influxDbService"; import { NodeInfoService } from "./services/stardust/nodeInfoService"; import { StardustStatsService } from "./services/stardust/stats/stardustStatsService"; +import { StardustTangleHelper } from "./utils/stardust/stardustTangleHelper"; const CURRENCY_UPDATE_INTERVAL_MS = 5 * 60000; @@ -157,6 +158,9 @@ function initStardustServices(networkConfig: INetwork): void { const stardustClient = new StardustClient(stardustClientParams); ServiceFactory.register(`client-${networkConfig.network}`, () => stardustClient); + const tangleHelper = new StardustTangleHelper(networkConfig); + ServiceFactory.register(`tangle-helper-${networkConfig.network}`, () => tangleHelper); + // eslint-disable-next-line no-void void NodeInfoService.build(networkConfig).then((nodeInfoService) => { ServiceFactory.register(`node-info-${networkConfig.network}`, () => nodeInfoService); diff --git a/api/src/routes/stardust/address/balance/get.ts b/api/src/routes/stardust/address/balance/get.ts index 2d0032c9b..67eccf23b 100644 --- a/api/src/routes/stardust/address/balance/get.ts +++ b/api/src/routes/stardust/address/balance/get.ts @@ -24,5 +24,6 @@ export async function get(config: IConfiguration, request: IAddressBalanceReques return undefined; } - return StardustTangleHelper.addressDetails(networkConfig, request.address); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.addressDetails(request.address); } diff --git a/api/src/routes/stardust/address/outputs/alias/get.ts b/api/src/routes/stardust/address/outputs/alias/get.ts index 6fcc1aec1..f08664df0 100644 --- a/api/src/routes/stardust/address/outputs/alias/get.ts +++ b/api/src/routes/stardust/address/outputs/alias/get.ts @@ -24,5 +24,6 @@ export async function get(config: IConfiguration, request: IAddressDetailsReques return {}; } - return StardustTangleHelper.aliasOutputDetailsByAddress(networkConfig, request.address); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.aliasOutputDetailsByAddress(request.address); } diff --git a/api/src/routes/stardust/address/outputs/basic/get.ts b/api/src/routes/stardust/address/outputs/basic/get.ts index 616fc181b..94fdc6365 100644 --- a/api/src/routes/stardust/address/outputs/basic/get.ts +++ b/api/src/routes/stardust/address/outputs/basic/get.ts @@ -24,5 +24,6 @@ export async function get(config: IConfiguration, request: IAddressDetailsReques return {}; } - return StardustTangleHelper.basicOutputDetailsByAddress(networkConfig, request.address); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.basicOutputDetailsByAddress(request.address); } diff --git a/api/src/routes/stardust/address/outputs/nft/get.ts b/api/src/routes/stardust/address/outputs/nft/get.ts index 85b8cd4bd..61c6fb080 100644 --- a/api/src/routes/stardust/address/outputs/nft/get.ts +++ b/api/src/routes/stardust/address/outputs/nft/get.ts @@ -24,5 +24,6 @@ export async function get(config: IConfiguration, request: IAddressDetailsReques return {}; } - return StardustTangleHelper.nftOutputDetailsByAddress(networkConfig, request.address); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.nftOutputDetailsByAddress(request.address); } diff --git a/api/src/routes/stardust/alias/foundries/get.ts b/api/src/routes/stardust/alias/foundries/get.ts index 548673d73..6af77f208 100644 --- a/api/src/routes/stardust/alias/foundries/get.ts +++ b/api/src/routes/stardust/alias/foundries/get.ts @@ -25,5 +25,6 @@ export async function get(config: IConfiguration, request: IFoundriesRequest): P return {}; } - return StardustTangleHelper.aliasFoundries(networkConfig, request.aliasAddress); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.aliasFoundries(request.aliasAddress); } diff --git a/api/src/routes/stardust/alias/get.ts b/api/src/routes/stardust/alias/get.ts index 41a2e6bc2..66ef60890 100644 --- a/api/src/routes/stardust/alias/get.ts +++ b/api/src/routes/stardust/alias/get.ts @@ -25,5 +25,6 @@ export async function get(config: IConfiguration, request: IAliasRequest): Promi return {}; } - return StardustTangleHelper.aliasDetails(networkConfig, request.aliasId); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.aliasDetails(request.aliasId); } diff --git a/api/src/routes/stardust/block/get.ts b/api/src/routes/stardust/block/get.ts index 49ecc7457..07cafcd21 100644 --- a/api/src/routes/stardust/block/get.ts +++ b/api/src/routes/stardust/block/get.ts @@ -25,5 +25,6 @@ export async function get(_: IConfiguration, request: IBlockRequest): Promise(`tangle-helper-${networkConfig.network}`); + return tangleHelper.block(request.blockId); } diff --git a/api/src/routes/stardust/block/metadata/get.ts b/api/src/routes/stardust/block/metadata/get.ts index efdcfeea0..fd0fbc9aa 100644 --- a/api/src/routes/stardust/block/metadata/get.ts +++ b/api/src/routes/stardust/block/metadata/get.ts @@ -25,5 +25,6 @@ export async function get(_: IConfiguration, request: IBlockRequest): Promise(`tangle-helper-${networkConfig.network}`); + return tangleHelper.blockDetails(request.blockId); } diff --git a/api/src/routes/stardust/foundry/get.ts b/api/src/routes/stardust/foundry/get.ts index d4d7836ed..92282fccf 100644 --- a/api/src/routes/stardust/foundry/get.ts +++ b/api/src/routes/stardust/foundry/get.ts @@ -25,5 +25,6 @@ export async function get(config: IConfiguration, request: IFoundryRequest): Pro return {}; } - return StardustTangleHelper.foundryDetails(networkConfig, request.foundryId); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.foundryDetails(request.foundryId); } diff --git a/api/src/routes/stardust/milestone/get.ts b/api/src/routes/stardust/milestone/get.ts index bc71bb4be..0e4684838 100644 --- a/api/src/routes/stardust/milestone/get.ts +++ b/api/src/routes/stardust/milestone/get.ts @@ -25,7 +25,8 @@ export async function get(config: IConfiguration, request: IMilestoneDetailsRequ return {}; } - const milestoneDetails = await StardustTangleHelper.milestoneDetailsByIndex(networkConfig, Number(request.milestoneIndex)); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + const milestoneDetails = await tangleHelper.milestoneDetailsByIndex(Number(request.milestoneIndex)); return milestoneDetails; } diff --git a/api/src/routes/stardust/nft/get.ts b/api/src/routes/stardust/nft/get.ts index 32285bde8..1b5eb7d01 100644 --- a/api/src/routes/stardust/nft/get.ts +++ b/api/src/routes/stardust/nft/get.ts @@ -25,5 +25,6 @@ export async function get(config: IConfiguration, request: INftDetailsRequest): return {}; } - return StardustTangleHelper.nftDetails(networkConfig, request.nftId); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.nftDetails(request.nftId); } diff --git a/api/src/routes/stardust/output/get.ts b/api/src/routes/stardust/output/get.ts index 720dea6f5..e8dc18b68 100644 --- a/api/src/routes/stardust/output/get.ts +++ b/api/src/routes/stardust/output/get.ts @@ -25,5 +25,6 @@ export async function get(config: IConfiguration, request: IOutputDetailsRequest return {}; } - return StardustTangleHelper.outputDetails(networkConfig, request.outputId); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.outputDetails(request.outputId); } diff --git a/api/src/routes/stardust/output/tagged/get.ts b/api/src/routes/stardust/output/tagged/get.ts index c96ad74d9..f602daa4b 100644 --- a/api/src/routes/stardust/output/tagged/get.ts +++ b/api/src/routes/stardust/output/tagged/get.ts @@ -29,11 +29,12 @@ export async function get(_: IConfiguration, request: ITaggedOutputsRequest): Pr } const tagHex = Converter.utf8ToHex(request.tag, true); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); if (request.outputType === "basic") { - return StardustTangleHelper.taggedBasicOutputs(networkConfig, tagHex, 10, request.cursor); + return tangleHelper.taggedBasicOutputs(tagHex, 10, request.cursor); } else if (request.outputType === "nft") { - return StardustTangleHelper.taggedNftOutputs(networkConfig, tagHex, 10, request.cursor); + return tangleHelper.taggedNftOutputs(tagHex, 10, request.cursor); } return { error: "Unsupported output type" }; diff --git a/api/src/routes/stardust/participation/events/get.ts b/api/src/routes/stardust/participation/events/get.ts index de54dfa68..40c0d2d8b 100644 --- a/api/src/routes/stardust/participation/events/get.ts +++ b/api/src/routes/stardust/participation/events/get.ts @@ -24,5 +24,6 @@ export async function get(config: IConfiguration, request: IParticipationEventRe return {}; } - return StardustTangleHelper.participationEventDetails(networkConfig, request.eventId); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.participationEventDetails(request.eventId); } diff --git a/api/src/routes/stardust/search.ts b/api/src/routes/stardust/search.ts index 44ead06d8..843bf11aa 100644 --- a/api/src/routes/stardust/search.ts +++ b/api/src/routes/stardust/search.ts @@ -25,5 +25,6 @@ export async function search(_: IConfiguration, request: ISearchRequest): Promis return {}; } - return StardustTangleHelper.search(networkConfig, request.query); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.search(request.query); } diff --git a/api/src/routes/stardust/transaction/get.ts b/api/src/routes/stardust/transaction/get.ts index d95dbbd4f..42f2b6c41 100644 --- a/api/src/routes/stardust/transaction/get.ts +++ b/api/src/routes/stardust/transaction/get.ts @@ -25,5 +25,6 @@ export async function get(config: IConfiguration, request: ITransactionDetailsRe return {}; } - return StardustTangleHelper.transactionIncludedBlock(networkConfig, request.transactionId); + const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + return tangleHelper.transactionIncludedBlock(request.transactionId); } diff --git a/api/src/utils/stardust/searchExecutor.ts b/api/src/utils/stardust/searchExecutor.ts index 499a48d52..f2c7ac136 100644 --- a/api/src/utils/stardust/searchExecutor.ts +++ b/api/src/utils/stardust/searchExecutor.ts @@ -1,6 +1,6 @@ -import { OutputResponse } from "@iota/sdk"; import { SearchQuery } from "./searchQueryBuilder"; import { StardustTangleHelper } from "./stardustTangleHelper"; +import { ServiceFactory } from "../../factories/serviceFactory"; import { ISearchResponse } from "../../models/api/stardust/ISearchResponse"; import { INetwork } from "../../models/db/INetwork"; @@ -8,30 +8,28 @@ import { INetwork } from "../../models/db/INetwork"; * Performs the search from a SearchQuery object on a Stardust network. */ export class SearchExecutor { - /** - * The network to search on. - */ - private readonly network: INetwork; - /** * The search query. */ private readonly query: SearchQuery; + private readonly tangleHelper: StardustTangleHelper; + constructor(network: INetwork, query: SearchQuery) { - this.network = network; this.query = query; + this.tangleHelper = ServiceFactory.get(`tangle-helper-${network.network}`); } public async run(): Promise { - const network = this.network; const searchQuery = this.query; const promises: Promise[] = []; let promisesResult: ISearchResponse | null = null; + if (searchQuery.did) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeData(searchQuery.aliasId, "aliasOutputId", network) + this.tangleHelper + .aliasDetails(searchQuery.aliasId) .then((aliasOutputs) => { if (aliasOutputs) { promisesResult = { @@ -53,7 +51,8 @@ export class SearchExecutor { if (searchQuery.milestoneIndex) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.milestoneDetailsByIndex(network, searchQuery.milestoneIndex) + this.tangleHelper + .milestoneDetailsByIndex(searchQuery.milestoneIndex) .then((milestoneDetails) => { if (milestoneDetails) { promisesResult = { @@ -74,7 +73,8 @@ export class SearchExecutor { if (searchQuery.milestoneId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.milestoneDetailsById(network, searchQuery.milestoneId) + this.tangleHelper + .milestoneDetailsById(searchQuery.milestoneId) .then((milestoneDetails) => { if (milestoneDetails) { promisesResult = { @@ -95,7 +95,8 @@ export class SearchExecutor { if (searchQuery.blockId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.block(network, searchQuery.blockId) + this.tangleHelper + .block(searchQuery.blockId) .then((blockResponse) => { if (blockResponse && !blockResponse.error) { promisesResult = { @@ -116,7 +117,8 @@ export class SearchExecutor { if (searchQuery.transactionId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.transactionIncludedBlock(network, searchQuery.transactionId) + this.tangleHelper + .transactionIncludedBlock(searchQuery.transactionId) .then((txDetailsResponse) => { if (txDetailsResponse.block && Object.keys(txDetailsResponse.block).length > 0) { promisesResult = { @@ -137,10 +139,11 @@ export class SearchExecutor { if (searchQuery.output) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeData(searchQuery.output, "getOutput", network) + this.tangleHelper + .outputDetails(searchQuery.output) .then((output) => { if (output) { - promisesResult = { output }; + promisesResult = { output: output.output }; resolve(); } else { reject(new Error("Output response not present")); @@ -156,7 +159,8 @@ export class SearchExecutor { if (searchQuery.aliasId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeData(searchQuery.aliasId, "aliasOutputId", network) + this.tangleHelper + .aliasDetails(searchQuery.aliasId) .then((aliasOutputs) => { if (aliasOutputs) { promisesResult = { @@ -177,7 +181,8 @@ export class SearchExecutor { if (searchQuery.nftId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeData(searchQuery.nftId, "nftOutputId", network) + this.tangleHelper + .nftDetails(searchQuery.nftId) .then((nftOutputs) => { if (nftOutputs) { promisesResult = { @@ -198,7 +203,8 @@ export class SearchExecutor { if (searchQuery.foundryId) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.tryFetchNodeData(searchQuery.foundryId, "foundryOutputId", network) + this.tangleHelper + .foundryDetails(searchQuery.foundryId) .then((foundryOutput) => { if (foundryOutput) { promisesResult = { @@ -219,7 +225,8 @@ export class SearchExecutor { if (searchQuery.tag) { promises.push( new Promise((resolve, reject) => { - StardustTangleHelper.taggedOutputs(network, searchQuery.tag) + this.tangleHelper + .taggedOutputs(searchQuery.tag) .then((response) => { if (!response.basicOutputs.error || !response.nftOutputs.error) { promisesResult = { diff --git a/api/src/utils/stardust/stardustTangleHelper.ts b/api/src/utils/stardust/stardustTangleHelper.ts index 4e05326e4..3ad739b9e 100644 --- a/api/src/utils/stardust/stardustTangleHelper.ts +++ b/api/src/utils/stardust/stardustTangleHelper.ts @@ -1,19 +1,5 @@ /* eslint-disable no-warning-comments */ -import { - __ClientMethods__, - OutputResponse, - Client, - IBlockMetadata, - MilestonePayload, - IOutputsResponse, - HexEncodedString, - Block, - Utils, - QueryParameter, - NftQueryParameter, - AliasQueryParameter, - FoundryQueryParameter, -} from "@iota/sdk"; +import { OutputResponse, Client, IOutputsResponse, HexEncodedString, Utils, NftQueryParameter } from "@iota/sdk"; import { SearchExecutor } from "./searchExecutor"; import { SearchQueryBuilder, SearchQuery } from "./searchQueryBuilder"; import { addressBalance, blockIdFromMilestonePayload } from "./utils"; @@ -41,22 +27,32 @@ import { INetwork } from "../../models/db/INetwork"; import { NodeInfoService } from "../../services/stardust/nodeInfoService"; import { HexHelper } from "../hexHelper"; -type NameType = T extends { name: infer U } ? U : never; -type ExtractedMethodNames = NameType<__ClientMethods__>; - /** * Helper functions for use with tangle. */ export class StardustTangleHelper { + /** + * The network in context. + */ + private readonly network: INetwork; + + /** + * The client to use for requests. + */ + private readonly client: Client; + + constructor(network: INetwork) { + this.network = network; + this.client = ServiceFactory.get(`client-${network.network}`); + } + /** * Get the address details from iotajs. - * @param network The network in context. * @param addressBech32 The address to get the details for in bech32 format. * @returns The address details. */ - public static async addressDetails(network: INetwork, addressBech32: string): Promise { - const { bechHrp } = network; - const client = ServiceFactory.get(`client-${network.network}`); + public async addressDetails(addressBech32: string): Promise { + const { bechHrp } = this.network; const searchQuery: SearchQuery = new SearchQueryBuilder(addressBech32, bechHrp).build(); if (!searchQuery.address) { @@ -65,7 +61,7 @@ export class StardustTangleHelper { try { // Using ported balance from iota.js until it is added to iota-sdk https://github.com/iotaledger/iota-sdk/issues/604 - const addressBalanceDetails = await addressBalance(client, searchQuery.address.bech32); + const addressBalanceDetails = await addressBalance(this.client, searchQuery.address.bech32); if (addressBalanceDetails) { const addressDetails = { @@ -82,19 +78,18 @@ export class StardustTangleHelper { /** * Get a block. - * @param network The network to find the items on. * @param blockId The block id to get the details. * @returns The block response. */ - public static async block(network: INetwork, blockId: string): Promise { + public async block(blockId: string): Promise { blockId = HexHelper.addPrefix(blockId); - const block = await this.tryFetchNodeData(blockId, "getBlock", network); + try { + const block = await this.client.getBlock(blockId); - if (!block) { - return { error: `Couldn't find block with id ${blockId}` }; - } + if (!block) { + return { error: `Couldn't find block with id ${blockId}` }; + } - try { if (block && Object.keys(block).length > 0) { return { block, @@ -108,36 +103,38 @@ export class StardustTangleHelper { /** * Get the block details. - * @param network The network to find the items on. * @param blockId The block id to get the details. * @returns The item details. */ - public static async blockDetails(network: INetwork, blockId: string): Promise { - blockId = HexHelper.addPrefix(blockId); - const metadata = await this.tryFetchNodeData(blockId, "getBlockMetadata", network); + public async blockDetails(blockId: string): Promise { + try { + blockId = HexHelper.addPrefix(blockId); + const metadata = await this.client.getBlockMetadata(blockId); - if (metadata) { - return { - metadata, - }; + if (metadata) { + return { + metadata, + }; + } + } catch (e) { + logger.error(`Failed fetching block metadata with block id ${blockId}. Cause: ${e}`); + return { error: "Block metadata fetch failed." }; } } /** * Get the transaction included block. - * @param network The network to find the items on. * @param transactionId The transaction id to get the details. * @returns The item details. */ - public static async transactionIncludedBlock(network: INetwork, transactionId: string): Promise { + public async transactionIncludedBlock(transactionId: string): Promise { transactionId = HexHelper.addPrefix(transactionId); - const block = await this.tryFetchNodeData(transactionId, "getIncludedBlock", network); - - if (!block) { - return { error: `Couldn't find block from transaction id ${transactionId}` }; - } - try { + const block = await this.client.getIncludedBlock(transactionId); + + if (!block) { + return { error: `Couldn't find block from transaction id ${transactionId}` }; + } if (block && Object.keys(block).length > 0) { return { block, @@ -145,33 +142,36 @@ export class StardustTangleHelper { } } catch (e) { logger.error(`Failed fetching block with transaction id ${transactionId}. Cause: ${e}`); + return { error: "Block fetch failed." }; } } /** * Get the output details. - * @param network The network to find the items on. * @param outputId The output id to get the details. * @returns The item details. */ - public static async outputDetails(network: INetwork, outputId: string): Promise { - const outputResponse = await this.tryFetchNodeData(outputId, "getOutput", network); - - return outputResponse ? { output: outputResponse } : { message: "Output not found" }; + public async outputDetails(outputId: string): Promise { + try { + const outputResponse = await this.client.getOutput(outputId); + return { output: outputResponse }; + } catch (e) { + logger.error(`Failed fetching output with output id ${outputId}. Cause: ${e}`); + return { error: "Output not found" }; + } } /** * Get the outputs details. - * @param network The network to find the items on. * @param outputIds The output ids to get the details. * @returns The item details. */ - public static async outputsDetails(network: INetwork, outputIds: string[]): Promise { + public async outputsDetails(outputIds: string[]): Promise { const promises: Promise[] = []; const outputResponses: OutputResponse[] = []; for (const outputId of outputIds) { - const promise = this.outputDetails(network, outputId); + const promise = this.outputDetails(outputId); promises.push(promise); } try { @@ -191,72 +191,77 @@ export class StardustTangleHelper { /** * Get the milestone details by milestone id. - * @param network The network to find the items on. * @param milestoneId The milestone id to get the details. * @returns The milestone details. */ - public static async milestoneDetailsById(network: INetwork, milestoneId: string): Promise { - const milestonePayload = await this.tryFetchNodeData(milestoneId, "getMilestoneById", network); - - if (milestonePayload) { - const nodeInfoService = ServiceFactory.get(`node-info-${network.network}`); - const protocolVersion = nodeInfoService.getNodeInfo().protocolVersion; - const blockId = blockIdFromMilestonePayload(protocolVersion, milestonePayload); - - return { - blockId, - milestoneId, - milestone: milestonePayload, - }; + public async milestoneDetailsById(milestoneId: string): Promise { + try { + const milestonePayload = await this.client.getMilestoneById(milestoneId); + + if (milestonePayload) { + const nodeInfoService = ServiceFactory.get(`node-info-${this.network.network}`); + const protocolVersion = nodeInfoService.getNodeInfo().protocolVersion; + const blockId = blockIdFromMilestonePayload(protocolVersion, milestonePayload); + + return { + blockId, + milestoneId, + milestone: milestonePayload, + }; + } + } catch (e) { + logger.error(`Fetching milestone details failed. Cause: ${e}`); } } /** * Get the milestone details by index. - * @param network The network to find the items on. * @param milestoneIndex The milestone index to get the details. * @returns The milestone details. */ - public static async milestoneDetailsByIndex(network: INetwork, milestoneIndex: number): Promise { - const milestonePayload = await this.tryFetchNodeData(milestoneIndex, "getMilestoneByIndex", network); + public async milestoneDetailsByIndex(milestoneIndex: number): Promise { + try { + const milestonePayload = await this.client.getMilestoneByIndex(milestoneIndex); - if (milestonePayload) { - const nodeInfoService = ServiceFactory.get(`node-info-${network.network}`); - const protocolVersion = nodeInfoService.getNodeInfo().protocolVersion; + if (milestonePayload) { + const nodeInfoService = ServiceFactory.get(`node-info-${this.network.network}`); + const protocolVersion = nodeInfoService.getNodeInfo().protocolVersion; - const blockId = blockIdFromMilestonePayload(protocolVersion, milestonePayload); - const milestoneId = Utils.milestoneId(milestonePayload); + const blockId = blockIdFromMilestonePayload(protocolVersion, milestonePayload); + const milestoneId = Utils.milestoneId(milestonePayload); - return { - blockId, - milestoneId, - milestone: milestonePayload, - }; + return { + blockId, + milestoneId, + milestone: milestonePayload, + }; + } + } catch (e) { + logger.error(`Fetching milestone details failed. Cause: ${e}`); } } /** * Get the relevant basic output details for an address. - * @param network The network to find the items on. * @param addressBech32 The address in bech32 format. * @returns The basic output details. */ - public static async basicOutputDetailsByAddress(network: INetwork, addressBech32: string): Promise { + public async basicOutputDetailsByAddress(addressBech32: string): Promise { let cursor: string | undefined; let outputIds: string[] = []; do { - const outputIdsResponse = await this.tryFetchNodeData( - [{ address: addressBech32 }, { cursor: cursor ?? "" }], - "basicOutputIds", - network, - ); - - outputIds = outputIds.concat(outputIdsResponse.items); - cursor = outputIdsResponse.cursor; + try { + const outputIdsResponse = await this.client.basicOutputIds([{ address: addressBech32 }, { cursor: cursor ?? "" }]); + + outputIds = outputIds.concat(outputIdsResponse.items); + cursor = outputIdsResponse.cursor; + } catch (e) { + logger.error(`Fetching basic output ids failed. Cause: ${e}`); + } } while (cursor); - const outputResponses = await this.outputsDetails(network, outputIds); + const outputResponses = await this.outputsDetails(outputIds); return { outputs: outputResponses, @@ -265,26 +270,25 @@ export class StardustTangleHelper { /** * Get the relevant alias output details for an address. - * @param network The network to find the items on. * @param addressBech32 The address in bech32 format. * @returns The alias output details. */ - public static async aliasOutputDetailsByAddress(network: INetwork, addressBech32: string): Promise { + public async aliasOutputDetailsByAddress(addressBech32: string): Promise { let cursor: string | undefined; let outputIds: string[] = []; do { - const outputIdsResponse = await this.tryFetchNodeData( - [{ stateController: addressBech32 }, { cursor: cursor ?? "" }], - "aliasOutputIds", - network, - ); - - outputIds = outputIds.concat(outputIdsResponse.items); - cursor = outputIdsResponse.cursor; + try { + const outputIdsResponse = await this.client.aliasOutputIds([{ stateController: addressBech32 }, { cursor: cursor ?? "" }]); + + outputIds = outputIds.concat(outputIdsResponse.items); + cursor = outputIdsResponse.cursor; + } catch (e) { + logger.error(`Fetching alias output ids failed. Cause: ${e}`); + } } while (cursor); - const outputResponses = await this.outputsDetails(network, outputIds); + const outputResponses = await this.outputsDetails(outputIds); return { outputs: outputResponses, @@ -293,26 +297,25 @@ export class StardustTangleHelper { /** * Get the relevant nft output details for an address. - * @param network The network to find the items on. * @param addressBech32 The address in bech32 format. * @returns The alias output details. */ - public static async nftOutputDetailsByAddress(network: INetwork, addressBech32: string): Promise { + public async nftOutputDetailsByAddress(addressBech32: string): Promise { let cursor: string | undefined; let outputIds: string[] = []; do { - const outputIdsResponse = await this.tryFetchNodeData( - [{ address: addressBech32 }, { cursor: cursor ?? "" }], - "nftOutputIds", - network, - ); - - outputIds = outputIds.concat(outputIdsResponse.items); - cursor = outputIdsResponse.cursor; + try { + const outputIdsResponse = await this.client.nftOutputIds([{ address: addressBech32 }, { cursor: cursor ?? "" }]); + + outputIds = outputIds.concat(outputIdsResponse.items); + cursor = outputIdsResponse.cursor; + } catch (e) { + logger.error(`Fetching nft output ids failed. Cause: ${e}`); + } } while (cursor); - const outputResponses = await this.outputsDetails(network, outputIds); + const outputResponses = await this.outputsDetails(outputIds); return { outputs: outputResponses, }; @@ -320,35 +323,31 @@ export class StardustTangleHelper { /** * Get the alias details. - * @param network The network to find the items on. * @param aliasId The aliasId to get the details for. * @returns The alias details. */ - public static async aliasDetails(network: INetwork, aliasId: string): Promise { - const aliasOutputId = await this.tryFetchNodeData(aliasId, "aliasOutputId", network); + public async aliasDetails(aliasId: string): Promise { + try { + const aliasOutputId = await this.client.aliasOutputId(aliasId); - if (aliasOutputId) { - const outputResponse = await this.outputDetails(network, aliasOutputId); + if (aliasOutputId) { + const outputResponse = await this.outputDetails(aliasOutputId); - return outputResponse.error ? { error: outputResponse.error } : { aliasDetails: outputResponse.output }; + return outputResponse.error ? { error: outputResponse.error } : { aliasDetails: outputResponse.output }; + } + } catch { + return { message: "Alias output not found" }; } - - return { message: "Alias output not found" }; } /** * Get controlled Foundry output id by controller Alias address - * @param network The network to find the items on. * @param aliasAddress The alias address to get the controlled Foundries for. * @returns The foundry outputs. */ - public static async aliasFoundries(network: INetwork, aliasAddress: string): Promise { + public async aliasFoundries(aliasAddress: string): Promise { try { - const response = await this.tryFetchNodeData( - [{ aliasAddress }], - "foundryOutputIds", - network, - ); + const response = await this.client.foundryOutputIds([{ aliasAddress }]); if (response) { return { @@ -362,34 +361,33 @@ export class StardustTangleHelper { /** * Get the foundry details. - * @param network The network to find the items on. * @param foundryId The foundryId to get the details for. * @returns The foundry details. */ - public static async foundryDetails(network: INetwork, foundryId: string): Promise { - const foundryOutputId = await this.tryFetchNodeData(foundryId, "foundryOutputId", network); - - if (foundryOutputId) { - const outputResponse = await this.outputDetails(network, foundryOutputId); + public async foundryDetails(foundryId: string): Promise { + try { + const foundryOutputId = await this.client.foundryOutputId(foundryId); - return outputResponse.error ? { error: outputResponse.error } : { foundryDetails: outputResponse.output }; - } + if (foundryOutputId) { + const outputResponse = await this.outputDetails(foundryOutputId); - return { message: "Foundry output not found" }; + return outputResponse.error ? { error: outputResponse.error } : { foundryDetails: outputResponse.output }; + } + return { message: "Foundry output not found" }; + } catch {} } /** * Get the nft details by nftId. - * @param network The network to find the items on. * @param nftId The nftId to get the details for. * @returns The nft details. */ - public static async nftDetails(network: INetwork, nftId: string): Promise { + public async nftDetails(nftId: string): Promise { try { - const nftOutputId = await this.tryFetchNodeData(nftId, "nftOutputId", network); + const nftOutputId = await this.client.nftOutputId(nftId); if (nftOutputId) { - const outputResponse = await this.outputDetails(network, nftOutputId); + const outputResponse = await this.outputDetails(nftOutputId); return outputResponse.error ? { error: outputResponse.error } : { nftDetails: outputResponse.output }; } @@ -400,25 +398,19 @@ export class StardustTangleHelper { /** * Get the basic output Ids with specific tag feature. - * @param network The network to find the items on. * @param encodedTag The tag hex. * @param pageSize The page size. * @param cursor The cursor for pagination. * @returns The basic outputs response. */ - public static async taggedBasicOutputs( - network: INetwork, + public async taggedBasicOutputs( encodedTag: HexEncodedString, pageSize: number, cursor?: string, ): Promise { try { const params: NftQueryParameter[] = [{ tag: encodedTag }, { pageSize }, { cursor: cursor ?? "" }]; - const basicOutputIdsResponse: IOutputsResponse = await this.tryFetchNodeData( - params, - "basicOutputIds", - network, - ); + const basicOutputIdsResponse: IOutputsResponse = await this.client.basicOutputIds(params); if (basicOutputIdsResponse?.items.length > 0) { return { outputs: basicOutputIdsResponse }; @@ -430,25 +422,19 @@ export class StardustTangleHelper { /** * Get the nft output Ids with specific tag feature. - * @param network The network to find the items on. * @param encodedTag The tag hex. * @param pageSize The page size. * @param cursor The cursor for pagination. * @returns The nft outputs response. */ - public static async taggedNftOutputs( - network: INetwork, + public async taggedNftOutputs( encodedTag: HexEncodedString, pageSize: number, cursor?: string, ): Promise { try { const params: NftQueryParameter[] = [{ tag: encodedTag }, { pageSize }, { cursor: cursor ?? "" }]; - const nftOutputIdsResponse: IOutputsResponse = await this.tryFetchNodeData( - params, - "nftOutputIds", - network, - ); + const nftOutputIdsResponse: IOutputsResponse = await this.client.nftOutputIds(params); if (nftOutputIdsResponse?.items.length > 0) { return { outputs: nftOutputIdsResponse }; @@ -460,13 +446,12 @@ export class StardustTangleHelper { /** * Get the output Ids (basic/nft) with specific tag feature. - * @param network The network to find the items on. * @param tag The tag hex. * @returns . */ - public static async taggedOutputs(network: INetwork, tag: HexEncodedString): Promise { - const basicOutputs = await this.taggedBasicOutputs(network, tag, 10); - const nftOutputs = await this.taggedNftOutputs(network, tag, 10); + public async taggedOutputs(tag: HexEncodedString): Promise { + const basicOutputs = await this.taggedBasicOutputs(tag, 10); + const nftOutputs = await this.taggedNftOutputs(tag, 10); return { basicOutputs, @@ -476,16 +461,15 @@ export class StardustTangleHelper { /** * Get the relevant nft output details for an address. - * @param network The network to find the items on. * @param eventId The id of the event. * @returns The participation event details. */ - public static async participationEventDetails(network: INetwork, eventId: string): Promise { + public async participationEventDetails(eventId: string): Promise { const basePluginPath: string = "api/participation/v1/"; const method = "GET"; const methodPath: string = `events/${eventId}`; - const info = await this.nodePluginFetch(network, basePluginPath, method, methodPath); - const status = await this.nodePluginFetch(network, basePluginPath, method, `${methodPath}/status`); + const info = await this.nodePluginFetch(basePluginPath, method, methodPath); + const status = await this.nodePluginFetch(basePluginPath, method, `${methodPath}/status`); return { info, @@ -495,36 +479,15 @@ export class StardustTangleHelper { /** * Find item on the stardust network. - * @param network The network config. * @param query The query to use for finding items. * @returns The item found. */ - public static async search(network: INetwork, query: string): Promise { - return new SearchExecutor(network, new SearchQueryBuilder(query, network.bechHrp).build()).run(); - } - - /** - * Generic helper function to try fetching from node client. - * On failure (or not present), SDK will try to fetch from permanode (if configured). - * @param args The argument(s) to pass to the fetch calls. - * @param methodName The function to call on the client. - * @param network The network config in context. - * @returns The results or null if call(s) failed. - */ - public static async tryFetchNodeData(args: A, methodName: ExtractedMethodNames, network: INetwork): Promise | null { - const client = ServiceFactory.get(`client-${network.network}`); - - try { - const result: Promise = client[methodName](args); - return await result; - } catch {} - - return null; + public async search(query: string): Promise { + return new SearchExecutor(this.network, new SearchQueryBuilder(query, this.network.bechHrp).build()).run(); } /** * Extension method which provides request methods for plugins. - * @param network The network config in context. * @param basePluginPath The base path for the plugin eg indexer/v1/ . * @param method The http method. * @param methodPath The path for the plugin request. @@ -532,15 +495,14 @@ export class StardustTangleHelper { * @param request The request object. * @returns The response object. */ - private static async nodePluginFetch( - network: INetwork, + private async nodePluginFetch( basePluginPath: string, method: "GET" | "POST", methodPath: string, queryParams?: string[], request?: string, ): Promise | null { - const client = ServiceFactory.get(`client-${network.network}`); + const client = this.client; try { const response: S = (await client.callPluginRoute(basePluginPath, method, methodPath, queryParams, request)) as S; From 6cb41d32e79e8e198becfc8829c8945255e79bb6 Mon Sep 17 00:00:00 2001 From: JCNoguera Date: Fri, 19 Jan 2024 16:52:30 +0100 Subject: [PATCH 5/6] chore: rename `stardustTangleHelper` to `stardustApiService` --- api/src/initServices.ts | 6 +++--- api/src/routes/stardust/address/balance/get.ts | 6 +++--- api/src/routes/stardust/address/outputs/alias/get.ts | 6 +++--- api/src/routes/stardust/address/outputs/basic/get.ts | 6 +++--- api/src/routes/stardust/address/outputs/nft/get.ts | 6 +++--- api/src/routes/stardust/alias/foundries/get.ts | 6 +++--- api/src/routes/stardust/alias/get.ts | 6 +++--- api/src/routes/stardust/block/get.ts | 6 +++--- api/src/routes/stardust/block/metadata/get.ts | 6 +++--- api/src/routes/stardust/foundry/get.ts | 6 +++--- api/src/routes/stardust/milestone/get.ts | 6 +++--- api/src/routes/stardust/nft/get.ts | 6 +++--- api/src/routes/stardust/output/get.ts | 6 +++--- api/src/routes/stardust/output/tagged/get.ts | 8 ++++---- api/src/routes/stardust/participation/events/get.ts | 6 +++--- api/src/routes/stardust/search.ts | 6 +++--- api/src/routes/stardust/transaction/get.ts | 6 +++--- .../stardust/stardustApiService.ts} | 12 ++++++------ api/src/utils/stardust/searchExecutor.ts | 6 +++--- 19 files changed, 61 insertions(+), 61 deletions(-) rename api/src/{utils/stardust/stardustTangleHelper.ts => services/stardust/stardustApiService.ts} (97%) diff --git a/api/src/initServices.ts b/api/src/initServices.ts index f78c07bc8..921371b39 100644 --- a/api/src/initServices.ts +++ b/api/src/initServices.ts @@ -24,8 +24,8 @@ import { ChronicleService } from "./services/stardust/chronicleService"; import { StardustFeed } from "./services/stardust/feed/stardustFeed"; import { InfluxDBService } from "./services/stardust/influx/influxDbService"; import { NodeInfoService } from "./services/stardust/nodeInfoService"; +import { StardustApiService } from "./services/stardust/stardustApiService"; import { StardustStatsService } from "./services/stardust/stats/stardustStatsService"; -import { StardustTangleHelper } from "./utils/stardust/stardustTangleHelper"; const CURRENCY_UPDATE_INTERVAL_MS = 5 * 60000; @@ -158,8 +158,8 @@ function initStardustServices(networkConfig: INetwork): void { const stardustClient = new StardustClient(stardustClientParams); ServiceFactory.register(`client-${networkConfig.network}`, () => stardustClient); - const tangleHelper = new StardustTangleHelper(networkConfig); - ServiceFactory.register(`tangle-helper-${networkConfig.network}`, () => tangleHelper); + const stardustApiService = new StardustApiService(networkConfig); + ServiceFactory.register(`api-service-${networkConfig.network}`, () => stardustApiService); // eslint-disable-next-line no-void void NodeInfoService.build(networkConfig).then((nodeInfoService) => { diff --git a/api/src/routes/stardust/address/balance/get.ts b/api/src/routes/stardust/address/balance/get.ts index 67eccf23b..74110051e 100644 --- a/api/src/routes/stardust/address/balance/get.ts +++ b/api/src/routes/stardust/address/balance/get.ts @@ -4,7 +4,7 @@ import IAddressDetailsWithBalance from "../../../../models/api/stardust/IAddress import { IConfiguration } from "../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../utils/validationHelper"; /** @@ -24,6 +24,6 @@ export async function get(config: IConfiguration, request: IAddressBalanceReques return undefined; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.addressDetails(request.address); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.addressDetails(request.address); } diff --git a/api/src/routes/stardust/address/outputs/alias/get.ts b/api/src/routes/stardust/address/outputs/alias/get.ts index f08664df0..aeb9aa652 100644 --- a/api/src/routes/stardust/address/outputs/alias/get.ts +++ b/api/src/routes/stardust/address/outputs/alias/get.ts @@ -4,7 +4,7 @@ import { IAddressDetailsResponse } from "../../../../../models/api/stardust/IAdd import { IConfiguration } from "../../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../../utils/validationHelper"; /** @@ -24,6 +24,6 @@ export async function get(config: IConfiguration, request: IAddressDetailsReques return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.aliasOutputDetailsByAddress(request.address); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.aliasOutputDetailsByAddress(request.address); } diff --git a/api/src/routes/stardust/address/outputs/basic/get.ts b/api/src/routes/stardust/address/outputs/basic/get.ts index 94fdc6365..69565d796 100644 --- a/api/src/routes/stardust/address/outputs/basic/get.ts +++ b/api/src/routes/stardust/address/outputs/basic/get.ts @@ -4,7 +4,7 @@ import { IAddressDetailsResponse } from "../../../../../models/api/stardust/IAdd import { IConfiguration } from "../../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../../utils/validationHelper"; /** @@ -24,6 +24,6 @@ export async function get(config: IConfiguration, request: IAddressDetailsReques return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.basicOutputDetailsByAddress(request.address); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.basicOutputDetailsByAddress(request.address); } diff --git a/api/src/routes/stardust/address/outputs/nft/get.ts b/api/src/routes/stardust/address/outputs/nft/get.ts index 61c6fb080..f738f656d 100644 --- a/api/src/routes/stardust/address/outputs/nft/get.ts +++ b/api/src/routes/stardust/address/outputs/nft/get.ts @@ -4,7 +4,7 @@ import { IAddressDetailsResponse } from "../../../../../models/api/stardust/IAdd import { IConfiguration } from "../../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../../utils/validationHelper"; /** @@ -24,6 +24,6 @@ export async function get(config: IConfiguration, request: IAddressDetailsReques return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.nftOutputDetailsByAddress(request.address); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.nftOutputDetailsByAddress(request.address); } diff --git a/api/src/routes/stardust/alias/foundries/get.ts b/api/src/routes/stardust/alias/foundries/get.ts index 6af77f208..3417d25d0 100644 --- a/api/src/routes/stardust/alias/foundries/get.ts +++ b/api/src/routes/stardust/alias/foundries/get.ts @@ -4,7 +4,7 @@ import { IFoundriesResponse } from "../../../../models/api/stardust/foundry/IFou import { IConfiguration } from "../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(config: IConfiguration, request: IFoundriesRequest): P return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.aliasFoundries(request.aliasAddress); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.aliasFoundries(request.aliasAddress); } diff --git a/api/src/routes/stardust/alias/get.ts b/api/src/routes/stardust/alias/get.ts index 66ef60890..f2ab84a87 100644 --- a/api/src/routes/stardust/alias/get.ts +++ b/api/src/routes/stardust/alias/get.ts @@ -4,7 +4,7 @@ import { IAliasResponse } from "../../../models/api/stardust/IAliasResponse"; import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(config: IConfiguration, request: IAliasRequest): Promi return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.aliasDetails(request.aliasId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.aliasDetails(request.aliasId); } diff --git a/api/src/routes/stardust/block/get.ts b/api/src/routes/stardust/block/get.ts index 07cafcd21..d5b912976 100644 --- a/api/src/routes/stardust/block/get.ts +++ b/api/src/routes/stardust/block/get.ts @@ -4,7 +4,7 @@ import { IBlockResponse } from "../../../models/api/stardust/IBlockResponse"; import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(_: IConfiguration, request: IBlockRequest): Promise(`tangle-helper-${networkConfig.network}`); - return tangleHelper.block(request.blockId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.block(request.blockId); } diff --git a/api/src/routes/stardust/block/metadata/get.ts b/api/src/routes/stardust/block/metadata/get.ts index fd0fbc9aa..6efb937e6 100644 --- a/api/src/routes/stardust/block/metadata/get.ts +++ b/api/src/routes/stardust/block/metadata/get.ts @@ -4,7 +4,7 @@ import { IBlockRequest } from "../../../../models/api/stardust/IBlockRequest"; import { IConfiguration } from "../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(_: IConfiguration, request: IBlockRequest): Promise(`tangle-helper-${networkConfig.network}`); - return tangleHelper.blockDetails(request.blockId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.blockDetails(request.blockId); } diff --git a/api/src/routes/stardust/foundry/get.ts b/api/src/routes/stardust/foundry/get.ts index 92282fccf..e5233dd83 100644 --- a/api/src/routes/stardust/foundry/get.ts +++ b/api/src/routes/stardust/foundry/get.ts @@ -4,7 +4,7 @@ import { IFoundryResponse } from "../../../models/api/stardust/foundry/IFoundryR import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(config: IConfiguration, request: IFoundryRequest): Pro return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.foundryDetails(request.foundryId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.foundryDetails(request.foundryId); } diff --git a/api/src/routes/stardust/milestone/get.ts b/api/src/routes/stardust/milestone/get.ts index 0e4684838..9d3c52992 100644 --- a/api/src/routes/stardust/milestone/get.ts +++ b/api/src/routes/stardust/milestone/get.ts @@ -4,7 +4,7 @@ import { IMilestoneDetailsResponse } from "../../../models/api/stardust/mileston import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,8 +25,8 @@ export async function get(config: IConfiguration, request: IMilestoneDetailsRequ return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - const milestoneDetails = await tangleHelper.milestoneDetailsByIndex(Number(request.milestoneIndex)); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + const milestoneDetails = await stardustApiService.milestoneDetailsByIndex(Number(request.milestoneIndex)); return milestoneDetails; } diff --git a/api/src/routes/stardust/nft/get.ts b/api/src/routes/stardust/nft/get.ts index 1b5eb7d01..88b04bc3a 100644 --- a/api/src/routes/stardust/nft/get.ts +++ b/api/src/routes/stardust/nft/get.ts @@ -4,7 +4,7 @@ import { INftDetailsResponse } from "../../../models/api/stardust/nft/INftDetail import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(config: IConfiguration, request: INftDetailsRequest): return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.nftDetails(request.nftId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.nftDetails(request.nftId); } diff --git a/api/src/routes/stardust/output/get.ts b/api/src/routes/stardust/output/get.ts index e8dc18b68..413d87c20 100644 --- a/api/src/routes/stardust/output/get.ts +++ b/api/src/routes/stardust/output/get.ts @@ -4,7 +4,7 @@ import { IOutputDetailsResponse } from "../../../models/api/stardust/IOutputDeta import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(config: IConfiguration, request: IOutputDetailsRequest return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.outputDetails(request.outputId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.outputDetails(request.outputId); } diff --git a/api/src/routes/stardust/output/tagged/get.ts b/api/src/routes/stardust/output/tagged/get.ts index f602daa4b..cf96cc4f3 100644 --- a/api/src/routes/stardust/output/tagged/get.ts +++ b/api/src/routes/stardust/output/tagged/get.ts @@ -5,8 +5,8 @@ import { INftOutputsResponse } from "../../../../models/api/stardust/nft/INftOut import { IConfiguration } from "../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../services/networkService"; +import { StardustApiService } from "../../../../services/stardust/stardustApiService"; import { Converter } from "../../../../utils/convertUtils"; -import { StardustTangleHelper } from "../../../../utils/stardust/stardustTangleHelper"; import { ValidationHelper } from "../../../../utils/validationHelper"; /** @@ -29,12 +29,12 @@ export async function get(_: IConfiguration, request: ITaggedOutputsRequest): Pr } const tagHex = Converter.utf8ToHex(request.tag, true); - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); if (request.outputType === "basic") { - return tangleHelper.taggedBasicOutputs(tagHex, 10, request.cursor); + return stardustApiService.taggedBasicOutputs(tagHex, 10, request.cursor); } else if (request.outputType === "nft") { - return tangleHelper.taggedNftOutputs(tagHex, 10, request.cursor); + return stardustApiService.taggedNftOutputs(tagHex, 10, request.cursor); } return { error: "Unsupported output type" }; diff --git a/api/src/routes/stardust/participation/events/get.ts b/api/src/routes/stardust/participation/events/get.ts index 40c0d2d8b..8de22a1bb 100644 --- a/api/src/routes/stardust/participation/events/get.ts +++ b/api/src/routes/stardust/participation/events/get.ts @@ -4,7 +4,7 @@ import { IParticipationEventResponse } from "../../../../models/api/stardust/par import { IConfiguration } from "../../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../../models/db/protocolVersion"; import { NetworkService } from "../../../../services/networkService"; -import { StardustTangleHelper } from "../../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../../utils/validationHelper"; /** @@ -24,6 +24,6 @@ export async function get(config: IConfiguration, request: IParticipationEventRe return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.participationEventDetails(request.eventId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.participationEventDetails(request.eventId); } diff --git a/api/src/routes/stardust/search.ts b/api/src/routes/stardust/search.ts index 843bf11aa..e19a88113 100644 --- a/api/src/routes/stardust/search.ts +++ b/api/src/routes/stardust/search.ts @@ -4,7 +4,7 @@ import { ISearchResponse } from "../../models/api/stardust/ISearchResponse"; import { IConfiguration } from "../../models/configuration/IConfiguration"; import { STARDUST } from "../../models/db/protocolVersion"; import { NetworkService } from "../../services/networkService"; -import { StardustTangleHelper } from "../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function search(_: IConfiguration, request: ISearchRequest): Promis return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.search(request.query); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.search(request.query); } diff --git a/api/src/routes/stardust/transaction/get.ts b/api/src/routes/stardust/transaction/get.ts index 42f2b6c41..a559badeb 100644 --- a/api/src/routes/stardust/transaction/get.ts +++ b/api/src/routes/stardust/transaction/get.ts @@ -4,7 +4,7 @@ import { ITransactionDetailsResponse } from "../../../models/api/stardust/ITrans import { IConfiguration } from "../../../models/configuration/IConfiguration"; import { STARDUST } from "../../../models/db/protocolVersion"; import { NetworkService } from "../../../services/networkService"; -import { StardustTangleHelper } from "../../../utils/stardust/stardustTangleHelper"; +import { StardustApiService } from "../../../services/stardust/stardustApiService"; import { ValidationHelper } from "../../../utils/validationHelper"; /** @@ -25,6 +25,6 @@ export async function get(config: IConfiguration, request: ITransactionDetailsRe return {}; } - const tangleHelper = ServiceFactory.get(`tangle-helper-${networkConfig.network}`); - return tangleHelper.transactionIncludedBlock(request.transactionId); + const stardustApiService = ServiceFactory.get(`api-service-${networkConfig.network}`); + return stardustApiService.transactionIncludedBlock(request.transactionId); } diff --git a/api/src/utils/stardust/stardustTangleHelper.ts b/api/src/services/stardust/stardustApiService.ts similarity index 97% rename from api/src/utils/stardust/stardustTangleHelper.ts rename to api/src/services/stardust/stardustApiService.ts index 3ad739b9e..0295e98b0 100644 --- a/api/src/utils/stardust/stardustTangleHelper.ts +++ b/api/src/services/stardust/stardustApiService.ts @@ -1,8 +1,6 @@ /* eslint-disable no-warning-comments */ import { OutputResponse, Client, IOutputsResponse, HexEncodedString, Utils, NftQueryParameter } from "@iota/sdk"; -import { SearchExecutor } from "./searchExecutor"; -import { SearchQueryBuilder, SearchQuery } from "./searchQueryBuilder"; -import { addressBalance, blockIdFromMilestonePayload } from "./utils"; +import { NodeInfoService } from "./nodeInfoService"; import { ServiceFactory } from "../../factories/serviceFactory"; import logger from "../../logger"; import { IBasicOutputsResponse } from "../../models/api/stardust/basic/IBasicOutputsResponse"; @@ -24,13 +22,15 @@ import { IParticipationEventInfo } from "../../models/api/stardust/participation import { IParticipationEventResponse } from "../../models/api/stardust/participation/IParticipationEventResponse"; import { IParticipationEventStatus } from "../../models/api/stardust/participation/IParticipationEventStatus"; import { INetwork } from "../../models/db/INetwork"; -import { NodeInfoService } from "../../services/stardust/nodeInfoService"; -import { HexHelper } from "../hexHelper"; +import { HexHelper } from "../../utils/hexHelper"; +import { SearchExecutor } from "../../utils/stardust/searchExecutor"; +import { SearchQuery, SearchQueryBuilder } from "../../utils/stardust/searchQueryBuilder"; +import { addressBalance, blockIdFromMilestonePayload } from "../../utils/stardust/utils"; /** * Helper functions for use with tangle. */ -export class StardustTangleHelper { +export class StardustApiService { /** * The network in context. */ diff --git a/api/src/utils/stardust/searchExecutor.ts b/api/src/utils/stardust/searchExecutor.ts index f2c7ac136..b7765f617 100644 --- a/api/src/utils/stardust/searchExecutor.ts +++ b/api/src/utils/stardust/searchExecutor.ts @@ -1,8 +1,8 @@ import { SearchQuery } from "./searchQueryBuilder"; -import { StardustTangleHelper } from "./stardustTangleHelper"; import { ServiceFactory } from "../../factories/serviceFactory"; import { ISearchResponse } from "../../models/api/stardust/ISearchResponse"; import { INetwork } from "../../models/db/INetwork"; +import { StardustApiService } from "../../services/stardust/stardustApiService"; /** * Performs the search from a SearchQuery object on a Stardust network. @@ -13,11 +13,11 @@ export class SearchExecutor { */ private readonly query: SearchQuery; - private readonly tangleHelper: StardustTangleHelper; + private readonly tangleHelper: StardustApiService; constructor(network: INetwork, query: SearchQuery) { this.query = query; - this.tangleHelper = ServiceFactory.get(`tangle-helper-${network.network}`); + this.tangleHelper = ServiceFactory.get(`api-service-${network.network}`); } public async run(): Promise { From 93e9a164e4b0f0304289a8e6457adeae21314cef Mon Sep 17 00:00:00 2001 From: JCNoguera Date: Fri, 19 Jan 2024 17:57:59 +0100 Subject: [PATCH 6/6] fix: rename tangleHelper --- api/src/utils/stardust/searchExecutor.ts | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/api/src/utils/stardust/searchExecutor.ts b/api/src/utils/stardust/searchExecutor.ts index b7765f617..912676a05 100644 --- a/api/src/utils/stardust/searchExecutor.ts +++ b/api/src/utils/stardust/searchExecutor.ts @@ -13,11 +13,11 @@ export class SearchExecutor { */ private readonly query: SearchQuery; - private readonly tangleHelper: StardustApiService; + private readonly apiService: StardustApiService; constructor(network: INetwork, query: SearchQuery) { this.query = query; - this.tangleHelper = ServiceFactory.get(`api-service-${network.network}`); + this.apiService = ServiceFactory.get(`api-service-${network.network}`); } public async run(): Promise { @@ -28,7 +28,7 @@ export class SearchExecutor { if (searchQuery.did) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .aliasDetails(searchQuery.aliasId) .then((aliasOutputs) => { if (aliasOutputs) { @@ -51,7 +51,7 @@ export class SearchExecutor { if (searchQuery.milestoneIndex) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .milestoneDetailsByIndex(searchQuery.milestoneIndex) .then((milestoneDetails) => { if (milestoneDetails) { @@ -73,7 +73,7 @@ export class SearchExecutor { if (searchQuery.milestoneId) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .milestoneDetailsById(searchQuery.milestoneId) .then((milestoneDetails) => { if (milestoneDetails) { @@ -95,7 +95,7 @@ export class SearchExecutor { if (searchQuery.blockId) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .block(searchQuery.blockId) .then((blockResponse) => { if (blockResponse && !blockResponse.error) { @@ -117,7 +117,7 @@ export class SearchExecutor { if (searchQuery.transactionId) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .transactionIncludedBlock(searchQuery.transactionId) .then((txDetailsResponse) => { if (txDetailsResponse.block && Object.keys(txDetailsResponse.block).length > 0) { @@ -139,7 +139,7 @@ export class SearchExecutor { if (searchQuery.output) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .outputDetails(searchQuery.output) .then((output) => { if (output) { @@ -159,7 +159,7 @@ export class SearchExecutor { if (searchQuery.aliasId) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .aliasDetails(searchQuery.aliasId) .then((aliasOutputs) => { if (aliasOutputs) { @@ -181,7 +181,7 @@ export class SearchExecutor { if (searchQuery.nftId) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .nftDetails(searchQuery.nftId) .then((nftOutputs) => { if (nftOutputs) { @@ -203,7 +203,7 @@ export class SearchExecutor { if (searchQuery.foundryId) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .foundryDetails(searchQuery.foundryId) .then((foundryOutput) => { if (foundryOutput) { @@ -225,7 +225,7 @@ export class SearchExecutor { if (searchQuery.tag) { promises.push( new Promise((resolve, reject) => { - this.tangleHelper + this.apiService .taggedOutputs(searchQuery.tag) .then((response) => { if (!response.basicOutputs.error || !response.nftOutputs.error) {