accesslist.ts 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import { getAddress } from "../address/index.js";
  2. import { assertArgument, isHexString } from "../utils/index.js";
  3. import type { AccessList, AccessListish } from "./index.js";
  4. function accessSetify(addr: string, storageKeys: Array<string>): { address: string,storageKeys: Array<string> } {
  5. return {
  6. address: getAddress(addr),
  7. storageKeys: storageKeys.map((storageKey, index) => {
  8. assertArgument(isHexString(storageKey, 32), "invalid slot", `storageKeys[${ index }]`, storageKey);
  9. return storageKey.toLowerCase();
  10. })
  11. };
  12. }
  13. /**
  14. * Returns a [[AccessList]] from any ethers-supported access-list structure.
  15. */
  16. export function accessListify(value: AccessListish): AccessList {
  17. if (Array.isArray(value)) {
  18. return (<Array<[ string, Array<string>] | { address: string, storageKeys: Array<string>}>>value).map((set, index) => {
  19. if (Array.isArray(set)) {
  20. assertArgument(set.length === 2, "invalid slot set", `value[${ index }]`, set);
  21. return accessSetify(set[0], set[1])
  22. }
  23. assertArgument(set != null && typeof(set) === "object", "invalid address-slot set", "value", value);
  24. return accessSetify(set.address, set.storageKeys);
  25. });
  26. }
  27. assertArgument(value != null && typeof(value) === "object", "invalid access list", "value", value);
  28. const result: Array<{ address: string, storageKeys: Array<string> }> = Object.keys(value).map((addr) => {
  29. const storageKeys: Record<string, true> = value[addr].reduce((accum, storageKey) => {
  30. accum[storageKey] = true;
  31. return accum;
  32. }, <Record<string, true>>{ });
  33. return accessSetify(addr, Object.keys(storageKeys).sort())
  34. });
  35. result.sort((a, b) => (a.address.localeCompare(b.address)));
  36. return result;
  37. }