diff --git a/api-gateway/configs/.env.gateway b/api-gateway/configs/.env.gateway index 060aba22ff..629405cf60 100644 --- a/api-gateway/configs/.env.gateway +++ b/api-gateway/configs/.env.gateway @@ -17,6 +17,9 @@ MQ_MAX_PAYLOAD="1048576" HOST_CACHE='localhost' PORT_CACHE='6379' ENABLE_CACHE='true' +USE_SENTINEL='false' +SENTINEL_HOSTS='' +REDIS_MASTER_NAME='' #PINO_LOGGER TRANSPORTS="CONSOLE, MONGO" diff --git a/api-gateway/configs/.env.gateway.develop b/api-gateway/configs/.env.gateway.develop index f0e2263529..ccee3e8f58 100644 --- a/api-gateway/configs/.env.gateway.develop +++ b/api-gateway/configs/.env.gateway.develop @@ -17,6 +17,9 @@ MQ_MAX_PAYLOAD="1048576" HOST_CACHE='localhost' PORT_CACHE='6379' ENABLE_CACHE='true' +USE_SENTINEL='false' +SENTINEL_HOSTS='' +REDIS_MASTER_NAME='' #PINO_LOGGER TRANSPORTS="CONSOLE, MONGO" diff --git a/api-gateway/configs/.env.gateway.template b/api-gateway/configs/.env.gateway.template index 8d0623f71e..8fc62e572d 100644 --- a/api-gateway/configs/.env.gateway.template +++ b/api-gateway/configs/.env.gateway.template @@ -17,6 +17,9 @@ MQ_MAX_PAYLOAD="" HOST_CACHE='' PORT_CACHE='' ENABLE_CACHE='true' +USE_SENTINEL='false' +SENTINEL_HOSTS='' +REDIS_MASTER_NAME='' #PINO_LOGGER TRANSPORTS="CONSOLE, MONGO" diff --git a/api-gateway/src/helpers/providers/cache-provider.ts b/api-gateway/src/helpers/providers/cache-provider.ts index 5975866368..1922513b1e 100644 --- a/api-gateway/src/helpers/providers/cache-provider.ts +++ b/api-gateway/src/helpers/providers/cache-provider.ts @@ -10,13 +10,27 @@ export const CACHE_CLIENT = 'CACHE_CLIENT' const HOST = process.env.HOST_CACHE; const PORT = Number(process.env.PORT_CACHE); +const USE_SENTINEL = process.env.USE_SENTINEL === 'true'; +const SENTINEL_HOSTS = process.env.SENTINEL_HOSTS?.split(',') || []; +const MASTER_NAME = process.env.REDIS_MASTER_NAME; export const cacheProvider: Provider = { useFactory: (): CacheClient => { - return new Cache({ - host: HOST, - port: PORT, - }); + if (USE_SENTINEL && SENTINEL_HOSTS.length > 0) { + return new Cache({ + sentinels: SENTINEL_HOSTS.map(host => { + const [hostName, port] = host.split(':'); + return { host: hostName, port: Number(port) }; + }), + name: MASTER_NAME, + }); + } else { + // Direct Redis connection + return new Cache({ + host: HOST, + port: PORT, + }); + } }, provide: CACHE_CLIENT, }; diff --git a/common/package.json b/common/package.json index d5da9115cb..445d9b4369 100644 --- a/common/package.json +++ b/common/package.json @@ -27,7 +27,7 @@ "ajv": "^8.10.0", "ajv-formats": "^2.1.1", "axios": "^1.3.6", - "bs58": "^4.0.1", + "bs58": "^6.0.0", "bson": "^6.5.0", "dotenv": "^16.0.0", "exceljs": "^4.4.0", diff --git a/common/src/hedera-modules/hashing.ts b/common/src/hedera-modules/hashing.ts index 4424c5830b..c7f4fb430b 100644 --- a/common/src/hedera-modules/hashing.ts +++ b/common/src/hedera-modules/hashing.ts @@ -13,8 +13,8 @@ export class Hashing { encode: (data: Uint8Array): string => { return bs58.encode(data); }, - decode: (data: string): Uint8Array => { - return bs58.decode(data); + decode: (data: string): Buffer => { + return Buffer.from(bs58.decode(data)); } } /** diff --git a/common/src/helpers/vc-helper.ts b/common/src/helpers/vc-helper.ts index ef5fb7bc6c..051a9ebee5 100644 --- a/common/src/helpers/vc-helper.ts +++ b/common/src/helpers/vc-helper.ts @@ -43,7 +43,7 @@ import { KeyType, Users, Wallet } from '../helpers/index.js'; import { IAuthUser } from '../interfaces/index.js'; import { Ed25519VerificationKey2018 } from '@transmute/ed25519-signature-2018'; import { bls12_381 } from '@noble/curves/bls12-381'; -import bs58 from 'bs58'; +import { Hashing } from '../hedera-modules/hashing.js'; import { DatabaseServer } from '../database-modules/index.js'; /** @@ -501,10 +501,10 @@ export class VcHelper extends VCJS { const option = method.toObject(true) as any; switch (option.type) { case 'Ed25519VerificationKey2018': { - const privateKeyHex = bs58 + const privateKeyHex = Hashing.base58 .decode(option.privateKeyBase58) .toString('hex') - const publicKeyHex = bs58 + const publicKeyHex = Hashing.base58 .decode(option.publicKeyBase58) .toString('hex') if (!privateKeyHex.endsWith(publicKeyHex)) { @@ -516,12 +516,12 @@ export class VcHelper extends VCJS { case 'Bls12381G2Key2020': { const privateKeyBase58 = option.privateKeyBase58; const publicKeyBase58 = option.publicKeyBase58; - const privateKeyHex = bs58 + const privateKeyHex = Hashing.base58 .decode(privateKeyBase58) .toString('hex') .toUpperCase(); const publicKey = bls12_381.getPublicKeyForShortSignatures(privateKeyHex); - if (publicKeyBase58 !== bs58.encode(publicKey)) { + if (publicKeyBase58 !== Hashing.base58.encode(publicKey)) { return false; } keyPair = await Bls12381G2KeyPair.from(option); diff --git a/common/src/wallet/wallet.ts b/common/src/wallet/wallet.ts index 96f4890750..4c04512a07 100644 --- a/common/src/wallet/wallet.ts +++ b/common/src/wallet/wallet.ts @@ -1,6 +1,6 @@ import { SecretManager, SecretManagerBase, SecretManagerType } from '../secret-manager/index.js'; import crypto from 'crypto'; -import * as bs58 from 'bs58'; +import { Hashing } from '../hedera-modules/hashing.js'; import { AzureSecretManager } from '../secret-manager/azure/azure-secret-manager.js'; import { GcpSecretManager } from '../secret-manager/gcp/gcp-secret-manager.js'; @@ -64,7 +64,7 @@ export class Wallet { // convert hashedKey from hex to Base58 to shoeten key length, Azure does not accept keys longet than 128 chars // convert hashedKey from hex to Base58 to shoeten key length, GCP does not accept keys longet than 255 chars const buffer = Buffer.from(hashedKey, 'hex'); - const hashedKeyBase58 = bs58.encode(buffer); + const hashedKeyBase58 = Hashing.base58.encode(buffer); return hashedKeyBase58; } diff --git a/guardian-service/package.json b/guardian-service/package.json index 79cce74113..e38a0c2358 100644 --- a/guardian-service/package.json +++ b/guardian-service/package.json @@ -36,7 +36,6 @@ "ajv": "^8.10.0", "ajv-formats": "^2.1.1", "axios": "^1.3.6", - "bs58": "^4.0.1", "bson": "^6.5.0", "cors": "^2.8.5", "cron": "^2.0.0", diff --git a/indexer-service/package.json b/indexer-service/package.json index be95a3c2d0..a7fc1c5d19 100644 --- a/indexer-service/package.json +++ b/indexer-service/package.json @@ -11,7 +11,7 @@ "@nestjs/core": "^9.4.1", "@nestjs/microservices": "^9.4.1", "axios": "^1.7.2", - "bs58": "^4.0.1", + "bs58": "^6.0.0", "axios-retry": "^3.2.4", "cron": "^3.1.7", "cross-blob": "^2.0.1", diff --git a/policy-service/package.json b/policy-service/package.json index c253470e20..74cdce22f1 100644 --- a/policy-service/package.json +++ b/policy-service/package.json @@ -35,7 +35,6 @@ "ajv": "^8.10.0", "ajv-formats": "^2.1.1", "axios": "^1.3.6", - "bs58": "^4.0.1", "bson": "^6.5.0", "cors": "^2.8.5", "cron": "^2.0.0",