Extract swr fetcher
This commit is contained in:
parent
5fc0058fb9
commit
50ac6f7a3e
@ -5,6 +5,7 @@ import {
|
|||||||
TransactionDescription,
|
TransactionDescription,
|
||||||
} from "@ethersproject/abi";
|
} from "@ethersproject/abi";
|
||||||
import { BigNumberish } from "@ethersproject/bignumber";
|
import { BigNumberish } from "@ethersproject/bignumber";
|
||||||
|
import { Fetcher } from "swr";
|
||||||
import useSWRImmutable from "swr/immutable";
|
import useSWRImmutable from "swr/immutable";
|
||||||
import { RuntimeContext } from "./useRuntime";
|
import { RuntimeContext } from "./useRuntime";
|
||||||
import { fourBytesURL } from "./url";
|
import { fourBytesURL } from "./url";
|
||||||
@ -29,16 +30,32 @@ export const extract4Bytes = (rawInput: string): string | null => {
|
|||||||
return rawInput.slice(0, 10);
|
return rawInput.slice(0, 10);
|
||||||
};
|
};
|
||||||
|
|
||||||
const fetch4Bytes = async (
|
type FourBytesKey = [id: "4bytes", fourBytes: string];
|
||||||
assetsURLPrefix: string,
|
type FourBytesFetcher = Fetcher<
|
||||||
fourBytes: string
|
FourBytesEntry | null | undefined,
|
||||||
): Promise<FourBytesEntry | null> => {
|
FourBytesKey
|
||||||
const signatureURL = fourBytesURL(assetsURLPrefix, fourBytes);
|
>;
|
||||||
|
|
||||||
|
const fourBytesFetcher =
|
||||||
|
(assetsURLPrefix: string): FourBytesFetcher =>
|
||||||
|
async (_, key) => {
|
||||||
|
if (key === null || key === "0x") {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle simple transfers with invalid selector like tx:
|
||||||
|
// 0x8bcbdcc1589b5c34c1e55909c8269a411f0267a4fed59a73dd4348cc71addbb9,
|
||||||
|
// which contains 0x00 as data
|
||||||
|
if (key.length !== 10) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
const fourBytes = key.slice(2);
|
||||||
|
const signatureURL = fourBytesURL(assetsURLPrefix, fourBytes);
|
||||||
|
|
||||||
try {
|
|
||||||
const res = await fetch(signatureURL);
|
const res = await fetch(signatureURL);
|
||||||
if (!res.ok) {
|
if (!res.ok) {
|
||||||
console.error(`Signature does not exist in 4bytes DB: ${fourBytes}`);
|
console.warn(`Signature does not exist in 4bytes DB: ${fourBytes}`);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -53,11 +70,7 @@ const fetch4Bytes = async (
|
|||||||
signature: sig,
|
signature: sig,
|
||||||
};
|
};
|
||||||
return entry;
|
return entry;
|
||||||
} catch (err) {
|
};
|
||||||
console.error(`Couldn't fetch signature URL ${signatureURL}`, err);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extract 4bytes DB info
|
* Extract 4bytes DB info
|
||||||
@ -75,26 +88,10 @@ export const use4Bytes = (
|
|||||||
|
|
||||||
const { config } = useContext(RuntimeContext);
|
const { config } = useContext(RuntimeContext);
|
||||||
const assetsURLPrefix = config?.assetsURLPrefix;
|
const assetsURLPrefix = config?.assetsURLPrefix;
|
||||||
|
const fourBytesKey = assetsURLPrefix !== undefined ? rawFourBytes : null;
|
||||||
|
|
||||||
const fourBytesFetcher = (key: string | null) => {
|
const fetcher = fourBytesFetcher(assetsURLPrefix!);
|
||||||
if (key === null || key === "0x") {
|
const { data, error } = useSWRImmutable(["4bytes", fourBytesKey], fetcher);
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle simple transfers with invalid selector like tx:
|
|
||||||
// 0x8bcbdcc1589b5c34c1e55909c8269a411f0267a4fed59a73dd4348cc71addbb9,
|
|
||||||
// which contains 0x00 as data
|
|
||||||
if (key.length !== 10) {
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
return fetch4Bytes(assetsURLPrefix!, key.slice(2));
|
|
||||||
};
|
|
||||||
|
|
||||||
const { data, error } = useSWRImmutable<FourBytesEntry | null | undefined>(
|
|
||||||
assetsURLPrefix !== undefined ? rawFourBytes : null,
|
|
||||||
fourBytesFetcher
|
|
||||||
);
|
|
||||||
return error ? undefined : data;
|
return error ? undefined : data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user