From ec6d416288dd99753e94df00878ea3ddcb2bcfca Mon Sep 17 00:00:00 2001 From: jsy1218 <91580504+jsy1218@users.noreply.github.com> Date: Fri, 7 Jun 2024 12:11:05 -0700 Subject: [PATCH 1/2] feat: shadow tenderly new node endpoint --- README.md | 1 + bin/app.ts | 6 ++++++ bin/stacks/routing-api-stack.ts | 3 +++ bin/stacks/routing-lambda-stack.ts | 5 ++++- lib/handlers/injector-sor.ts | 13 ++++++++----- package-lock.json | 14 +++++++------- package.json | 2 +- 7 files changed, 30 insertions(+), 14 deletions(-) diff --git a/README.md b/README.md index a7d608426f..7ebe03bfbb 100644 --- a/README.md +++ b/README.md @@ -36,6 +36,7 @@ The best way to develop and test the API is to deploy your own instance to AWS. TENDERLY_USER = '' # For enabling Tenderly simulations TENDERLY_PROJECT = '' # For enabling Tenderly simulations TENDERLY_ACCESS_KEY = '' # For enabling Tenderly simulations + TENDERLY_NODE_API_KEY = '' # For enabling Tenderly node-level RPC access ``` 3. Install and build the package ``` diff --git a/bin/app.ts b/bin/app.ts index 1e30da5a44..19c5cd3f0f 100644 --- a/bin/app.ts +++ b/bin/app.ts @@ -35,6 +35,7 @@ export class RoutingAPIStage extends Stage { tenderlyUser: string tenderlyProject: string tenderlyAccessKey: string + tenderlyNodeApiKey: string unicornSecret: string alchemyQueryKey?: string decentralizedNetworkApiKey?: string @@ -55,6 +56,7 @@ export class RoutingAPIStage extends Stage { tenderlyUser, tenderlyProject, tenderlyAccessKey, + tenderlyNodeApiKey, unicornSecret, alchemyQueryKey, decentralizedNetworkApiKey, @@ -74,6 +76,7 @@ export class RoutingAPIStage extends Stage { tenderlyUser, tenderlyProject, tenderlyAccessKey, + tenderlyNodeApiKey, unicornSecret, alchemyQueryKey, decentralizedNetworkApiKey, @@ -246,6 +249,7 @@ export class RoutingAPIPipeline extends Stack { tenderlyUser: tenderlyCreds.secretValueFromJson('tenderly-user').toString(), tenderlyProject: tenderlyCreds.secretValueFromJson('tenderly-project').toString(), tenderlyAccessKey: tenderlyCreds.secretValueFromJson('tenderly-access-key').toString(), + tenderlyNodeApiKey: tenderlyCreds.secretValueFromJson('tenderly-node-api-key').toString(), unicornSecret: unicornSecrets.secretValueFromJson('debug-config-unicorn-key').toString(), alchemyQueryKey: routingApiNewSecrets.secretValueFromJson('alchemy-query-key').toString(), decentralizedNetworkApiKey: routingApiNewSecrets.secretValueFromJson('decentralized-network-api-key').toString(), @@ -271,6 +275,7 @@ export class RoutingAPIPipeline extends Stack { tenderlyUser: tenderlyCreds.secretValueFromJson('tenderly-user').toString(), tenderlyProject: tenderlyCreds.secretValueFromJson('tenderly-project').toString(), tenderlyAccessKey: tenderlyCreds.secretValueFromJson('tenderly-access-key').toString(), + tenderlyNodeApiKey: tenderlyCreds.secretValueFromJson('tenderly-node-api-key').toString(), unicornSecret: unicornSecrets.secretValueFromJson('debug-config-unicorn-key').toString(), alchemyQueryKey: routingApiNewSecrets.secretValueFromJson('alchemy-query-key').toString(), decentralizedNetworkApiKey: routingApiNewSecrets.secretValueFromJson('decentralized-network-api-key').toString(), @@ -404,6 +409,7 @@ new RoutingAPIStack(app, 'RoutingAPIStack', { tenderlyUser: process.env.TENDERLY_USER!, tenderlyProject: process.env.TENDERLY_PROJECT!, tenderlyAccessKey: process.env.TENDERLY_ACCESS_KEY!, + tenderlyNodeApiKey: process.env.TENDERLY_NODE_API_KEY!, unicornSecret: process.env.UNICORN_SECRET!, }) diff --git a/bin/stacks/routing-api-stack.ts b/bin/stacks/routing-api-stack.ts index 293bb125b4..bee79f6756 100644 --- a/bin/stacks/routing-api-stack.ts +++ b/bin/stacks/routing-api-stack.ts @@ -45,6 +45,7 @@ export class RoutingAPIStack extends cdk.Stack { tenderlyUser: string tenderlyProject: string tenderlyAccessKey: string + tenderlyNodeApiKey: string unicornSecret: string alchemyQueryKey?: string decentralizedNetworkApiKey?: string @@ -67,6 +68,7 @@ export class RoutingAPIStack extends cdk.Stack { tenderlyUser, tenderlyProject, tenderlyAccessKey, + tenderlyNodeApiKey, unicornSecret, alchemyQueryKey, decentralizedNetworkApiKey, @@ -117,6 +119,7 @@ export class RoutingAPIStack extends cdk.Stack { tenderlyUser, tenderlyProject, tenderlyAccessKey, + tenderlyNodeApiKey, routesDynamoDb, routesDbCachingRequestFlagDynamoDb, cachedRoutesDynamoDb, diff --git a/bin/stacks/routing-lambda-stack.ts b/bin/stacks/routing-lambda-stack.ts index 9b08c42397..0ccdc7d8b2 100644 --- a/bin/stacks/routing-lambda-stack.ts +++ b/bin/stacks/routing-lambda-stack.ts @@ -27,6 +27,7 @@ export interface RoutingLambdaStackProps extends cdk.NestedStackProps { tenderlyUser: string tenderlyProject: string tenderlyAccessKey: string + tenderlyNodeApiKey: string chatbotSNSArn?: string routesDynamoDb: aws_dynamodb.Table routesDbCachingRequestFlagDynamoDb: aws_dynamodb.Table @@ -58,6 +59,7 @@ export class RoutingLambdaStack extends cdk.NestedStack { tenderlyUser, tenderlyProject, tenderlyAccessKey, + tenderlyNodeApiKey, routesDynamoDb, routesDbCachingRequestFlagDynamoDb, cachedRoutesDynamoDb, @@ -117,7 +119,7 @@ export class RoutingLambdaStack extends cdk.NestedStack { description: 'Routing Lambda', environment: { - VERSION: '23', + VERSION: '24', NODE_OPTIONS: '--enable-source-maps', POOL_CACHE_BUCKET: poolCacheBucket.bucketName, POOL_CACHE_BUCKET_2: poolCacheBucket2.bucketName, @@ -129,6 +131,7 @@ export class RoutingLambdaStack extends cdk.NestedStack { TENDERLY_USER: tenderlyUser, TENDERLY_PROJECT: tenderlyProject, TENDERLY_ACCESS_KEY: tenderlyAccessKey, + TENDERLY_NODE_API_KEY: tenderlyNodeApiKey, // WARNING: Dynamo table name should be the tableinstance.name, e.g. routesDynamoDb.tableName. // But we tried and had seen lambd version error: // The following resource(s) failed to create: [RoutingLambda2CurrentVersion49A1BB948389ce4f9c26b15e2ccb07b4c1bab726]. diff --git a/lib/handlers/injector-sor.ts b/lib/handlers/injector-sor.ts index 8ab085bf4c..af840da189 100644 --- a/lib/handlers/injector-sor.ts +++ b/lib/handlers/injector-sor.ts @@ -37,7 +37,7 @@ import { UniswapMulticallProvider, V2PoolProvider, V2QuoteProvider, - V3PoolProvider, + V3PoolProvider } from '@uniswap/smart-order-router' import { TokenList } from '@uniswap/token-lists' import { default as bunyan, default as Logger } from 'bunyan' @@ -60,12 +60,12 @@ import { GlobalRpcProviders } from '../rpc/GlobalRpcProviders' import { StaticJsonRpcProvider } from '@ethersproject/providers' import { TrafficSwitchOnChainQuoteProvider } from './quote/provider-migration/v3/traffic-switch-on-chain-quote-provider' import { - NON_OPTIMISTIC_CACHED_ROUTES_BATCH_PARAMS, BLOCK_NUMBER_CONFIGS, GAS_ERROR_FAILURE_OVERRIDES, - RETRY_OPTIONS, - SUCCESS_RATE_FAILURE_OVERRIDES, + NON_OPTIMISTIC_CACHED_ROUTES_BATCH_PARAMS, OPTIMISTIC_CACHED_ROUTES_BATCH_PARAMS, + RETRY_OPTIONS, + SUCCESS_RATE_FAILURE_OVERRIDES } from '../util/onChainQuoteProviderConfigs' import { v4 } from 'uuid/index' import { chainProtocols } from '../cron/cache-config' @@ -388,13 +388,16 @@ export abstract class InjectorSOR extends Injector< process.env.TENDERLY_USER!, process.env.TENDERLY_PROJECT!, process.env.TENDERLY_ACCESS_KEY!, + process.env.TENDERLY_NODE_API_KEY!, v2PoolProvider, v3PoolProvider, provider, portionProvider, undefined, // The timeout for the underlying axios call to Tenderly, measured in milliseconds. - 2.5 * 1000 + 2.5 * 1000, + 10, + [ChainId.MAINNET] ) const ethEstimateGasSimulator = new EthEstimateGasSimulator( diff --git a/package-lock.json b/package-lock.json index 9fe1c06475..fabba5d113 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "@uniswap/permit2-sdk": "^1.2.0", "@uniswap/router-sdk": "^1.9.2", "@uniswap/sdk-core": "^4.2.0", - "@uniswap/smart-order-router": "3.33.1", + "@uniswap/smart-order-router": "3.34.0", "@uniswap/token-lists": "^1.0.0-beta.33", "@uniswap/universal-router-sdk": "^2.1.0", "@uniswap/v2-sdk": "^4.3.2", @@ -4761,9 +4761,9 @@ } }, "node_modules/@uniswap/smart-order-router": { - "version": "3.33.1", - "resolved": "https://registry.npmjs.org/@uniswap/smart-order-router/-/smart-order-router-3.33.1.tgz", - "integrity": "sha512-w6LaNgsMdsz3M+DX98M3PzosHg1nn2mIH/1uXVydNhYG9XyIRLS71x/75mx/jfp1MCoqw/OernLE2cMRq5YQUg==", + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/@uniswap/smart-order-router/-/smart-order-router-3.34.0.tgz", + "integrity": "sha512-/cWIxmvrsaEvpvGYsGGgmU47FNKZKpo53LJHvzCjFdBNWG/0vPF8OeiecaSi+H4o16f4HTM2UgBzv+E0HVXK4w==", "dependencies": { "@eth-optimism/sdk": "^3.2.2", "@types/brotli": "^1.3.4", @@ -28474,9 +28474,9 @@ } }, "@uniswap/smart-order-router": { - "version": "3.33.1", - "resolved": "https://registry.npmjs.org/@uniswap/smart-order-router/-/smart-order-router-3.33.1.tgz", - "integrity": "sha512-w6LaNgsMdsz3M+DX98M3PzosHg1nn2mIH/1uXVydNhYG9XyIRLS71x/75mx/jfp1MCoqw/OernLE2cMRq5YQUg==", + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/@uniswap/smart-order-router/-/smart-order-router-3.34.0.tgz", + "integrity": "sha512-/cWIxmvrsaEvpvGYsGGgmU47FNKZKpo53LJHvzCjFdBNWG/0vPF8OeiecaSi+H4o16f4HTM2UgBzv+E0HVXK4w==", "requires": { "@eth-optimism/sdk": "^3.2.2", "@types/brotli": "^1.3.4", diff --git a/package.json b/package.json index 72b90a84ae..40603e20e8 100644 --- a/package.json +++ b/package.json @@ -87,7 +87,7 @@ "@uniswap/router-sdk": "^1.9.2", "@uniswap/sdk-core": "^4.2.0", "@types/semver": "^7.5.8", - "@uniswap/smart-order-router": "3.33.1", + "@uniswap/smart-order-router": "3.34.0", "@uniswap/token-lists": "^1.0.0-beta.33", "@uniswap/universal-router-sdk": "^2.1.0", "@uniswap/v2-sdk": "^4.3.2", From 69be2f550c9e8346f9c084fcb4eb216566cfb474 Mon Sep 17 00:00:00 2001 From: jsy1218 <91580504+jsy1218@users.noreply.github.com> Date: Fri, 7 Jun 2024 12:32:43 -0700 Subject: [PATCH 2/2] fix prettier --- lib/handlers/injector-sor.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/handlers/injector-sor.ts b/lib/handlers/injector-sor.ts index af840da189..5a3a527233 100644 --- a/lib/handlers/injector-sor.ts +++ b/lib/handlers/injector-sor.ts @@ -37,7 +37,7 @@ import { UniswapMulticallProvider, V2PoolProvider, V2QuoteProvider, - V3PoolProvider + V3PoolProvider, } from '@uniswap/smart-order-router' import { TokenList } from '@uniswap/token-lists' import { default as bunyan, default as Logger } from 'bunyan' @@ -65,7 +65,7 @@ import { NON_OPTIMISTIC_CACHED_ROUTES_BATCH_PARAMS, OPTIMISTIC_CACHED_ROUTES_BATCH_PARAMS, RETRY_OPTIONS, - SUCCESS_RATE_FAILURE_OVERRIDES + SUCCESS_RATE_FAILURE_OVERRIDES, } from '../util/onChainQuoteProviderConfigs' import { v4 } from 'uuid/index' import { chainProtocols } from '../cron/cache-config'