diff --git a/examples/key-value-store-local/index.js b/examples/key-value-store-local/index.js new file mode 100644 index 00000000..09fb4a00 --- /dev/null +++ b/examples/key-value-store-local/index.js @@ -0,0 +1,15 @@ +const { Defender } = require('@openzeppelin/defender-sdk'); + +async function main() { + const store = Defender.localKVStoreClient({ path: './store.json' }); + await store.put('key', 'value!'); + + const value = await store.get('key'); + console.log(value); + + await store.del('key'); +} + +if (require.main === module) { + main().catch(console.error); +} diff --git a/examples/key-value-store-local/package.json b/examples/key-value-store-local/package.json new file mode 100644 index 00000000..627d45bf --- /dev/null +++ b/examples/key-value-store-local/package.json @@ -0,0 +1,14 @@ +{ + "name": "@openzeppelin/defender-sdk-example-key-value-store-local", + "version": "1.14.2", + "private": true, + "main": "index.js", + "author": "OpenZeppelin Defender ", + "license": "MIT", + "scripts": { + "start": "node index.js" + }, + "dependencies": { + "@openzeppelin/defender-sdk": "1.14.2" + } +} diff --git a/examples/key-value-store-local/store.json b/examples/key-value-store-local/store.json new file mode 100644 index 00000000..0967ef42 --- /dev/null +++ b/examples/key-value-store-local/store.json @@ -0,0 +1 @@ +{} diff --git a/packages/base/src/api/api.ts b/packages/base/src/api/api.ts index cec7e9d5..ec22f921 100644 --- a/packages/base/src/api/api.ts +++ b/packages/base/src/api/api.ts @@ -1,4 +1,3 @@ -import { CognitoUserSession } from 'amazon-cognito-identity-js'; import axios, { AxiosError, AxiosInstance } from 'axios'; import https from 'https'; diff --git a/packages/base/src/index.ts b/packages/base/src/index.ts index 4ddc8565..7cf6393f 100644 --- a/packages/base/src/index.ts +++ b/packages/base/src/index.ts @@ -1,6 +1,7 @@ export { createApi, createAuthenticatedApi } from './api/api'; export { authenticate } from './api/auth'; export { BaseApiClient, RetryConfig, AuthConfig } from './api/client'; +export { BaseActionClient } from './action'; export * from './utils/network'; // eslint-disable-next-line @typescript-eslint/no-var-requires diff --git a/packages/defender-sdk/package.json b/packages/defender-sdk/package.json index 009fac55..3db062a6 100644 --- a/packages/defender-sdk/package.json +++ b/packages/defender-sdk/package.json @@ -29,7 +29,8 @@ "@openzeppelin/defender-sdk-notification-channel-client": "^1.14.2", "@openzeppelin/defender-sdk-relay-signer-client": "^1.14.2", "@openzeppelin/defender-sdk-network-client": "^1.14.2", - "@openzeppelin/defender-sdk-account-client": "^1.14.2" + "@openzeppelin/defender-sdk-account-client": "^1.14.2", + "@openzeppelin/defender-sdk-key-value-store-client": "^1.14.2" }, "publishConfig": { "access": "public" diff --git a/packages/defender-sdk/src/index.ts b/packages/defender-sdk/src/index.ts index 54617361..4ec6560e 100644 --- a/packages/defender-sdk/src/index.ts +++ b/packages/defender-sdk/src/index.ts @@ -6,13 +6,19 @@ import { DeployClient } from '@openzeppelin/defender-sdk-deploy-client'; import { NotificationChannelClient } from '@openzeppelin/defender-sdk-notification-channel-client'; import { NetworkClient } from '@openzeppelin/defender-sdk-network-client'; import { AccountClient } from '@openzeppelin/defender-sdk-account-client'; +import { KeyValueStoreClient, LocalKeyValueStoreCreateParams } from '@openzeppelin/defender-sdk-key-value-store-client'; import { Newable, ClientParams } from './types'; import { ActionRelayerParams, Relayer as RelaySignerClient } from '@openzeppelin/defender-sdk-relay-signer-client'; import { ListNetworkRequestOptions } from '@openzeppelin/defender-sdk-network-client/lib/models/networks'; import { AuthConfig, Network, RetryConfig } from '@openzeppelin/defender-sdk-base-client'; import https from 'https'; -import { isRelaySignerOptions } from './utils'; +import { + isActionKVStoreCredentials, + isActionRelayerCredentials, + isApiCredentials, + isRelaySignerOptions, +} from './utils'; export interface DefenderOptions { apiKey?: string; @@ -24,12 +30,14 @@ export interface DefenderOptions { httpsAgent?: https.Agent; retryConfig?: RetryConfig; useCredentialsCaching?: boolean; + kvstoreARN?: string; } function getClient(Client: Newable, credentials: Partial | ActionRelayerParams): T { if ( - !('credentials' in credentials && 'relayerARN' in credentials) && - !('apiKey' in credentials && 'apiSecret' in credentials) + !isActionRelayerCredentials(credentials) && + !isApiCredentials(credentials) && + !isActionKVStoreCredentials(credentials) ) { throw new Error(`API key and secret are required`); } @@ -44,6 +52,7 @@ export class Defender { private relayerApiSecret: string | undefined; private actionCredentials: ActionRelayerParams | undefined; private actionRelayerArn: string | undefined; + private actionKVStoreArn: string | undefined; private httpsAgent?: https.Agent; private retryConfig?: RetryConfig; private authConfig?: AuthConfig; @@ -56,6 +65,7 @@ export class Defender { // support for using relaySigner from Defender Actions this.actionCredentials = options.credentials; this.actionRelayerArn = options.relayerARN; + this.actionKVStoreArn = options.kvstoreARN; this.httpsAgent = options.httpsAgent; this.retryConfig = options.retryConfig; this.authConfig = { @@ -165,4 +175,23 @@ export class Defender { ...(this.relayerApiSecret ? { apiSecret: this.relayerApiSecret } : undefined), }); } + + get keyValueStore() { + return getClient(KeyValueStoreClient, { + apiKey: this.apiKey, + apiSecret: this.apiSecret, + httpsAgent: this.httpsAgent, + retryConfig: this.retryConfig, + authConfig: this.authConfig, + ...(this.actionCredentials ? { credentials: this.actionCredentials } : undefined), + ...(this.actionKVStoreArn ? { kvstoreARN: this.actionKVStoreArn } : undefined), + }); + } + + static localKVStoreClient(params: LocalKeyValueStoreCreateParams) { + if (!params.path) { + throw new Error(`Must provide a path for local key-value store`); + } + return new KeyValueStoreClient(params); + } } diff --git a/packages/defender-sdk/src/types.ts b/packages/defender-sdk/src/types.ts index 6c3b73c0..7ce20371 100644 --- a/packages/defender-sdk/src/types.ts +++ b/packages/defender-sdk/src/types.ts @@ -9,4 +9,5 @@ export type ClientParams = { httpsAgent?: https.Agent; retryConfig?: RetryConfig; authConfig: AuthConfig; + path?: string; }; diff --git a/packages/defender-sdk/src/utils.ts b/packages/defender-sdk/src/utils.ts index 66d63bb5..e18be111 100644 --- a/packages/defender-sdk/src/utils.ts +++ b/packages/defender-sdk/src/utils.ts @@ -1,4 +1,6 @@ +import { ActionRelayerParams } from '@openzeppelin/defender-sdk-relay-signer-client'; import { DefenderOptions } from '.'; +import { ClientParams } from './types'; export function isRelaySignerOptions(options: DefenderOptions): boolean { return ( @@ -8,3 +10,15 @@ export function isRelaySignerOptions(options: DefenderOptions): boolean { options.relayerARN !== undefined ); } + +export function isActionRelayerCredentials(credentials: Partial | ActionRelayerParams): boolean { + return 'credentials' in credentials && 'relayerARN' in credentials; +} + +export function isApiCredentials(credentials: Partial | ActionRelayerParams): boolean { + return 'apiKey' in credentials && 'apiSecret' in credentials; +} + +export function isActionKVStoreCredentials(credentials: Partial | ActionRelayerParams): boolean { + return 'credentials' in credentials && 'kvstoreARN' in credentials; +} diff --git a/packages/kvstore/README.md b/packages/kvstore/README.md new file mode 100644 index 00000000..633da4f9 --- /dev/null +++ b/packages/kvstore/README.md @@ -0,0 +1,65 @@ +# Defender Key-Value Store for Actions + +The [Defender Actions](https://docs.openzeppelin.com/defender/v2/module/actions) service allows you to run small code snippets on a regular basis or via webhooks that can make calls to the Ethereum network or to external APIs. Thanks to tight integration to Defender Relayers, you can use Actions to automate regular operations on your contracts. + +This client allows you to access a simple key-value data store from your Actions code, so you can persist data throughout executions and across different Actions. + +_Note that this package will not work outisde the Actions environment._ + +## Installation + +This package is included in the latest Actions runtime environment, so you do not need to bundle it in your code. To install it for local development and typescript type completion, run: + +```bash +npm install @openzeppelin/defender-sdk-key-value-store +``` + +```bash +yarn add @openzeppelin/defender-sdk-key-value-store +``` + +## Usage + +You can interact with your key-value store through an instance of `Defender`, which is initialized with the payload injected in the your Action `handler` function. Once initialized, you can call `kvstore.get`, `kvstore.put`, or `kvstore.del`. + +```js +const { Defender } = require('@openzeppelin/defender-sdk'); + +exports.handler = async function (event) { + // Creates an instance of the key-value store client + const client = new Defender(event); + + // Associates myValue to myKey + await client.keyValueStore.put('myKey', 'myValue'); + + // Returns myValue associated to myKey + const value = await client.keyValueStore.get('myKey'); + + // Deletes the entry for myKey + await client.keyValueStore.del('myKey'); +}; +``` + +## Local development + +The Defender key-value store is only accessible from within an Action. To simplify local development, you can create an instance using `Defender.localKVStoreClient` providing an object with a `path` property. The client will use a local json file at that path for all operations. + +```js +const { Defender } = require('@openzeppelin/defender-sdk'); + +async function local() { + // Creates an instance of the client that will write to a local file + const store = Defender.localKVStoreClient({ path: '/tmp/foo/store.json' }); + + // The store.json file will contain { myKey: myValue } + await store.put('myKey', 'myValue'); +} +``` + +## Considerations + +- All data in the key-value store is persisted as strings, both keys and values. +- Keys are limited to 1kb in size, and values to 300kb. +- The data store is shared across all your Actions; consider prefixing the keys with a namespace if you want to have different data buckets. +- A key-value entry is expired after 90 days of the last time it was `put` into the store. +- The total number of key-value records in your store is determined by your Defender plan. diff --git a/packages/kvstore/__mocks__/@aws-sdk/client-lambda.ts b/packages/kvstore/__mocks__/@aws-sdk/client-lambda.ts new file mode 100644 index 00000000..33d1b188 --- /dev/null +++ b/packages/kvstore/__mocks__/@aws-sdk/client-lambda.ts @@ -0,0 +1,11 @@ +const Lambda = jest.fn(() => ({ + invoke: jest.fn(() => + Promise.resolve({ + Payload: { + transformToString: () => JSON.stringify({ result: 'result' }), + }, + }), + ), +})); + +export { Lambda }; diff --git a/packages/kvstore/__mocks__/aws-sdk/clients/lambda.ts b/packages/kvstore/__mocks__/aws-sdk/clients/lambda.ts new file mode 100644 index 00000000..554dac45 --- /dev/null +++ b/packages/kvstore/__mocks__/aws-sdk/clients/lambda.ts @@ -0,0 +1,11 @@ +const mock = jest.fn(() => ({ + invoke: jest.fn(() => ({ + promise: jest.fn(() => + Promise.resolve({ + Payload: JSON.stringify({ result: 'result' }), + }), + ), + })), +})); + +export default mock; diff --git a/packages/kvstore/jest.config.js b/packages/kvstore/jest.config.js new file mode 100644 index 00000000..990bd442 --- /dev/null +++ b/packages/kvstore/jest.config.js @@ -0,0 +1 @@ +module.exports = require('../../jest.config'); diff --git a/packages/kvstore/package.json b/packages/kvstore/package.json new file mode 100644 index 00000000..32a4b1eb --- /dev/null +++ b/packages/kvstore/package.json @@ -0,0 +1,34 @@ +{ + "name": "@openzeppelin/defender-sdk-key-value-store-client", + "version": "1.14.2", + "description": "", + "main": "./lib/index.js", + "types": "./lib/index.d.ts", + "scripts": { + "build": "rm -rf lib && tsc", + "test": "npm run test:unit", + "test:unit": "jest --verbose --passWithNoTests --forceExit", + "watch": "tsc -w" + }, + "files": [ + "lib", + "!*.test.js", + "!*.test.js.map", + "!*.test.d.ts", + "!*__mocks__" + ], + "author": "OpenZeppelin Defender ", + "license": "MIT", + "dependencies": { + "@openzeppelin/defender-sdk-base-client": "^1.14.2", + "axios": "^1.7.2", + "lodash": "^4.17.21", + "fs-extra": "^11.2.0" + }, + "devDependencies": { + "@types/fs-extra": "^11.0.4" + }, + "publishConfig": { + "access": "public" + } +} diff --git a/packages/kvstore/src/action.test.ts b/packages/kvstore/src/action.test.ts new file mode 100644 index 00000000..21fb8f41 --- /dev/null +++ b/packages/kvstore/src/action.test.ts @@ -0,0 +1,67 @@ +import { KeyValueStoreActionClient } from './action'; +import Lambda from '../__mocks__/aws-sdk/clients/lambda'; +import { Lambda as LambdaV3 } from '../__mocks__/@aws-sdk/client-lambda'; +jest.mock('node:process', () => ({ + ...jest.requireActual('node:process'), + version: 'v16.0.3', +})); + +type TestClient = Omit & { lambda: typeof Lambda }; + +describe('KeyValueStoreAutotaskClient', () => { + const credentials = { + AccessKeyId: 'keyId', + SecretAccessKey: 'accessKey', + SessionToken: 'token', + }; + + let client: TestClient; + + beforeEach(async function () { + jest.mock('aws-sdk/clients/lambda', () => Lambda); + jest.mock('@aws-sdk/client-lambda', () => ({ Lambda: LambdaV3 })); + client = new KeyValueStoreActionClient({ + credentials: JSON.stringify(credentials), + kvstoreARN: 'arn', + }) as unknown as TestClient; + }); + + describe('get', () => { + test('calls kvstore function', async () => { + ((client.lambda as any).invoke as jest.Mock).mockImplementationOnce(() => ({ + promise: () => Promise.resolve({ Payload: JSON.stringify('myvalue') }), + })); + + const result = await client.get('mykey'); + + expect(result).toEqual('myvalue'); + expect((client.lambda as any).invoke).toBeCalledWith({ + FunctionName: 'arn', + InvocationType: 'RequestResponse', + Payload: '{"action":"get","key":"mykey"}', + }); + }); + }); + + describe('del', () => { + test('calls kvstore function', async () => { + await client.del('mykey'); + expect((client.lambda as any).invoke).toBeCalledWith({ + FunctionName: 'arn', + InvocationType: 'RequestResponse', + Payload: '{"action":"del","key":"mykey"}', + }); + }); + }); + + describe('put', () => { + test('calls kvstore function', async () => { + await client.put('mykey', 'myvalue'); + expect((client.lambda as any).invoke).toBeCalledWith({ + FunctionName: 'arn', + InvocationType: 'RequestResponse', + Payload: '{"action":"put","key":"mykey","value":"myvalue"}', + }); + }); + }); +}); diff --git a/packages/kvstore/src/action.ts b/packages/kvstore/src/action.ts new file mode 100644 index 00000000..22de89f5 --- /dev/null +++ b/packages/kvstore/src/action.ts @@ -0,0 +1,23 @@ +import { IKeyValueStoreClient, KeyValueStoreCreateParams, KeyValueStoreRequest } from './types'; +import { BaseActionClient } from '@openzeppelin/defender-sdk-base-client'; + +export class KeyValueStoreActionClient extends BaseActionClient implements IKeyValueStoreClient { + public constructor(params: KeyValueStoreCreateParams) { + super(params.credentials, params.kvstoreARN); + } + + public async get(key: string): Promise { + const request: KeyValueStoreRequest = { action: 'get', key }; + return this.execute(request); + } + + public async put(key: string, value: string): Promise { + const request: KeyValueStoreRequest = { action: 'put', key, value }; + return this.execute(request); + } + + public async del(key: string): Promise { + const request: KeyValueStoreRequest = { action: 'del', key }; + return this.execute(request); + } +} diff --git a/packages/kvstore/src/index.test.ts b/packages/kvstore/src/index.test.ts new file mode 100644 index 00000000..5a9fe3b5 --- /dev/null +++ b/packages/kvstore/src/index.test.ts @@ -0,0 +1,53 @@ +import { KeyValueStoreClient, KeyValueStoreCreateParams } from '.'; +import { KeyValueStoreActionClient } from './action'; +import { KeyValueStoreLocalClient } from './local'; +import { IKeyValueStoreClient } from './types'; + +class TestClient extends KeyValueStoreClient { + public getImplementation(): IKeyValueStoreClient { + return this.implementation; + } +} + +describe('KeyValueStoreClient', () => { + describe('create', () => { + test('creates a local client', async () => { + const client = new TestClient({ path: '/tmp/foo' }); + expect(client.getImplementation()).toBeInstanceOf(KeyValueStoreLocalClient); + }); + + test('creates an autotask client', async () => { + const credentials = JSON.stringify({ + AccessKeyId: 'keyId', + SecretAccessKey: 'accessKey', + SessionToken: 'token', + }); + + const client = new TestClient({ credentials, kvstoreARN: 'bar' }); + expect(client.getImplementation()).toBeInstanceOf(KeyValueStoreActionClient); + }); + + test('fails to create a client', async () => { + expect(() => { + new TestClient({} as KeyValueStoreCreateParams); + }).toThrowError(/Invalid create params/i); + }); + }); + + describe('validate', () => { + let client: TestClient; + beforeEach(() => { + client = new TestClient({ path: '/tmp/foo' }); + }); + + test('validates length', async () => { + await expect(() => client.put('a'.repeat(1025), 'myvalue')).rejects.toThrowError(/key size/i); + await expect(() => client.put('mykey', 'a'.repeat(300 * 1024 + 1))).rejects.toThrowError(/value size/i); + }); + + test('validates type', async () => { + await expect(() => client.put(42 as unknown as string, 'myvalue')).rejects.toThrowError(/string/i); + await expect(() => client.put('mykey', 42 as unknown as string)).rejects.toThrowError(/string/i); + }); + }); +}); diff --git a/packages/kvstore/src/index.ts b/packages/kvstore/src/index.ts new file mode 100644 index 00000000..ba406c01 --- /dev/null +++ b/packages/kvstore/src/index.ts @@ -0,0 +1,47 @@ +import { + IKeyValueStoreClient, + isActionCreateParams, + isLocalCreateParams, + KeyValueStoreCreateParams, + LocalKeyValueStoreCreateParams, +} from './types'; + +export { KeyValueStoreCreateParams, LocalKeyValueStoreCreateParams }; + +export class KeyValueStoreClient implements IKeyValueStoreClient { + protected implementation: IKeyValueStoreClient; + + public constructor(params: KeyValueStoreCreateParams | LocalKeyValueStoreCreateParams) { + if (isActionCreateParams(params)) { + // eslint-disable-next-line @typescript-eslint/no-var-requires + const { KeyValueStoreActionClient } = require('./action'); + this.implementation = new KeyValueStoreActionClient(params); + } else if (isLocalCreateParams(params)) { + // eslint-disable-next-line @typescript-eslint/no-var-requires + const { KeyValueStoreLocalClient } = require('./local'); + this.implementation = new KeyValueStoreLocalClient(params); + } else { + throw new Error(`Invalid create params for KeyValueStoreClient`); + } + } + + public async get(key: string): Promise { + return this.implementation.get(key); + } + + public async put(key: string, value: string): Promise { + if (typeof key !== 'string') throw new Error(`Key must be a string`); + if (value && typeof value !== 'string') throw new Error(`Value must be a string`); + if (key.length > 1024) throw new Error(`Key size cannot exceed 1024 characters`); + if (value && value.length > 300 * 1024) throw new Error(`Value size cannot exceed 300 KB`); + + return this.implementation.put(key, value); + } + + public async del(key: string): Promise { + return this.implementation.del(key); + } +} + +// eslint-disable-next-line @typescript-eslint/no-var-requires +export const VERSION = require('../package.json').version; diff --git a/packages/kvstore/src/local.test.ts b/packages/kvstore/src/local.test.ts new file mode 100644 index 00000000..7f1ba673 --- /dev/null +++ b/packages/kvstore/src/local.test.ts @@ -0,0 +1,61 @@ +import { KeyValueStoreLocalClient } from './local'; +import { mkdtempSync } from 'fs'; +import { join } from 'path'; +import { tmpdir } from 'os'; + +describe('KeyValueStoreLocalClient', () => { + let client: KeyValueStoreLocalClient; + let path: string; + + beforeEach(async function () { + const dir = mkdtempSync(join(tmpdir(), 'defender-client-kvstore-test-')); + path = join(dir, 'store.json'); + client = new KeyValueStoreLocalClient({ path }); + }); + + test('reads from an empty store', async () => { + const value = await client.get('foo'); + expect(value).toBeUndefined(); + }); + + test('puts then gets', async () => { + await client.put('foo', 'bar'); + expect(await client.get('foo')).toEqual('bar'); + }); + + test('multiple puts', async () => { + await client.put('foo1', 'bar1'); + await client.put('foo2', 'bar2'); + await client.put('foo3', 'bar3'); + + expect(await client.get('foo1')).toEqual('bar1'); + }); + + test('apparently concurrent puts', async () => { + await Promise.all([client.put('foo1', 'bar1'), client.put('foo2', 'bar2'), client.put('foo3', 'bar3')]); + + expect(await client.get('foo1')).toEqual('bar1'); + expect(await client.get('foo2')).toEqual('bar2'); + expect(await client.get('foo3')).toEqual('bar3'); + }); + + test('overwrites', async () => { + await client.put('foo', 'bar'); + await client.put('foo', 'baz'); + const value = await client.get('foo'); + expect(value).toEqual('baz'); + }); + + test('deletes a key', async () => { + await client.put('foo', 'bar'); + await client.del('foo'); + const value = await client.get('foo'); + expect(value).toBeUndefined(); + }); + + test('deletes non-existing key', async () => { + await client.del('foo'); + const value = await client.get('foo'); + expect(value).toBeUndefined(); + }); +}); diff --git a/packages/kvstore/src/local.ts b/packages/kvstore/src/local.ts new file mode 100644 index 00000000..f589a089 --- /dev/null +++ b/packages/kvstore/src/local.ts @@ -0,0 +1,43 @@ +import { ensureFileSync, readJsonSync, writeJsonSync } from 'fs-extra'; +import { IKeyValueStoreClient, LocalKeyValueStoreCreateParams } from './types'; + +type Store = Record; + +/** + * Uses a local file for representing the store as a JSON. All fs operations + * are synchronous to prevent race conditions on put/del operations. + */ +export class KeyValueStoreLocalClient implements IKeyValueStoreClient { + protected path: string; + + public constructor(params: LocalKeyValueStoreCreateParams) { + this.path = params.path; + } + + public async get(key: string): Promise { + return this.getStore()[key]; + } + + public async put(key: string, value: string): Promise { + this.updateStore((store) => { + store[key] = value; + }); + } + + public async del(key: string): Promise { + this.updateStore((store) => { + delete store[key]; + }); + } + + protected getStore(): Store { + return readJsonSync(this.path, { throws: false }) ?? {}; + } + + protected updateStore(updater: (store: Store) => void) { + const store = this.getStore(); + updater(store); + ensureFileSync(this.path); + writeJsonSync(this.path, store, { spaces: 2 }); + } +} diff --git a/packages/kvstore/src/types.ts b/packages/kvstore/src/types.ts new file mode 100644 index 00000000..b1a77b3a --- /dev/null +++ b/packages/kvstore/src/types.ts @@ -0,0 +1,29 @@ +export type KeyValueStoreCreateParams = { + credentials: string; + kvstoreARN: string; +}; + +export type LocalKeyValueStoreCreateParams = { + path: string; +}; + +export function isLocalCreateParams(params: any): params is LocalKeyValueStoreCreateParams { + return !!params && !!(params as LocalKeyValueStoreCreateParams).path; +} + +export function isActionCreateParams(params: any): params is KeyValueStoreCreateParams { + const asCreateParams = params as KeyValueStoreCreateParams; + return !!params && !!asCreateParams.credentials && !!asCreateParams.kvstoreARN; +} + +export interface KeyValueStoreRequest { + action: 'put' | 'get' | 'del'; + key: string; + value?: string; +} + +export interface IKeyValueStoreClient { + get(key: string): Promise; + put(key: string, value: string): Promise; + del(key: string): Promise; +} diff --git a/packages/kvstore/tsconfig.json b/packages/kvstore/tsconfig.json new file mode 100644 index 00000000..09f1bb8c --- /dev/null +++ b/packages/kvstore/tsconfig.json @@ -0,0 +1,11 @@ +{ + "extends": "code-style/tsconfig.json", + "compilerOptions": { + "declaration": true, + "outDir": "./lib", + "skipLibCheck": true, + "sourceMap": false + }, + "include": ["./src"], + "exclude": ["**/*.test.ts", "**/__mocks__/*"] +} diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 67ad58af..a3b52859 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -82,6 +82,316 @@ importers: specifier: ^4.9.3 version: 4.9.5 + examples/create-action: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-batch-proposal: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-forked-network: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-monitor: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-private-network: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-proposal: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-relayer: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/create-relayer-key: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/custom-ethers-pkg: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + '@openzeppelin/defender-sdk-action-client': + specifier: 1.14.2 + version: link:../../packages/action + dotenv: + specifier: ^16.4.5 + version: 16.4.5 + ethers: + specifier: ^6.9.0 + version: 6.9.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + devDependencies: + '@rollup/plugin-commonjs': + specifier: ^25.0.8 + version: 25.0.8(rollup@4.19.0) + '@rollup/plugin-json': + specifier: ^6.1.0 + version: 6.1.0(rollup@4.19.0) + '@rollup/plugin-node-resolve': + specifier: ^15.2.3 + version: 15.2.3(rollup@4.19.0) + '@rollup/plugin-typescript': + specifier: ^11.1.6 + version: 11.1.6(rollup@4.19.0)(tslib@2.6.3)(typescript@5.4.5) + '@types/node': + specifier: ^20.12.13 + version: 20.12.13 + builtin-modules: + specifier: ^4.0.0 + version: 4.0.0 + rollup: + specifier: ^4.18.0 + version: 4.19.0 + tslib: + specifier: ^2.6.3 + version: 2.6.3 + typescript: + specifier: ^5.4.5 + version: 5.4.5 + + examples/deploy-contract: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + ethers: + specifier: ^6.9.0 + version: 6.9.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + + examples/ethers-signer-v5: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + ethers: + specifier: ^5.6.1 + version: 5.7.2 + + examples/ethers-signer-v6: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + ethers: + specifier: ^6.9.0 + version: 6.9.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + + examples/get-usage: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/key-value-store-local: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + + examples/list-contracts: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/list-networks: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/list-proposals: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/relayer-call-contract-function: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + ethers: + specifier: ^6.9.0 + version: 6.9.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + + examples/relayer-load-balance: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/relayer-signer-actions: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/relayer-signer-auth-v2: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/relayer-web3-provider: + dependencies: + '@openzeppelin/defender-sdk-relay-signer-client': + specifier: 1.14.2 + version: link:../../packages/relay-signer + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + web3: + specifier: ^1.10.0 + version: 1.10.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + + examples/simulate-proposal: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + ethers: + specifier: ^6.9.0 + version: 6.9.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + + examples/update-action: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/update-action-env-variables: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/update-monitor: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/update-relayer: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/upgrade-contract: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + + examples/webhook-notification: + dependencies: + '@openzeppelin/defender-sdk': + specifier: 1.14.2 + version: link:../../packages/defender-sdk + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + packages/account: dependencies: '@openzeppelin/defender-sdk-base-client': @@ -148,6 +458,9 @@ importers: '@openzeppelin/defender-sdk-deploy-client': specifier: ^1.14.2 version: link:../deploy + '@openzeppelin/defender-sdk-key-value-store-client': + specifier: ^1.14.2 + version: link:../kvstore '@openzeppelin/defender-sdk-monitor-client': specifier: ^1.14.2 version: link:../monitor @@ -179,6 +492,25 @@ importers: specifier: ^4.17.21 version: 4.17.21 + packages/kvstore: + dependencies: + '@openzeppelin/defender-sdk-base-client': + specifier: ^1.14.2 + version: link:../base + axios: + specifier: ^1.7.2 + version: 1.7.2 + fs-extra: + specifier: ^11.2.0 + version: 11.2.0 + lodash: + specifier: ^4.17.21 + version: 4.17.21 + devDependencies: + '@types/fs-extra': + specifier: ^11.0.4 + version: 11.0.4 + packages/monitor: dependencies: '@openzeppelin/defender-sdk-base-client': @@ -757,9 +1089,18 @@ packages: '@ethersproject/constants@5.7.0': resolution: {integrity: sha512-DHI+y5dBNvkpYUMiRQyxRBYBefZkJfo70VUkUAsRjcPs47muV9evftfZ0PJVCXYbAiCgght0DtcF9srFQmIgWA==} + '@ethersproject/contracts@5.7.0': + resolution: {integrity: sha512-5GJbzEU3X+d33CdfPhcyS+z8MzsTrBGk/sc+G+59+tPa9yFkl6HQ9D6L0QMgNTA9q8dT0XKxxkyp883XsQvbbg==} + '@ethersproject/hash@5.7.0': resolution: {integrity: sha512-qX5WrQfnah1EFnO5zJv1v46a8HW0+E5xuBBDTwMFZLuVTx0tbU2kkx15NqdjxecrLGatQN9FGQKpb1FKdHCt+g==} + '@ethersproject/hdnode@5.7.0': + resolution: {integrity: sha512-OmyYo9EENBPPf4ERhR7oj6uAtUAhYGqOnIS+jE5pTXvdKBS99ikzq1E7Iv0ZQZ5V36Lqx1qZLeak0Ra16qpeOg==} + + '@ethersproject/json-wallets@5.7.0': + resolution: {integrity: sha512-8oee5Xgu6+RKgJTkvEMl2wDgSPSAQ9MB/3JYjFV9jlKvcYHUXZC+cQp0njgmxdHkYWn8s6/IqIZYm0YWCjO/0g==} + '@ethersproject/keccak256@5.7.0': resolution: {integrity: sha512-2UcPboeL/iW+pSg6vZ6ydF8tCnv3Iu/8tUmLLzWWGzxWKFFqOBQFLo6uLUv6BDrLgCDfN28RJ/wtByx+jZ4KBg==} @@ -769,6 +1110,9 @@ packages: '@ethersproject/networks@5.7.1': resolution: {integrity: sha512-n/MufjFYv3yFcUyfhnXotyDlNdFb7onmkSy8aQERi2PjNcnWQ66xXxa3XlS8nCcA8aJKJjIIMNJTC7tu80GwpQ==} + '@ethersproject/pbkdf2@5.7.0': + resolution: {integrity: sha512-oR/dBRZR6GTyaofd86DehG72hY6NpAjhabkhxgr3X2FpJtJuodEl2auADWBZfhDHgVCbu3/H/Ocq2uC6dpNjjw==} + '@ethersproject/properties@5.7.0': resolution: {integrity: sha512-J87jy8suntrAkIZtecpxEPxY//szqr1mlBaYlQ0r4RCaiD2hjheqF9s1LVE8vVuJCXisjIP+JgtK/Do54ej4Sw==} @@ -787,15 +1131,27 @@ packages: '@ethersproject/signing-key@5.7.0': resolution: {integrity: sha512-MZdy2nL3wO0u7gkB4nA/pEf8lu1TlFswPNmy8AiYkfKTdO6eXBJyUdmHO/ehm/htHw9K/qF8ujnTyUAD+Ry54Q==} + '@ethersproject/solidity@5.7.0': + resolution: {integrity: sha512-HmabMd2Dt/raavyaGukF4XxizWKhKQ24DoLtdNbBmNKUOPqwjsKQSdV9GQtj9CBEea9DlzETlVER1gYeXXBGaA==} + '@ethersproject/strings@5.7.0': resolution: {integrity: sha512-/9nu+lj0YswRNSH0NXYqrh8775XNyEdUQAuf3f+SmOrnVewcJ5SBNAjF7lpgehKi4abvNNXyf+HX86czCdJ8Mg==} '@ethersproject/transactions@5.7.0': resolution: {integrity: sha512-kmcNicCp1lp8qanMTC3RIikGgoJ80ztTyvtsFvCYpSCfkjhD0jZ2LOrnbcuxuToLIUYYf+4XwD1rP+B/erDIhQ==} + '@ethersproject/units@5.7.0': + resolution: {integrity: sha512-pD3xLMy3SJu9kG5xDGI7+xhTEmGXlEqXU4OfNapmfnxLVY4EMSSRp7j1k7eezutBPH7RBN/7QPnwR7hzNlEFeg==} + + '@ethersproject/wallet@5.7.0': + resolution: {integrity: sha512-MhmXlJXEJFBFVKrDLB4ZdDzxcBxQ3rLyCkhNqVu3CDYvR97E+8r01UgrI+TI99Le+aYm/in/0vp86guJuM7FCA==} + '@ethersproject/web@5.7.1': resolution: {integrity: sha512-Gueu8lSvyjBWL4cYsWsjh6MtMwM0+H4HvqFPZfB6dV8ctbP9zFAO73VG1cMWae0FLPCtz0peKPpZY8/ugJJX2w==} + '@ethersproject/wordlists@5.7.0': + resolution: {integrity: sha512-S2TFNJNfHWVHNE6cNDjbVlZ6MgE17MIxMbMg2zv3wn+3XSJGosL1m9ZVv3GXCf/2ymSsQ+hRI5IzoMJTG6aoVA==} + '@humanwhocodes/config-array@0.11.14': resolution: {integrity: sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==} engines: {node: '>=10.10.0'} @@ -1024,6 +1380,135 @@ packages: resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==} engines: {node: '>=14'} + '@rollup/plugin-commonjs@25.0.8': + resolution: {integrity: sha512-ZEZWTK5n6Qde0to4vS9Mr5x/0UZoqCxPVR9KRUjU4kA2sO7GEUn1fop0DAwpO6z0Nw/kJON9bDmSxdWxO/TT1A==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^2.68.0||^3.0.0||^4.0.0 + peerDependenciesMeta: + rollup: + optional: true + + '@rollup/plugin-json@6.1.0': + resolution: {integrity: sha512-EGI2te5ENk1coGeADSIwZ7G2Q8CJS2sF120T7jLw4xFw9n7wIOXHo+kIYRAoVpJAN+kmqZSoO3Fp4JtoNF4ReA==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^1.20.0||^2.0.0||^3.0.0||^4.0.0 + peerDependenciesMeta: + rollup: + optional: true + + '@rollup/plugin-node-resolve@15.2.3': + resolution: {integrity: sha512-j/lym8nf5E21LwBT4Df1VD6hRO2L2iwUeUmP7litikRsVp1H6NWx20NEp0Y7su+7XGc476GnXXc4kFeZNGmaSQ==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^2.78.0||^3.0.0||^4.0.0 + peerDependenciesMeta: + rollup: + optional: true + + '@rollup/plugin-typescript@11.1.6': + resolution: {integrity: sha512-R92yOmIACgYdJ7dJ97p4K69I8gg6IEHt8M7dUBxN3W6nrO8uUxX5ixl0yU/N3aZTi8WhPuICvOHXQvF6FaykAA==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^2.14.0||^3.0.0||^4.0.0 + tslib: '*' + typescript: '>=3.7.0' + peerDependenciesMeta: + rollup: + optional: true + tslib: + optional: true + + '@rollup/pluginutils@5.1.0': + resolution: {integrity: sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^1.20.0||^2.0.0||^3.0.0||^4.0.0 + peerDependenciesMeta: + rollup: + optional: true + + '@rollup/rollup-android-arm-eabi@4.19.0': + resolution: {integrity: sha512-JlPfZ/C7yn5S5p0yKk7uhHTTnFlvTgLetl2VxqE518QgyM7C9bSfFTYvB/Q/ftkq0RIPY4ySxTz+/wKJ/dXC0w==} + cpu: [arm] + os: [android] + + '@rollup/rollup-android-arm64@4.19.0': + resolution: {integrity: sha512-RDxUSY8D1tWYfn00DDi5myxKgOk6RvWPxhmWexcICt/MEC6yEMr4HNCu1sXXYLw8iAsg0D44NuU+qNq7zVWCrw==} + cpu: [arm64] + os: [android] + + '@rollup/rollup-darwin-arm64@4.19.0': + resolution: {integrity: sha512-emvKHL4B15x6nlNTBMtIaC9tLPRpeA5jMvRLXVbl/W9Ie7HhkrE7KQjvgS9uxgatL1HmHWDXk5TTS4IaNJxbAA==} + cpu: [arm64] + os: [darwin] + + '@rollup/rollup-darwin-x64@4.19.0': + resolution: {integrity: sha512-fO28cWA1dC57qCd+D0rfLC4VPbh6EOJXrreBmFLWPGI9dpMlER2YwSPZzSGfq11XgcEpPukPTfEVFtw2q2nYJg==} + cpu: [x64] + os: [darwin] + + '@rollup/rollup-linux-arm-gnueabihf@4.19.0': + resolution: {integrity: sha512-2Rn36Ubxdv32NUcfm0wB1tgKqkQuft00PtM23VqLuCUR4N5jcNWDoV5iBC9jeGdgS38WK66ElncprqgMUOyomw==} + cpu: [arm] + os: [linux] + + '@rollup/rollup-linux-arm-musleabihf@4.19.0': + resolution: {integrity: sha512-gJuzIVdq/X1ZA2bHeCGCISe0VWqCoNT8BvkQ+BfsixXwTOndhtLUpOg0A1Fcx/+eA6ei6rMBzlOz4JzmiDw7JQ==} + cpu: [arm] + os: [linux] + + '@rollup/rollup-linux-arm64-gnu@4.19.0': + resolution: {integrity: sha512-0EkX2HYPkSADo9cfeGFoQ7R0/wTKb7q6DdwI4Yn/ULFE1wuRRCHybxpl2goQrx4c/yzK3I8OlgtBu4xvted0ug==} + cpu: [arm64] + os: [linux] + + '@rollup/rollup-linux-arm64-musl@4.19.0': + resolution: {integrity: sha512-GlIQRj9px52ISomIOEUq/IojLZqzkvRpdP3cLgIE1wUWaiU5Takwlzpz002q0Nxxr1y2ZgxC2obWxjr13lvxNQ==} + cpu: [arm64] + os: [linux] + + '@rollup/rollup-linux-powerpc64le-gnu@4.19.0': + resolution: {integrity: sha512-N6cFJzssruDLUOKfEKeovCKiHcdwVYOT1Hs6dovDQ61+Y9n3Ek4zXvtghPPelt6U0AH4aDGnDLb83uiJMkWYzQ==} + cpu: [ppc64] + os: [linux] + + '@rollup/rollup-linux-riscv64-gnu@4.19.0': + resolution: {integrity: sha512-2DnD3mkS2uuam/alF+I7M84koGwvn3ZVD7uG+LEWpyzo/bq8+kKnus2EVCkcvh6PlNB8QPNFOz6fWd5N8o1CYg==} + cpu: [riscv64] + os: [linux] + + '@rollup/rollup-linux-s390x-gnu@4.19.0': + resolution: {integrity: sha512-D6pkaF7OpE7lzlTOFCB2m3Ngzu2ykw40Nka9WmKGUOTS3xcIieHe82slQlNq69sVB04ch73thKYIWz/Ian8DUA==} + cpu: [s390x] + os: [linux] + + '@rollup/rollup-linux-x64-gnu@4.19.0': + resolution: {integrity: sha512-HBndjQLP8OsdJNSxpNIN0einbDmRFg9+UQeZV1eiYupIRuZsDEoeGU43NQsS34Pp166DtwQOnpcbV/zQxM+rWA==} + cpu: [x64] + os: [linux] + + '@rollup/rollup-linux-x64-musl@4.19.0': + resolution: {integrity: sha512-HxfbvfCKJe/RMYJJn0a12eiOI9OOtAUF4G6ozrFUK95BNyoJaSiBjIOHjZskTUffUrB84IPKkFG9H9nEvJGW6A==} + cpu: [x64] + os: [linux] + + '@rollup/rollup-win32-arm64-msvc@4.19.0': + resolution: {integrity: sha512-HxDMKIhmcguGTiP5TsLNolwBUK3nGGUEoV/BO9ldUBoMLBssvh4J0X8pf11i1fTV7WShWItB1bKAKjX4RQeYmg==} + cpu: [arm64] + os: [win32] + + '@rollup/rollup-win32-ia32-msvc@4.19.0': + resolution: {integrity: sha512-xItlIAZZaiG/u0wooGzRsx11rokP4qyc/79LkAOdznGRAbOFc+SfEdfUOszG1odsHNgwippUJavag/+W/Etc6Q==} + cpu: [ia32] + os: [win32] + + '@rollup/rollup-win32-x64-msvc@4.19.0': + resolution: {integrity: sha512-xNo5fV5ycvCCKqiZcpB65VMR11NJB+StnxHz20jdqRAktfdfzhgjTiJ2doTDQE/7dqGaV5I7ZGqKpgph6lCIag==} + cpu: [x64] + os: [win32] + '@scure/base@1.1.3': resolution: {integrity: sha512-/+SgoRjLq7Xlf0CWuLHq2LUZeL/w65kfzAPG5NH9pcmBhs+nunQTn4gvdwgMTIXnt9b2C/1SeL2XiysZEyIC9Q==} @@ -1253,6 +1738,12 @@ packages: '@types/cacheable-request@6.0.3': resolution: {integrity: sha512-IQ3EbTzGxIigb1I3qPZc1rWJnH0BmSKv5QYTalEwweFvyBDLSAe24zP0le/hyi7ecGfZVlIVAg4BZqb8WBwKqw==} + '@types/estree@1.0.5': + resolution: {integrity: sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==} + + '@types/fs-extra@11.0.4': + resolution: {integrity: sha512-yTbItCNreRooED33qjunPthRcSjERP1r4MqCZc7wv0u2sUkzTFp45tgUfS5+r7FrZPdmCCNflLhVSP/o+SemsQ==} + '@types/glob@8.1.0': resolution: {integrity: sha512-IO+MJPVhoqz+28h1qLAcBEH2+xHMK6MTyHJc7MTnnYb6wsoLR29POVGJ7LycmVXIqyy/4/2ShP5sUwTXuOwb/w==} @@ -1277,6 +1768,9 @@ packages: '@types/json-schema@7.0.12': resolution: {integrity: sha512-Hr5Jfhc9eYOQNPYO5WLDq/n4jqijdHNlDXjuAQkkt+mWdQR+XJToOHrsD4cPaMXpn6KO7y2+wM8AZEs8VpBLVA==} + '@types/jsonfile@6.1.4': + resolution: {integrity: sha512-D5qGUYwjvnNNextdU59/+fI+spnwtTFmyQP0h+PfIOSkNfpU6AOICUOkm4i0OnSk+NyjdPJrxCDro0sJsWlRpQ==} + '@types/keyv@3.1.4': resolution: {integrity: sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg==} @@ -1298,6 +1792,9 @@ packages: '@types/pbkdf2@3.1.2': resolution: {integrity: sha512-uRwJqmiXmh9++aSu1VNEn3iIxWOhd8AHXNSdlaLfdAAdSTY9jYVeGWnzejM3dvrkbqE3/hyQkQQ29IFATEGlew==} + '@types/resolve@1.20.2': + resolution: {integrity: sha512-60BCwRFOZCQhDncwQdxxeOEEkbc5dIMccYLwbxsS4TUNeVECQ/pBJ0j09mrHOl/JJvpRPGwO9SvE4nR2Nb/a4Q==} + '@types/responselike@1.0.3': resolution: {integrity: sha512-H/+L+UkTV33uf49PH5pCAUBVPNj2nDBXTN+qS1dOwyyg24l3CcicicCA7ca+HMvJBZcFgl5r8e+RR6elsb4Lyw==} @@ -1408,6 +1905,9 @@ packages: engines: {node: '>=0.4.0'} hasBin: true + aes-js@3.0.0: + resolution: {integrity: sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw==} + aes-js@4.0.0-beta.5: resolution: {integrity: sha512-G965FqalsNyrPqgEGON7nIx1e/OVENSgiEIzyC63haUMuvNnwIgIjMs52hlTCKhkBny7A2ORNlfY9Zu+jmGk1Q==} @@ -1621,6 +2121,14 @@ packages: resolution: {integrity: sha512-4T53u4PdgsXqKaIctwF8ifXlRTTmEPJ8iEPWFdGZvcf7sbwYo6FKFEX9eNNAnzFZ7EzJAQ3CJeOtCRA4rDp7Pw==} engines: {node: '>=6.14.2'} + builtin-modules@3.3.0: + resolution: {integrity: sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==} + engines: {node: '>=6'} + + builtin-modules@4.0.0: + resolution: {integrity: sha512-p1n8zyCkt1BVrKNFymOHjcDSAl7oq/gUvfgULv2EblgpPVQlQr9yHnWjg9IJ2MhfwPqiYqMMrr01OY7yQoK2yA==} + engines: {node: '>=18.20'} + bytes@3.1.2: resolution: {integrity: sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==} engines: {node: '>= 0.8'} @@ -1743,6 +2251,9 @@ packages: resolution: {integrity: sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==} engines: {node: '>= 0.8'} + commondir@1.0.1: + resolution: {integrity: sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==} + concat-map@0.0.1: resolution: {integrity: sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==} @@ -2077,6 +2588,9 @@ packages: resolution: {integrity: sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==} engines: {node: '>=4.0'} + estree-walker@2.0.2: + resolution: {integrity: sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==} + esutils@2.0.3: resolution: {integrity: sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==} engines: {node: '>=0.10.0'} @@ -2107,6 +2621,9 @@ packages: resolution: {integrity: sha512-SDl5kKrQAudFBUe5OJM9Ac6WmMyYmXX/6sTmLZ3ffG2eY6ZIGBes3pEDxNN6V72WyOw4CPD5RomKdsa8DAAwLg==} engines: {node: '>=10.0.0'} + ethers@5.7.2: + resolution: {integrity: sha512-wswUsmWo1aOK8rR7DIKiWSw9DbLWe6x98Jrn8wcTflTVvaXhAMaB5zGAXy0GYQEQp9iO1iSHWVyARQm11zUtyg==} + ethers@6.9.0: resolution: {integrity: sha512-pmfNyQzc2mseLe91FnT2vmNaTt8dDzhxZ/xItAV7uGsF4dI4ek2ufMu3rAkgQETL/TIs0GS5A+U05g9QyWnv3Q==} engines: {node: '>=14.0.0'} @@ -2276,8 +2793,8 @@ packages: fs-constants@1.0.0: resolution: {integrity: sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==} - fs-extra@11.1.1: - resolution: {integrity: sha512-MGIE4HOvQCeUCzmlHs0vXpih4ysz4wg9qiSAu6cd42lVwPbTM1TjV7RusoyQqMmk/95gdQZX72u+YW+c3eEpFQ==} + fs-extra@11.2.0: + resolution: {integrity: sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==} engines: {node: '>=14.14'} fs-extra@4.0.3: @@ -2350,6 +2867,11 @@ packages: resolution: {integrity: sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==} deprecated: Glob versions prior to v9 are no longer supported + glob@8.1.0: + resolution: {integrity: sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==} + engines: {node: '>=12'} + deprecated: Glob versions prior to v9 are no longer supported + global@4.4.0: resolution: {integrity: sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w==} @@ -2516,6 +3038,10 @@ packages: is-arrayish@0.2.1: resolution: {integrity: sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==} + is-builtin-module@3.2.1: + resolution: {integrity: sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A==} + engines: {node: '>=6'} + is-callable@1.2.7: resolution: {integrity: sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==} engines: {node: '>= 0.4'} @@ -2559,6 +3085,9 @@ packages: resolution: {integrity: sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==} engines: {node: '>=8'} + is-module@1.0.0: + resolution: {integrity: sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g==} + is-number@7.0.0: resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==} engines: {node: '>=0.12.0'} @@ -2567,6 +3096,9 @@ packages: resolution: {integrity: sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==} engines: {node: '>=8'} + is-reference@1.2.1: + resolution: {integrity: sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==} + is-stream@2.0.1: resolution: {integrity: sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==} engines: {node: '>=8'} @@ -2931,6 +3463,9 @@ packages: lru-cache@5.1.1: resolution: {integrity: sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==} + magic-string@0.30.10: + resolution: {integrity: sha512-iIRwTIf0QKV3UAnYK4PU8uiEc4SRh5jX0mwpIwETPpHdhVM4f53RSwS/vXvN1JhGX+Cs7B8qIq3d6AH49O5fAQ==} + make-dir@3.1.0: resolution: {integrity: sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==} engines: {node: '>=8'} @@ -3010,6 +3545,10 @@ packages: minimatch@3.1.2: resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==} + minimatch@5.1.6: + resolution: {integrity: sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==} + engines: {node: '>=10'} + minimatch@9.0.3: resolution: {integrity: sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==} engines: {node: '>=16 || 14 >=14.17'} @@ -3486,6 +4025,11 @@ packages: resolution: {integrity: sha512-d5gdPmgQ0Z+AklL2NVXr/IoSjNZFfTVvQWzL/AM2AOcSzYP2xjlb0AC8YyCLc41MSNf6P6QVtjgPdmVtzb+4lQ==} hasBin: true + rollup@4.19.0: + resolution: {integrity: sha512-5r7EYSQIowHsK4eTZ0Y81qpZuJz+MUuYeqmmYmRMl1nwhdmbiYqt5jwzf6u7wyOzJgYqtCRMtVRKOtHANBz7rA==} + engines: {node: '>=18.0.0', npm: '>=8.0.0'} + hasBin: true + run-parallel@1.2.0: resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==} @@ -5067,6 +5611,19 @@ snapshots: dependencies: '@ethersproject/bignumber': 5.7.0 + '@ethersproject/contracts@5.7.0': + dependencies: + '@ethersproject/abi': 5.7.0 + '@ethersproject/abstract-provider': 5.7.0 + '@ethersproject/abstract-signer': 5.7.0 + '@ethersproject/address': 5.7.0 + '@ethersproject/bignumber': 5.7.0 + '@ethersproject/bytes': 5.7.0 + '@ethersproject/constants': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/properties': 5.7.0 + '@ethersproject/transactions': 5.7.0 + '@ethersproject/hash@5.7.0': dependencies: '@ethersproject/abstract-signer': 5.7.0 @@ -5079,6 +5636,37 @@ snapshots: '@ethersproject/properties': 5.7.0 '@ethersproject/strings': 5.7.0 + '@ethersproject/hdnode@5.7.0': + dependencies: + '@ethersproject/abstract-signer': 5.7.0 + '@ethersproject/basex': 5.7.0 + '@ethersproject/bignumber': 5.7.0 + '@ethersproject/bytes': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/pbkdf2': 5.7.0 + '@ethersproject/properties': 5.7.0 + '@ethersproject/sha2': 5.7.0 + '@ethersproject/signing-key': 5.7.0 + '@ethersproject/strings': 5.7.0 + '@ethersproject/transactions': 5.7.0 + '@ethersproject/wordlists': 5.7.0 + + '@ethersproject/json-wallets@5.7.0': + dependencies: + '@ethersproject/abstract-signer': 5.7.0 + '@ethersproject/address': 5.7.0 + '@ethersproject/bytes': 5.7.0 + '@ethersproject/hdnode': 5.7.0 + '@ethersproject/keccak256': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/pbkdf2': 5.7.0 + '@ethersproject/properties': 5.7.0 + '@ethersproject/random': 5.7.0 + '@ethersproject/strings': 5.7.0 + '@ethersproject/transactions': 5.7.0 + aes-js: 3.0.0 + scrypt-js: 3.0.1 + '@ethersproject/keccak256@5.7.0': dependencies: '@ethersproject/bytes': 5.7.0 @@ -5090,6 +5678,11 @@ snapshots: dependencies: '@ethersproject/logger': 5.7.0 + '@ethersproject/pbkdf2@5.7.0': + dependencies: + '@ethersproject/bytes': 5.7.0 + '@ethersproject/sha2': 5.7.0 + '@ethersproject/properties@5.7.0': dependencies: '@ethersproject/logger': 5.7.0 @@ -5145,6 +5738,15 @@ snapshots: elliptic: 6.5.4 hash.js: 1.1.7 + '@ethersproject/solidity@5.7.0': + dependencies: + '@ethersproject/bignumber': 5.7.0 + '@ethersproject/bytes': 5.7.0 + '@ethersproject/keccak256': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/sha2': 5.7.0 + '@ethersproject/strings': 5.7.0 + '@ethersproject/strings@5.7.0': dependencies: '@ethersproject/bytes': 5.7.0 @@ -5163,6 +5765,30 @@ snapshots: '@ethersproject/rlp': 5.7.0 '@ethersproject/signing-key': 5.7.0 + '@ethersproject/units@5.7.0': + dependencies: + '@ethersproject/bignumber': 5.7.0 + '@ethersproject/constants': 5.7.0 + '@ethersproject/logger': 5.7.0 + + '@ethersproject/wallet@5.7.0': + dependencies: + '@ethersproject/abstract-provider': 5.7.0 + '@ethersproject/abstract-signer': 5.7.0 + '@ethersproject/address': 5.7.0 + '@ethersproject/bignumber': 5.7.0 + '@ethersproject/bytes': 5.7.0 + '@ethersproject/hash': 5.7.0 + '@ethersproject/hdnode': 5.7.0 + '@ethersproject/json-wallets': 5.7.0 + '@ethersproject/keccak256': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/properties': 5.7.0 + '@ethersproject/random': 5.7.0 + '@ethersproject/signing-key': 5.7.0 + '@ethersproject/transactions': 5.7.0 + '@ethersproject/wordlists': 5.7.0 + '@ethersproject/web@5.7.1': dependencies: '@ethersproject/base64': 5.7.0 @@ -5171,6 +5797,14 @@ snapshots: '@ethersproject/properties': 5.7.0 '@ethersproject/strings': 5.7.0 + '@ethersproject/wordlists@5.7.0': + dependencies: + '@ethersproject/bytes': 5.7.0 + '@ethersproject/hash': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/properties': 5.7.0 + '@ethersproject/strings': 5.7.0 + '@humanwhocodes/config-array@0.11.14': dependencies: '@humanwhocodes/object-schema': 2.0.2 @@ -5487,6 +6121,99 @@ snapshots: '@pkgjs/parseargs@0.11.0': optional: true + '@rollup/plugin-commonjs@25.0.8(rollup@4.19.0)': + dependencies: + '@rollup/pluginutils': 5.1.0(rollup@4.19.0) + commondir: 1.0.1 + estree-walker: 2.0.2 + glob: 8.1.0 + is-reference: 1.2.1 + magic-string: 0.30.10 + optionalDependencies: + rollup: 4.19.0 + + '@rollup/plugin-json@6.1.0(rollup@4.19.0)': + dependencies: + '@rollup/pluginutils': 5.1.0(rollup@4.19.0) + optionalDependencies: + rollup: 4.19.0 + + '@rollup/plugin-node-resolve@15.2.3(rollup@4.19.0)': + dependencies: + '@rollup/pluginutils': 5.1.0(rollup@4.19.0) + '@types/resolve': 1.20.2 + deepmerge: 4.3.1 + is-builtin-module: 3.2.1 + is-module: 1.0.0 + resolve: 1.22.2 + optionalDependencies: + rollup: 4.19.0 + + '@rollup/plugin-typescript@11.1.6(rollup@4.19.0)(tslib@2.6.3)(typescript@5.4.5)': + dependencies: + '@rollup/pluginutils': 5.1.0(rollup@4.19.0) + resolve: 1.22.2 + typescript: 5.4.5 + optionalDependencies: + rollup: 4.19.0 + tslib: 2.6.3 + + '@rollup/pluginutils@5.1.0(rollup@4.19.0)': + dependencies: + '@types/estree': 1.0.5 + estree-walker: 2.0.2 + picomatch: 2.3.1 + optionalDependencies: + rollup: 4.19.0 + + '@rollup/rollup-android-arm-eabi@4.19.0': + optional: true + + '@rollup/rollup-android-arm64@4.19.0': + optional: true + + '@rollup/rollup-darwin-arm64@4.19.0': + optional: true + + '@rollup/rollup-darwin-x64@4.19.0': + optional: true + + '@rollup/rollup-linux-arm-gnueabihf@4.19.0': + optional: true + + '@rollup/rollup-linux-arm-musleabihf@4.19.0': + optional: true + + '@rollup/rollup-linux-arm64-gnu@4.19.0': + optional: true + + '@rollup/rollup-linux-arm64-musl@4.19.0': + optional: true + + '@rollup/rollup-linux-powerpc64le-gnu@4.19.0': + optional: true + + '@rollup/rollup-linux-riscv64-gnu@4.19.0': + optional: true + + '@rollup/rollup-linux-s390x-gnu@4.19.0': + optional: true + + '@rollup/rollup-linux-x64-gnu@4.19.0': + optional: true + + '@rollup/rollup-linux-x64-musl@4.19.0': + optional: true + + '@rollup/rollup-win32-arm64-msvc@4.19.0': + optional: true + + '@rollup/rollup-win32-ia32-msvc@4.19.0': + optional: true + + '@rollup/rollup-win32-x64-msvc@4.19.0': + optional: true + '@scure/base@1.1.3': {} '@scure/bip32@1.3.1': @@ -5846,6 +6573,13 @@ snapshots: '@types/node': 20.12.13 '@types/responselike': 1.0.3 + '@types/estree@1.0.5': {} + + '@types/fs-extra@11.0.4': + dependencies: + '@types/jsonfile': 6.1.4 + '@types/node': 20.12.13 + '@types/glob@8.1.0': dependencies: '@types/minimatch': 5.1.2 @@ -5874,6 +6608,10 @@ snapshots: '@types/json-schema@7.0.12': {} + '@types/jsonfile@6.1.4': + dependencies: + '@types/node': 20.12.13 + '@types/keyv@3.1.4': dependencies: '@types/node': 20.12.13 @@ -5894,6 +6632,8 @@ snapshots: dependencies: '@types/node': 20.12.13 + '@types/resolve@1.20.2': {} + '@types/responselike@1.0.3': dependencies: '@types/node': 20.12.13 @@ -6024,6 +6764,8 @@ snapshots: acorn@8.10.0: {} + aes-js@3.0.0: {} + aes-js@4.0.0-beta.5: {} ajv@6.12.6: @@ -6296,6 +7038,10 @@ snapshots: dependencies: node-gyp-build: 4.8.1 + builtin-modules@3.3.0: {} + + builtin-modules@4.0.0: {} + bytes@3.1.2: {} cacheable-lookup@5.0.4: {} @@ -6406,6 +7152,8 @@ snapshots: dependencies: delayed-stream: 1.0.0 + commondir@1.0.1: {} + concat-map@0.0.1: {} content-disposition@0.5.4: @@ -6749,6 +7497,8 @@ snapshots: estraverse@5.3.0: {} + estree-walker@2.0.2: {} + esutils@2.0.3: {} etag@1.8.1: {} @@ -6814,6 +7564,42 @@ snapshots: ethereum-cryptography: 0.1.3 rlp: 2.2.7 + ethers@5.7.2: + dependencies: + '@ethersproject/abi': 5.7.0 + '@ethersproject/abstract-provider': 5.7.0 + '@ethersproject/abstract-signer': 5.7.0 + '@ethersproject/address': 5.7.0 + '@ethersproject/base64': 5.7.0 + '@ethersproject/basex': 5.7.0 + '@ethersproject/bignumber': 5.7.0 + '@ethersproject/bytes': 5.7.0 + '@ethersproject/constants': 5.7.0 + '@ethersproject/contracts': 5.7.0 + '@ethersproject/hash': 5.7.0 + '@ethersproject/hdnode': 5.7.0 + '@ethersproject/json-wallets': 5.7.0 + '@ethersproject/keccak256': 5.7.0 + '@ethersproject/logger': 5.7.0 + '@ethersproject/networks': 5.7.1 + '@ethersproject/pbkdf2': 5.7.0 + '@ethersproject/properties': 5.7.0 + '@ethersproject/providers': 5.7.2(bufferutil@4.0.8)(utf-8-validate@5.0.10) + '@ethersproject/random': 5.7.0 + '@ethersproject/rlp': 5.7.0 + '@ethersproject/sha2': 5.7.0 + '@ethersproject/signing-key': 5.7.0 + '@ethersproject/solidity': 5.7.0 + '@ethersproject/strings': 5.7.0 + '@ethersproject/transactions': 5.7.0 + '@ethersproject/units': 5.7.0 + '@ethersproject/wallet': 5.7.0 + '@ethersproject/web': 5.7.1 + '@ethersproject/wordlists': 5.7.0 + transitivePeerDependencies: + - bufferutil + - utf-8-validate + ethers@6.9.0(bufferutil@4.0.8)(utf-8-validate@5.0.10): dependencies: '@adraffy/ens-normalize': 1.10.0 @@ -7043,7 +7829,7 @@ snapshots: fs-constants@1.0.0: {} - fs-extra@11.1.1: + fs-extra@11.2.0: dependencies: graceful-fs: 4.2.11 jsonfile: 6.1.0 @@ -7128,6 +7914,14 @@ snapshots: once: 1.4.0 path-is-absolute: 1.0.1 + glob@8.1.0: + dependencies: + fs.realpath: 1.0.0 + inflight: 1.0.6 + inherits: 2.0.4 + minimatch: 5.1.6 + once: 1.4.0 + global@4.4.0: dependencies: min-document: 2.19.0 @@ -7312,6 +8106,10 @@ snapshots: is-arrayish@0.2.1: {} + is-builtin-module@3.2.1: + dependencies: + builtin-modules: 3.3.0 + is-callable@1.2.7: {} is-core-module@2.12.1: @@ -7340,10 +8138,16 @@ snapshots: is-interactive@1.0.0: {} + is-module@1.0.0: {} + is-number@7.0.0: {} is-path-inside@3.0.3: {} + is-reference@1.2.1: + dependencies: + '@types/estree': 1.0.5 + is-stream@2.0.1: {} is-subdir@1.2.0: @@ -7910,6 +8714,10 @@ snapshots: dependencies: yallist: 3.1.1 + magic-string@0.30.10: + dependencies: + '@jridgewell/sourcemap-codec': 1.4.15 + make-dir@3.1.0: dependencies: semver: 7.6.2 @@ -7973,6 +8781,10 @@ snapshots: dependencies: brace-expansion: 1.1.11 + minimatch@5.1.6: + dependencies: + brace-expansion: 2.0.1 + minimatch@9.0.3: dependencies: brace-expansion: 2.0.1 @@ -8076,7 +8888,7 @@ snapshots: axios: 1.7.2 chalk: 4.1.2 dotenv: 10.0.0 - fs-extra: 11.1.1 + fs-extra: 11.2.0 node-machine-id: 1.1.12 open: 8.4.2 strip-json-comments: 3.1.1 @@ -8103,7 +8915,7 @@ snapshots: figures: 3.2.0 flat: 5.0.2 front-matter: 4.0.2 - fs-extra: 11.1.1 + fs-extra: 11.2.0 ignore: 5.2.4 jest-diff: 29.7.0 jsonc-parser: 3.2.0 @@ -8465,6 +9277,28 @@ snapshots: dependencies: bn.js: 5.2.1 + rollup@4.19.0: + dependencies: + '@types/estree': 1.0.5 + optionalDependencies: + '@rollup/rollup-android-arm-eabi': 4.19.0 + '@rollup/rollup-android-arm64': 4.19.0 + '@rollup/rollup-darwin-arm64': 4.19.0 + '@rollup/rollup-darwin-x64': 4.19.0 + '@rollup/rollup-linux-arm-gnueabihf': 4.19.0 + '@rollup/rollup-linux-arm-musleabihf': 4.19.0 + '@rollup/rollup-linux-arm64-gnu': 4.19.0 + '@rollup/rollup-linux-arm64-musl': 4.19.0 + '@rollup/rollup-linux-powerpc64le-gnu': 4.19.0 + '@rollup/rollup-linux-riscv64-gnu': 4.19.0 + '@rollup/rollup-linux-s390x-gnu': 4.19.0 + '@rollup/rollup-linux-x64-gnu': 4.19.0 + '@rollup/rollup-linux-x64-musl': 4.19.0 + '@rollup/rollup-win32-arm64-msvc': 4.19.0 + '@rollup/rollup-win32-ia32-msvc': 4.19.0 + '@rollup/rollup-win32-x64-msvc': 4.19.0 + fsevents: 2.3.2 + run-parallel@1.2.0: dependencies: queue-microtask: 1.2.3 diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml index 18ec407e..15989339 100644 --- a/pnpm-workspace.yaml +++ b/pnpm-workspace.yaml @@ -1,2 +1,3 @@ packages: - 'packages/*' + - 'examples/*'