Skip to content

Commit

Permalink
Merge branch 'master' into npai/cache-allowances
Browse files Browse the repository at this point in the history
  • Loading branch information
pxrl authored Mar 21, 2024
2 parents 33a99d3 + ff30323 commit 28cd76a
Showing 1 changed file with 45 additions and 1 deletion.
46 changes: 45 additions & 1 deletion src/clients/AcrossAPIClient.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,16 @@
import _ from "lodash";
import axios, { AxiosError } from "axios";
import { SpokePoolClientsByChain } from "../interfaces";
import { bnZero, isDefined, winston, BigNumber, getL2TokenAddresses, CHAIN_IDs, TOKEN_SYMBOLS_MAP } from "../utils";
import {
bnZero,
isDefined,
winston,
BigNumber,
getL2TokenAddresses,
CHAIN_IDs,
TOKEN_SYMBOLS_MAP,
getRedisCache,
} from "../utils";
import { HubPoolClient } from "./HubPoolClient";

export interface DepositLimits {
Expand Down Expand Up @@ -108,6 +117,10 @@ export class AcrossApiClient {
return this.limits[l1Token];
}

getLimitsCacheKey(l1Token: string, destinationChainId: number): string {
return `limits_api_${l1Token}_${destinationChainId}`;
}

private async callLimits(
l1Token: string,
destinationChainIds: number[],
Expand All @@ -116,10 +129,41 @@ export class AcrossApiClient {
const path = "limits";
const url = `${this.endpoint}/${path}`;

const redis = await getRedisCache();
for (const destinationChainId of destinationChainIds) {
const params = { token: l1Token, destinationChainId, originChainId: 1 };
if (redis) {
try {
const cachedLimits = await redis.get<string>(this.getLimitsCacheKey(l1Token, destinationChainId));
if (cachedLimits !== null) {
return { maxDeposit: BigNumber.from(cachedLimits) };
}
} catch (e) {
this.logger.debug({
at: "AcrossAPIClient",
message: "Failed to get cached limits data",
l1Token,
destinationChainId,
error: e,
});
}
}
try {
const result = await axios(url, { timeout, params });
if (!result?.data?.maxDeposit) {
this.logger.error({
at: "AcrossAPIClient",
message: "Invalid response from /limits, expected maxDeposit field.",
url,
params,
result,
});
continue;
}
if (redis) {
// Cache limit for 5 minutes.
await redis.set(this.getLimitsCacheKey(l1Token, destinationChainId), result.data.maxDeposit.toString(), 300);
}
return result.data;
} catch (err) {
const msg = _.get(err, "response.data", _.get(err, "response.statusText", (err as AxiosError).message));
Expand Down

0 comments on commit 28cd76a

Please sign in to comment.