@renegade-fi/core
Version:
VanillaJS library for Renegade
78 lines • 3.2 kB
JavaScript
import invariant from "tiny-invariant";
import { parseAbiItem } from "viem";
import { FIND_WALLET_ROUTE } from "../constants.js";
import { BaseError } from "../errors/base.js";
import { postRelayerRaw } from "../utils/http.js";
import { waitForWalletIndexing } from "./waitForWalletIndexing.js";
export async function lookupWallet(config, parameters = {}) {
const { getBaseUrl, utils } = config;
let body;
if (config.renegadeKeyType === "internal") {
const { seed } = config.state;
invariant(seed, "seed is required");
body = utils.find_wallet(seed);
}
else {
const { blinderSeed, shareSeed, skMatch } = parameters;
const { walletId, publicKey, symmetricKey } = config;
invariant(blinderSeed, "blinderSeed is required");
invariant(shareSeed, "shareSeed is required");
invariant(skMatch, "skMatch is required");
body = await utils.find_external_wallet(walletId, blinderSeed, shareSeed, publicKey, skMatch, symmetricKey);
}
const res = await postRelayerRaw(getBaseUrl(FIND_WALLET_ROUTE), body);
if (res.task_id) {
console.log(`task lookup-wallet(${res.task_id}): ${res.wallet_id}`, {
status: "looking up",
walletId: res.wallet_id,
});
if (config.renegadeKeyType === "internal") {
config.setState((x) => ({ ...x, status: "looking up" }));
}
return waitForWalletIndexing(config, {
timeout: 300000,
isLookup: true,
onComplete(wallet) {
if (config.renegadeKeyType === "internal") {
config.setState((x) => ({
...x,
status: "in relayer",
}));
}
console.log(`task lookup-wallet(${res.task_id}) completed: ${wallet.id}`, {
status: "in relayer",
walletId: wallet.id,
});
},
onFailure() {
console.log(`task lookup-wallet(${res.task_id}) failed: ${res.wallet_id}`);
if (config.renegadeKeyType === "internal") {
config.setState({});
}
},
});
}
return Promise.reject(new BaseError("Failed to lookup wallet"));
}
// Returns true iff the query successfully returns 0 logs
export async function checkForWalletUpdatesOnChain(config) {
try {
const { utils, state: { seed }, } = config;
invariant(seed, "Seed is required");
const blinderShare = utils.derive_blinder_share(seed);
const logs = await config.viemClient.getLogs({
address: config.darkPoolAddress,
event: parseAbiItem("event WalletUpdated(uint256 indexed wallet_blinder_share)"),
args: {
wallet_blinder_share: blinderShare,
},
fromBlock: BigInt(process.env.FROM_BLOCK || process.env.NEXT_PUBLIC_FROM_BLOCK || 0),
});
return logs.length === 0;
}
catch (error) {
console.error(`Error looking up wallet on chain: ${error}`);
return false;
}
}
//# sourceMappingURL=lookupWallet.js.map