diff --git a/README.md b/README.md index 6c078bba0..cf688c198 100644 --- a/README.md +++ b/README.md @@ -76,7 +76,6 @@ yarn add \ @near-wallet-selector/ramper-wallet \ @near-wallet-selector/near-mobile-wallet \ @near-wallet-selector/bitget-wallet \ - @near-wallet-selector/okx-wallet \ @near-wallet-selector/mintbase-wallet \ @near-wallet-selector/bitte-wallet \ @near-wallet-selector/ethereum-wallets @@ -104,7 +103,6 @@ npm install \ @near-wallet-selector/ramper-wallet \ @near-wallet-selector/near-mobile-wallet \ @near-wallet-selector/bitget-wallet \ - @near-wallet-selector/okx-wallet \ @near-wallet-selector/mintbase-wallet \ @near-wallet-selector/bitte-wallet \ @near-wallet-selector/ethereum-wallets diff --git a/examples/angular/src/app/pages/wallet-selector/wallet-selector.component.ts b/examples/angular/src/app/pages/wallet-selector/wallet-selector.component.ts index ae071e9f1..74be6a265 100644 --- a/examples/angular/src/app/pages/wallet-selector/wallet-selector.component.ts +++ b/examples/angular/src/app/pages/wallet-selector/wallet-selector.component.ts @@ -46,7 +46,7 @@ const projectId = "30147604c5f01d0bc4482ab0665b5697"; // TODO: Replace with the NEAR chain after the protocol upgrade. const near: Chain = { id: 398, - name: "NEAR wallet playground", + name: "NEAR Protocol Testnet", nativeCurrency: { decimals: 18, name: "NEAR", @@ -156,7 +156,7 @@ export class WalletSelectorComponent implements OnInit { setupNearMobileWallet(), setupMintbaseWallet({ contractId: CONTRACT_ID }), setupBitteWallet({ contractId: CONTRACT_ID }), - setupEthereumWallets({ wagmiConfig, web3Modal, devMode: true }), + setupEthereumWallets({ wagmiConfig, web3Modal }), ], }); diff --git a/examples/react/contexts/WalletSelectorContext.tsx b/examples/react/contexts/WalletSelectorContext.tsx index 8bda704c2..5fadd74e9 100644 --- a/examples/react/contexts/WalletSelectorContext.tsx +++ b/examples/react/contexts/WalletSelectorContext.tsx @@ -77,7 +77,7 @@ const projectId = "30147604c5f01d0bc4482ab0665b5697"; // TODO: Replace with the NEAR chain after the protocol upgrade. const near: Chain = { id: 398, - name: "NEAR wallet playground", + name: "NEAR Protocol Testnet", nativeCurrency: { decimals: 18, name: "NEAR", @@ -188,7 +188,7 @@ export const WalletSelectorContextProvider: React.FC<{ setupNearMobileWallet(), setupMintbaseWallet({ contractId: CONTRACT_ID }), setupBitteWallet({ contractId: CONTRACT_ID }), - setupEthereumWallets({ wagmiConfig, web3Modal, devMode: true }), + setupEthereumWallets({ wagmiConfig, web3Modal }), ], }); const _modal = setupModal(_selector, { diff --git a/package.json b/package.json index bda89d9ce..20f8975a7 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "near-wallet-selector", - "version": "8.9.12", + "version": "8.9.13", "description": "NEAR Wallet Selector makes it easy for users to interact with your dApp by providing an abstraction over various wallets within the NEAR ecosystem", "keywords": [ "near", @@ -44,6 +44,7 @@ "scripts": { "build:account-export": "nx run-many --target=build --projects=account-export --configuration=production", "build:all": "nx run-many --target=build --all --exclude=react,angular --configuration=production && node ./scripts/update-package-json.js", + "build:arepa-wallet": "nx run-many --target=build --projects=arepa-wallet --configuration=production", "build:bitget-wallet": "nx run-many --target=build --projects=bitget-wallet --configuration=production", "build:core": "nx run-many --target=build --projects=core --configuration=production", "build:here-wallet": "nx run-many --target=build --projects=here-wallet --configuration=production", @@ -91,12 +92,12 @@ "@angular/platform-browser-dynamic": "16.1.9", "@angular/router": "16.1.9", "@here-wallet/core": "3.3.1", - "@jscutlery/semver": "5.2.2", + "@jscutlery/semver": "5.3.1", "@ledgerhq/hw-transport": "6.30.3", "@ledgerhq/hw-transport-webhid": "6.29.2", "@metamask/detect-provider": "2.0.0", "@meteorwallet/sdk": "1.0.9", - "@mintbase-js/wallet": "0.6.0-beta.10", + "@mintbase-js/wallet": "0.6.1", "@near-snap/sdk": "0.6.0", "@noble/ciphers": "0.5.3", "@noble/hashes": "1.4.0", @@ -106,7 +107,7 @@ "@walletconnect/modal": "2.6.2", "@walletconnect/sign-client": "2.13.0", "@web3modal/wagmi": "5.0.6", - "better-sqlite3": "11.1.2", + "better-sqlite3": "11.2.1", "big.js": "6.2.1", "borsh": "0.7.0", "browserify-fs": "1.0.0", @@ -122,7 +123,7 @@ "near-seed-phrase": "0.2.0", "next": "13.3.0", "ngx-deploy-npm": "7.1.0", - "qrcode": "1.5.3", + "qrcode": "1.5.4", "react": "18.2.0", "react-dom": "18.2.0", "react-qr-code": "2.0.15", @@ -130,7 +131,7 @@ "rxjs": "7.8.1", "stream-browserify": "3.0.0", "stream-http": "3.2.0", - "tslib": "2.6.3", + "tslib": "2.7.0", "url": "0.11.0", "viem": "2.16.2", "wagmi": "2.10.9", diff --git a/packages/account-export/package.json b/packages/account-export/package.json index db9b70777..f32408578 100644 --- a/packages/account-export/package.json +++ b/packages/account-export/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/account-export", - "version": "8.9.12", + "version": "8.9.13", "description": "This is the Export Selector UI package for NEAR Wallet Selector.", "keywords": [ "near", @@ -19,5 +19,8 @@ "bugs": { "url": "https://github.com/near/wallet-selector/issues" }, - "homepage": "https://github.com/near/wallet-selector/tree/magin/packages/account-export" + "homepage": "https://github.com/near/wallet-selector/tree/magin/packages/account-export", + "peerDependencies": { + "near-api-js": "4.0.3" + } } diff --git a/packages/arepa-wallet/.babelrc b/packages/arepa-wallet/.babelrc new file mode 100644 index 000000000..b63f0528f --- /dev/null +++ b/packages/arepa-wallet/.babelrc @@ -0,0 +1,10 @@ +{ + "presets": [ + [ + "@nrwl/js/babel", + { + "useBuiltIns": "usage" + } + ] + ] +} diff --git a/packages/arepa-wallet/.eslintrc.json b/packages/arepa-wallet/.eslintrc.json new file mode 100644 index 000000000..9d9c0db55 --- /dev/null +++ b/packages/arepa-wallet/.eslintrc.json @@ -0,0 +1,18 @@ +{ + "extends": ["../../.eslintrc.json"], + "ignorePatterns": ["!**/*"], + "overrides": [ + { + "files": ["*.ts", "*.tsx", "*.js", "*.jsx"], + "rules": {} + }, + { + "files": ["*.ts", "*.tsx"], + "rules": {} + }, + { + "files": ["*.js", "*.jsx"], + "rules": {} + } + ] +} diff --git a/packages/arepa-wallet/README.md b/packages/arepa-wallet/README.md new file mode 100644 index 000000000..620398a03 --- /dev/null +++ b/packages/arepa-wallet/README.md @@ -0,0 +1,65 @@ +# @near-wallet-selector/my-near-wallet + +This is the [Arepa Wallet](https://mi.arepa.digital/) package for NEAR Wallet Selector. + +## Installation and Usage + +The easiest way to use this package is to install it from the NPM registry, this package requires `near-api-js` v1.0.0 or above: + +```bash +# Using Yarn +yarn add near-api-js + +# Using NPM. +npm install near-api-js +``` +```bash +# Using Yarn +yarn add @near-wallet-selector/arepa-wallet + +# Using NPM. +npm install @near-wallet-selector/arepa-wallet +``` + +Then use it in your dApp: + +```ts +import { setupWalletSelector } from "@near-wallet-selector/core"; +import { setupArepaWallet } from "@near-wallet-selector/arepa-wallet"; + +// My NEAR Wallet for Wallet Selector can be setup without any params or it can take few optional params, see options below. +const arepaWallet = setupArepaWallet({ + walletUrl: "https://develop.globaldv.tech/wallet-arepa/", + iconUrl: "https://" // optional +}); + +const selector = await setupWalletSelector({ + network: "testnet", + modules: [arepaWallet], +}); +``` + +## Options + +- `walletUrl` (`string?`): Wallet URL used to redirect when signing transactions. This parameter is required for custom network configuration. +- `iconUrl`: (`string?`): Image URL for the icon shown in the modal. This can also be a relative path or base64 encoded image. Defaults to `./assets/arepa-wallet-icon.png`. +- `deprecated`: (`boolean?`): Deprecated is optional. Default is `false`. +- `successUrl`: (`string?`): SuccessUrl is optional. Default is `''` (empty string). +- `failureUrl`: (`string?`): FailureUrl is optional. Default is `''` (empty string). + +## Assets + +Assets such as icons can be found in the `/assets` directory of the package. Below is an example using Webpack: + +```ts +import { setupMyNearWallet } from "@near-wallet-selector/arepa-wallet"; +import arepaWalletIconUrl from "@near-wallet-selector/arepa-wallet/assets/arepa-wallet-icon.png"; + +const arepaWallet = setupArepaWallet({ + iconUrl: arepaWalletIconUrl +}); +``` + +## License + +This repository is distributed under the terms of both the MIT license and the Apache License (Version 2.0). diff --git a/packages/arepa-wallet/assets/arepa-wallet-icon.png b/packages/arepa-wallet/assets/arepa-wallet-icon.png new file mode 100644 index 000000000..20705413c Binary files /dev/null and b/packages/arepa-wallet/assets/arepa-wallet-icon.png differ diff --git a/packages/arepa-wallet/jest.config.js b/packages/arepa-wallet/jest.config.js new file mode 100644 index 000000000..fa21e8daf --- /dev/null +++ b/packages/arepa-wallet/jest.config.js @@ -0,0 +1,14 @@ +module.exports = { + displayName: "arepa-wallet", + preset: "../../jest.preset.js", + globals: { + "ts-jest": { + tsconfig: "/tsconfig.spec.json", + }, + }, + transform: { + "^.+\\.[tj]sx?$": "ts-jest", + }, + moduleFileExtensions: ["ts", "tsx", "js", "jsx"], + coverageDirectory: "../../coverage/packages/arepa-wallet", +}; diff --git a/packages/arepa-wallet/jest.config.ts b/packages/arepa-wallet/jest.config.ts new file mode 100644 index 000000000..531d03520 --- /dev/null +++ b/packages/arepa-wallet/jest.config.ts @@ -0,0 +1,16 @@ +/* eslint-disable */ +export default { + displayName: "arepa-wallet", + preset: "../../jest.preset.js", + globals: {}, + transform: { + "^.+\\.[tj]s$": [ + "ts-jest", + { + tsconfig: "/tsconfig.spec.json", + }, + ], + }, + moduleFileExtensions: ["ts", "tsx", "js", "jsx"], + coverageDirectory: "../../coverage/packages/arepa-wallet", +}; diff --git a/packages/arepa-wallet/package.json b/packages/arepa-wallet/package.json new file mode 100644 index 000000000..d88a31de2 --- /dev/null +++ b/packages/arepa-wallet/package.json @@ -0,0 +1,27 @@ +{ + "name": "@near-wallet-selector/arepa-wallet", + "version": "8.9.13", + "description": "Arepa Wallet package for NEAR Wallet Selector.", + "keywords": [ + "near", + "blockchain", + "wallets", + "dapps", + "near-protocol", + "near-blockchain", + "wallet selector", + "browser wallet", + "arepa Wallet" + ], + "repository": { + "type": "git", + "url": "https://github.com/near/wallet-selector.git" + }, + "bugs": { + "url": "https://github.com/near/wallet-selector/issues" + }, + "homepage": "https://github.com/near/wallet-selector/tree/main/packages/arepa-wallet", + "peerDependencies": { + "near-api-js": "4.0.3" + } +} diff --git a/packages/arepa-wallet/project.json b/packages/arepa-wallet/project.json new file mode 100644 index 000000000..877484034 --- /dev/null +++ b/packages/arepa-wallet/project.json @@ -0,0 +1,56 @@ +{ + "name": "arepa-wallet", + "$schema": "../../node_modules/nx/schemas/project-schema.json", + "sourceRoot": "packages/arepa-wallet/src", + "projectType": "library", + "targets": { + "build": { + "executor": "@nrwl/rollup:rollup", + "outputs": ["{options.outputPath}"], + "options": { + "outputPath": "dist/packages/arepa-wallet", + "tsConfig": "packages/arepa-wallet/tsconfig.lib.json", + "project": "packages/arepa-wallet/package.json", + "entryFile": "packages/arepa-wallet/src/index.ts", + "buildableProjectDepsInPackageJsonType": "dependencies", + "compiler": "babel", + "format": ["esm", "cjs"], + "assets": [ + { + "glob": "packages/arepa-wallet/README.md", + "input": ".", + "output": "." + }, + { + "glob": "packages/arepa-wallet/assets/*", + "input": ".", + "output": "assets" + } + ] + } + }, + "lint": { + "executor": "@nx/linter:eslint", + "outputs": ["{options.outputFile}"], + "options": { + "lintFilePatterns": ["packages/arepa-wallet/**/*.ts"] + } + }, + "test": { + "executor": "@nx/jest:jest", + "outputs": ["{workspaceRoot}/coverage/packages/arepa-wallet"], + "options": { + "jestConfig": "packages/arepa-wallet/jest.config.ts", + "passWithNoTests": true + } + }, + "deploy": { + "executor": "ngx-deploy-npm:deploy", + "options": { + "access": "public" + }, + "dependsOn": ["^deploy"] + } + }, + "tags": ["browser-wallet"] +} diff --git a/packages/arepa-wallet/src/index.ts b/packages/arepa-wallet/src/index.ts new file mode 100644 index 000000000..66360c65d --- /dev/null +++ b/packages/arepa-wallet/src/index.ts @@ -0,0 +1,2 @@ +export { setupArepaWallet } from "./lib/arepa-wallet"; +export type { ArepaWalletParams } from "./lib/arepa-wallet"; diff --git a/packages/arepa-wallet/src/lib/arepa-wallet.spec.ts b/packages/arepa-wallet/src/lib/arepa-wallet.spec.ts new file mode 100644 index 000000000..edfff1118 --- /dev/null +++ b/packages/arepa-wallet/src/lib/arepa-wallet.spec.ts @@ -0,0 +1,121 @@ +/* eslint-disable @nx/enforce-module-boundaries */ +import type { + Near, + WalletConnection, + ConnectedWalletAccount, +} from "near-api-js"; +import type { AccountView } from "near-api-js/lib/providers/provider"; +import { mock } from "jest-mock-extended"; + +import { mockWallet } from "../../../core/src/lib/testUtils"; +import type { MockWalletDependencies } from "../../../core/src/lib/testUtils"; +import type { BrowserWallet } from "../../../core/src/lib/wallet"; + +const createArepaWallet = async (deps: MockWalletDependencies = {}) => { + const walletConnection = mock(); + const account = mock({ + connection: { + signer: { + getPublicKey: jest.fn().mockReturnValue(""), + }, + }, + }); + + jest.mock("near-api-js", () => { + const module = jest.requireActual("near-api-js"); + return { + ...module, + connect: jest.fn().mockResolvedValue(mock()), + WalletConnection: jest.fn().mockReturnValue(walletConnection), + }; + }); + + walletConnection.isSignedIn.calledWith().mockReturnValue(true); + walletConnection.getAccountId + .calledWith() + .mockReturnValue("test-account.testnet"); + walletConnection.account.calledWith().mockReturnValue(account); + // @ts-ignore + // near-api-js marks this method as protected. + // TODO: return value instead of null + account.signAndSendTransaction.calledWith().mockReturnValue(null); + account.state.calledWith().mockResolvedValue( + mock({ + amount: "1000000000000000000000000", + }) + ); + + // eslint-disable-next-line @typescript-eslint/no-var-requires + const { setupArepaWallet } = require("./arepa-wallet"); + const { wallet } = await mockWallet(setupArepaWallet(), deps); + + return { + nearApiJs: require("near-api-js"), + wallet, + walletConnection, + account, + }; +}; + +afterEach(() => { + jest.resetModules(); +}); + +describe("signIn", () => { + it("sign into near wallet", async () => { + const { wallet, nearApiJs } = await createArepaWallet(); + + await wallet.signIn({ contractId: "test.testnet" }); + + expect(nearApiJs.connect).toHaveBeenCalled(); + }); +}); + +describe("signOut", () => { + it("sign out of near wallet", async () => { + const { wallet, walletConnection } = await createArepaWallet(); + + await wallet.signIn({ contractId: "test.testnet" }); + await wallet.signOut(); + + expect(walletConnection.signOut).toHaveBeenCalled(); + }); +}); + +describe("getAccounts", () => { + it("returns array of accounts", async () => { + const { wallet, walletConnection } = await createArepaWallet(); + + await wallet.signIn({ contractId: "test.testnet" }); + const result = await wallet.getAccounts(); + + expect(walletConnection.getAccountId).toHaveBeenCalled(); + expect(result).toEqual([ + { accountId: "test-account.testnet", publicKey: "" }, + ]); + }); +}); + +describe("signAndSendTransaction", () => { + // TODO: Figure out why imports to core are returning undefined. + it("signs and sends transaction", async () => { + const { wallet, walletConnection, account } = await createArepaWallet(); + + await wallet.signIn({ contractId: "test.testnet" }); + const result = await wallet.signAndSendTransaction({ + receiverId: "guest-book.testnet", + actions: [], + }); + + expect(walletConnection.account).toHaveBeenCalled(); + // near-api-js marks this method as protected. + // @ts-ignore + expect(account.signAndSendTransaction).toHaveBeenCalled(); + // @ts-ignore + expect(account.signAndSendTransaction).toBeCalledWith({ + actions: [], + receiverId: "guest-book.testnet", + }); + expect(result).toEqual(null); + }); +}); diff --git a/packages/arepa-wallet/src/lib/arepa-wallet.ts b/packages/arepa-wallet/src/lib/arepa-wallet.ts new file mode 100644 index 000000000..4be01ca12 --- /dev/null +++ b/packages/arepa-wallet/src/lib/arepa-wallet.ts @@ -0,0 +1,271 @@ +import * as nearAPI from "near-api-js"; +import type { + WalletModuleFactory, + WalletBehaviourFactory, + BrowserWallet, + Transaction, + Optional, + Network, + Account, +} from "@near-wallet-selector/core"; +import { createAction } from "@near-wallet-selector/wallet-utils"; +import icon from "./icon"; + +export interface ArepaWalletParams { + walletUrl?: string; + iconUrl?: string; + deprecated?: boolean; + successUrl?: string; + failureUrl?: string; +} + +interface ArepaWalletState { + wallet: nearAPI.WalletConnection; + keyStore: nearAPI.keyStores.BrowserLocalStorageKeyStore; +} + +interface ArepaWalletExtraOptions { + walletUrl: string; +} + +const resolveWalletUrl = (network: Network, walletUrl?: string) => { + if (walletUrl) { + return walletUrl; + } + + switch (network.networkId) { + case "mainnet": + return "https://mi.arepa.digital"; + case "testnet": + return "https://testnet.arepa.digital"; + default: + throw new Error("Invalid wallet url"); + } +}; + +const setupWalletState = async ( + params: ArepaWalletExtraOptions, + network: Network +): Promise => { + const keyStore = new nearAPI.keyStores.BrowserLocalStorageKeyStore(); + + const near = await nearAPI.connect({ + keyStore, + walletUrl: params.walletUrl, + ...network, + headers: {}, + }); + + const wallet = new nearAPI.WalletConnection(near, "near_app"); + + return { + wallet, + keyStore, + }; +}; + +const ArepaWallet: WalletBehaviourFactory< + BrowserWallet, + { params: ArepaWalletExtraOptions } +> = async ({ metadata, options, store, params, logger, id }) => { + const _state = await setupWalletState(params, options.network); + const getAccounts = async (): Promise> => { + const accountId = _state.wallet.getAccountId(); + const account = _state.wallet.account(); + + if (!accountId || !account) { + return []; + } + + const publicKey = await account.connection.signer.getPublicKey( + account.accountId, + options.network.networkId + ); + return [ + { + accountId, + publicKey: publicKey ? publicKey.toString() : "", + }, + ]; + }; + + const transformTransactions = async ( + transactions: Array> + ) => { + const account = _state.wallet.account(); + const { networkId, signer, provider } = account.connection; + + const localKey = await signer.getPublicKey(account.accountId, networkId); + + return Promise.all( + transactions.map(async (transaction, index) => { + const actions = transaction.actions.map((action) => + createAction(action) + ); + const accessKey = await account.accessKeyForTransaction( + transaction.receiverId, + actions, + localKey + ); + + if (!accessKey) { + throw new Error( + `Failed to find matching key for transaction sent to ${transaction.receiverId}` + ); + } + + const block = await provider.block({ finality: "final" }); + + return nearAPI.transactions.createTransaction( + account.accountId, + nearAPI.utils.PublicKey.from(accessKey.public_key), + transaction.receiverId, + accessKey.access_key.nonce + index + 1, + actions, + nearAPI.utils.serialize.base_decode(block.header.hash) + ); + }) + ); + }; + + return { + async signIn({ contractId, methodNames, successUrl, failureUrl }) { + const existingAccounts = await getAccounts(); + + if (existingAccounts.length) { + return existingAccounts; + } + + await _state.wallet.requestSignIn({ + contractId, + methodNames, + successUrl, + failureUrl, + }); + + return getAccounts(); + }, + + async signOut() { + if (_state.wallet.isSignedIn()) { + _state.wallet.signOut(); + } + }, + + async getAccounts() { + return getAccounts(); + }, + + async verifyOwner() { + throw new Error(`Method not supported by ${metadata.name}`); + }, + + async signMessage({ message, nonce, recipient, callbackUrl, state }) { + logger.log("sign message", { message }); + + if (id !== "arepa-wallet") { + throw Error( + `The signMessage method is not supported by ${metadata.name}` + ); + } + + const locationUrl = + typeof window !== "undefined" ? window.location.href : ""; + + const url = callbackUrl || locationUrl; + + if (!url) { + throw new Error(`The callbackUrl is missing for ${metadata.name}`); + } + + const href = new URL(params.walletUrl); + href.pathname = "sign-message"; + href.searchParams.append("message", message); + href.searchParams.append("nonce", nonce.toString("base64")); + href.searchParams.append("recipient", recipient); + href.searchParams.append("callbackUrl", url); + if (state) { + href.searchParams.append("state", state); + } + + window.location.replace(href.toString()); + + return; + }, + + async signAndSendTransaction({ + signerId, + receiverId, + actions, + callbackUrl, + }) { + logger.log("signAndSendTransaction", { + signerId, + receiverId, + actions, + callbackUrl, + }); + + const { contract } = store.getState(); + + if (!_state.wallet.isSignedIn() || !contract) { + throw new Error("Wallet not signed in"); + } + + const account = _state.wallet.account(); + + return account["signAndSendTransaction"]({ + receiverId: receiverId || contract.contractId, + actions: actions.map((action) => createAction(action)), + walletCallbackUrl: callbackUrl, + }); + }, + + async signAndSendTransactions({ transactions, callbackUrl }) { + logger.log("signAndSendTransactions", { transactions, callbackUrl }); + + if (!_state.wallet.isSignedIn()) { + throw new Error("Wallet not signed in"); + } + + return _state.wallet.requestSignTransactions({ + transactions: await transformTransactions(transactions), + callbackUrl, + }); + }, + }; +}; + +export function setupArepaWallet({ + walletUrl, + iconUrl = icon, + deprecated = false, + successUrl = "", + failureUrl = "", +}: ArepaWalletParams = {}): WalletModuleFactory { + return async (moduleOptions) => { + return { + id: "arepa-wallet", + type: "browser", + metadata: { + name: "ArepaWallet", + description: + "NEAR wallet to store, buy, send and stake assets for DeFi.", + iconUrl, + deprecated, + available: true, + successUrl, + failureUrl, + walletUrl: resolveWalletUrl(moduleOptions.options.network, walletUrl), + }, + init: (options) => { + return ArepaWallet({ + ...options, + params: { + walletUrl: resolveWalletUrl(options.options.network, walletUrl), + }, + }); + }, + }; + }; +} diff --git a/packages/arepa-wallet/src/lib/icon.ts b/packages/arepa-wallet/src/lib/icon.ts new file mode 100644 index 000000000..b3d406ad9 --- /dev/null +++ b/packages/arepa-wallet/src/lib/icon.ts @@ -0,0 +1 @@ +export default ``; diff --git a/packages/arepa-wallet/tsconfig.json b/packages/arepa-wallet/tsconfig.json new file mode 100644 index 000000000..8b6d6acaf --- /dev/null +++ b/packages/arepa-wallet/tsconfig.json @@ -0,0 +1,19 @@ +{ + "extends": "../../tsconfig.base.json", + "compilerOptions": { + "forceConsistentCasingInFileNames": true, + "strict": true, + "noImplicitReturns": true, + "noFallthroughCasesInSwitch": true + }, + "files": [], + "include": [], + "references": [ + { + "path": "./tsconfig.lib.json" + }, + { + "path": "./tsconfig.spec.json" + } + ] +} diff --git a/packages/arepa-wallet/tsconfig.lib.json b/packages/arepa-wallet/tsconfig.lib.json new file mode 100644 index 000000000..b3f90c22f --- /dev/null +++ b/packages/arepa-wallet/tsconfig.lib.json @@ -0,0 +1,10 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "../../dist/out-tsc", + "declaration": true, + "types": [] + }, + "include": ["**/*.ts"], + "exclude": ["jest.config.ts", "**/*.spec.ts"] +} diff --git a/packages/arepa-wallet/tsconfig.spec.json b/packages/arepa-wallet/tsconfig.spec.json new file mode 100644 index 000000000..546f12877 --- /dev/null +++ b/packages/arepa-wallet/tsconfig.spec.json @@ -0,0 +1,9 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "../../dist/out-tsc", + "module": "commonjs", + "types": ["jest", "node"] + }, + "include": ["jest.config.ts", "**/*.test.ts", "**/*.spec.ts", "**/*.d.ts"] +} diff --git a/packages/bitget-wallet/README.md b/packages/bitget-wallet/README.md index 8e4a04402..bd33921e9 100644 --- a/packages/bitget-wallet/README.md +++ b/packages/bitget-wallet/README.md @@ -1,6 +1,6 @@ # @near-wallet-selector/bitget-wallet -This is the [Bitget Wallet](https://chrome.google.com/webstore/detail/bitkeep-crypto-nft-wallet/jiidiaalihmmhddjgbnbgdfflelocpak) package for NEAR Wallet Selector. +This is the [Bitget Wallet](https://chromewebstore.google.com/detail/bitget-wallet-formerly-bi/jiidiaalihmmhddjgbnbgdfflelocpak) package for NEAR Wallet Selector. ## Installation and Usage diff --git a/packages/bitget-wallet/package.json b/packages/bitget-wallet/package.json index 417fdb9ad..b0909194a 100644 --- a/packages/bitget-wallet/package.json +++ b/packages/bitget-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/bitget-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Bitget wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/bitte-wallet/package.json b/packages/bitte-wallet/package.json index 1d091788b..0a983cc2c 100644 --- a/packages/bitte-wallet/package.json +++ b/packages/bitte-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/bitte-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Bitte wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/coin98-wallet/package.json b/packages/coin98-wallet/package.json index 9f7bd88d8..9ffde9e8c 100644 --- a/packages/coin98-wallet/package.json +++ b/packages/coin98-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/coin98-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Coin 98 wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/core/package.json b/packages/core/package.json index 4f6b896a7..62ddc3417 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/core", - "version": "8.9.12", + "version": "8.9.13", "description": "This is the core package for NEAR Wallet Selector.", "keywords": [ "near", @@ -18,5 +18,9 @@ "bugs": { "url": "https://github.com/near/wallet-selector/issues" }, - "homepage": "https://github.com/near/wallet-selector/tree/main/packages/core" + "homepage": "https://github.com/near/wallet-selector/tree/main/packages/core", + "peerDependencies": { + "near-api-js": "4.0.3", + "@near-js/providers": "latest" + } } diff --git a/packages/core/src/lib/locale/ar.json b/packages/core/src/lib/locale/ar.json index aa5517da5..8b84d5f0e 100644 --- a/packages/core/src/lib/locale/ar.json +++ b/packages/core/src/lib/locale/ar.json @@ -57,12 +57,59 @@ "open": "فتح" }, "walletTypes": { - "hardware": "Hardware Wallet", - "browser": "Browser Wallet", - "injected": "Wallet Extension", - "bridge": "Bridge Wallet", - "mobile": "Mobile Wallet", - "instant-link": "Instant Wallet" + "hardware": "محفظة الأجهزة", + "browser": "محفظة المتصفح", + "injected": "ملحق المحفظة", + "bridge": "محفظة الجسر", + "mobile": "محفظة الجوال", + "instant-link": "محفظة الرابط الفوري" + }, + "exportAccounts": { + "afterDecide": "بعد اتخاذ قرار بشأن محفظة، يمكنك اختيار الحسابات التي تريد نقلها.", + "chooseAWallet": "اختر محفظة", + "disclaimer": "لن تتمكن من نقل الحسابات التي لم يتم تمويلها أو استخدامها على NEAR.", + "selectAWallet": "اختر محفظة تناسب احتياجاتك وتدعم حساباتك المتصلة.", + "selectYourAccounts": "حدد حساباتك", + "transferYourAccounts": "نقل حساباتك", + "warning": "لا تدعم تصدير الحسابات في الوقت الحالي. يرجى اختيار محفظة أخرى.", + "complete": { + "button": "أكمل", + "descOne": "سيتم توجيهك الآن إلى المحفظة التي اخترتها لإكمال النقل.", + "descTwo": "بمجرد إكمال جزء الاستيراد من العملية من المحفظة المحددة، اضغط على الزر لإكمال عملية النقل.", + "startOverButton": "ابدأ من جديد", + "title": "أكمل النقل" + }, + "getPassphrase": { + "button": "تابع", + "checkLabel": "لقد قمت بنسخ أو كتابة كلمة المرور", + "desc": "ستحتاج إلى إدخال هذه الكلمة السرية عند بدء تصدير حساباتك إلى محفظة مختلفة.", + "label": "انقر لنسخ", + "title": "انسخ كلمة المرور المؤقتة", + "transferButton": "نقل الحسابات" + }, + "selectAccounts": { + "button": "تابع", + "deselectAll": "إلغاء تحديد الكل", + "error": "الحساب غير موجود", + "noBalance": "الحساب غير ممول", + "selectAll": "تحديد الكل", + "title": "حدد الحسابات لنقلها", + "unavailable": "النقل غير متاح", + "warningLedger": "دعم Ledger مطلوب" + }, + "walletTypes": { + "bridge": "محفظة الجسر", + "browser": "محفظة المتصفح", + "hardware": "محفظة الأجهزة", + "injected": "ملحق المحفظة", + "mobile": "محفظة الجوال" + } + } + }, + "component": { + "clickToCopy": { + "label": "تم النسخ", + "tooltip": "انقر لنسخ" } } } diff --git a/packages/core/src/lib/locale/bg.json b/packages/core/src/lib/locale/bg.json index 29775e92f..72f35ef1f 100644 --- a/packages/core/src/lib/locale/bg.json +++ b/packages/core/src/lib/locale/bg.json @@ -57,12 +57,12 @@ "open": "Отворете" }, "walletTypes": { - "hardware": "Hardware Wallet", - "browser": "Browser Wallet", - "injected": "Wallet Extension", - "bridge": "Bridge Wallet", - "mobile": "Mobile Wallet", - "instant-link": "Instant Wallet" + "hardware": "Хардуерен портфейл", + "browser": "Портфейл в браузъра", + "injected": "Разширение на портфейл", + "bridge": "Мостов портфейл", + "mobile": "Мобилен портфейл", + "instant-link": "Мигновен портфейл" } } } diff --git a/packages/core/src/lib/locale/es.json b/packages/core/src/lib/locale/es.json index 61b4eec1c..e81f75c11 100644 --- a/packages/core/src/lib/locale/es.json +++ b/packages/core/src/lib/locale/es.json @@ -57,12 +57,12 @@ "open": "Abrir" }, "walletTypes": { - "hardware": "Hardware Wallet", - "browser": "Browser Wallet", - "injected": "Wallet Extension", - "bridge": "Bridge Wallet", - "mobile": "Mobile Wallet", - "instant-link": "Instant Wallet" + "hardware": "Cartera de Hardware", + "browser": "Cartera de Navegador", + "injected": "Extensión de Cartera", + "bridge": "Cartera de Puente", + "mobile": "Cartera Móvil", + "instant-link": "Cartera Instantánea" } } } diff --git a/packages/core/src/lib/locale/hi.json b/packages/core/src/lib/locale/hi.json index f487c5398..75dc8ed9e 100644 --- a/packages/core/src/lib/locale/hi.json +++ b/packages/core/src/lib/locale/hi.json @@ -56,12 +56,12 @@ "open": "खोले|" }, "walletTypes": { - "hardware": "Hardware Wallet", - "browser": "Browser Wallet", - "injected": "Wallet Extension", - "bridge": "Bridge Wallet", - "mobile": "Mobile Wallet", - "instant-link": "Instant Wallet" + "hardware": "हार्डवेयर वॉलेट", + "browser": "ब्राउज़र वॉलेट", + "injected": "वॉलेट एक्सटेंशन", + "bridge": "ब्रिज वॉलेट", + "mobile": "मोबाइल वॉलेट", + "instant-link": "इंस्टेंट वॉलेट" } } } diff --git a/packages/core/src/lib/locale/jp.json b/packages/core/src/lib/locale/jp.json new file mode 100644 index 000000000..a5c2211d3 --- /dev/null +++ b/packages/core/src/lib/locale/jp.json @@ -0,0 +1,115 @@ +{ + "modal": { + "wallet": { + "connectYourWallet": "ウォレットを接続", + "whatIsAWallet": "ウォレットとは?", + "secureAndManage": "デジタル資産を安全に管理", + "safelyStore": "暗号通貨やNFTを安全に保存し、転送します。", + "logInToAny": "すべてのNEARアプリにログイン", + "noNeedToCreate": "新しいアカウントや資格情報を作成する必要はありません。ウォレットを接続するだけで準備完了です!", + "getAWallet": "ウォレットを取得", + "useAWallet": "ウォレットを使ってNEARの資産を安全に管理し、ユーザー名やパスワードなしでNEARアプリにログインします。", + "connectionFailed": "接続失敗", + "connectionSuccessful": "接続成功", + "rememberWallet": "ウォレットを記憶", + "connected": "接続済み", + "connectingTo": "接続中", + "connectingMessage": { + "injected": "拡張機能ウィンドウで接続を確認", + "browser": "リダイレクト後にウォレットで接続を確認", + "hardware": "Ledgerデバイスで接続を確認", + "bridge": "ウォレットで接続を確認" + } + }, + "ledger": { + "connectWithLedger": "Ledgerで接続", + "makeSureYourLedger": "Ledgerが安全に接続され、NEARアプリがデバイスで開いていることを確認してください", + "continue": "続行", + "specifyHDPath": "HDパスを指定", + "enterYourPreferredHDPath": "希望のHDパスを入力し、アクティブなアカウントをスキャンします。", + "scan": "スキャン", + "retry": "再試行", + "ledgerIsNotAvailable": "Ledgerが使用できません", + "accessDeniedToUseLedgerDevice": "Ledgerデバイスの使用が拒否されました", + "noAccountsFound": "アカウントが見つかりません", + "selectYourAccounts": "アカウントを選択", + "connecting1Account": "1アカウントに接続中", + "cantFindAnyAccount": "このLedgerに関連付けられたアカウントが見つかりません。新しいNEARアカウントを作成してください", + "orConnectAnAnotherLedger": "または別のLedgerを接続してください。", + "connecting": "接続中", + "ofAccounts": "アカウントの", + "failedToAutomatically": "アカウントIDを自動的に見つけることができませんでした。手動で提供してください:", + "overviewTheListOfAuthorized": "認可されたアカウントのリストを確認し、以下のボタンをクリックしてサインインを完了します。", + "finish": "完了" + }, + "install": { + "youllNeedToInstall": "インストールが必要です", + "toContinueAfterInstalling": "続行するには", + "refreshThePage": "ページを更新してください。", + "open": "開く" + }, + "qr": { + "copiedToClipboard": "クリップボードにコピーされました", + "failedToCopy": "クリップボードにコピーできませんでした", + "scanWithYourMobile": "モバイルデバイスでスキャン", + "copyToClipboard": "クリップボードにコピー", + "preferTheOfficial": "公式ダイアログを推奨します", + "open": "開く" + }, + "walletTypes": { + "hardware": "ハードウェアウォレット", + "browser": "ブラウザウォレット", + "injected": "ウォレット拡張機能", + "bridge": "ブリッジウォレット", + "mobile": "モバイルウォレット", + "instant-link": "インスタントウォレット" + }, + "exportAccounts": { + "chooseAWallet": "ウォレットを選択", + "transferYourAccounts": "アカウントを転送", + "selectAWallet": "ニーズに合ったウォレットを選択し、接続されたアカウントをサポートしているものを選びます。", + "selectYourAccounts": "アカウントを選択", + "afterDecide": "ウォレットを決定した後、転送したいアカウントを選択できます。", + "disclaimer": "NEARで資金が提供されたことがないアカウントは転送できません。", + "warning": "現在、アカウントのエクスポートをサポートしていません。他のウォレットを選択してください。", + "walletTypes": { + "hardware": "ハードウェアウォレット", + "browser": "ブラウザウォレット", + "injected": "ウォレット拡張機能", + "bridge": "ブリッジウォレット", + "mobile": "モバイルウォレット" + }, + "selectAccounts": { + "title": "転送するアカウントを選択", + "button": "続行", + "deselectAll": "すべて選択解除", + "selectAll": "すべて選択", + "unavailable": "転送不可", + "error": "アカウントが存在しません", + "warningLedger": "Ledgerサポートが必要です", + "noBalance": "アカウントに資金がありません" + }, + "getPassphrase": { + "title": "一時パスワードをコピー", + "desc": "アカウントを別のウォレットにエクスポートする際にこのパスワードを入力する必要があります。", + "button": "続行", + "transferButton": "アカウントを転送", + "label": "クリックしてコピー", + "checkLabel": "パスワードをコピーまたは書き留めた" + }, + "complete": { + "title": "転送を完了", + "descOne": "選択したウォレットにリダイレクトされ、転送を完了します。", + "descTwo": "選択したウォレットからインポートの一部が完了した後、転送プロセスを完了するためにボタンを押してください。", + "startOverButton": "最初からやり直す", + "button": "完了" + } + } + }, + "component": { + "clickToCopy": { + "label": "コピー済み", + "tooltip": "コピーするにはクリック" + } + } +} \ No newline at end of file diff --git a/packages/core/src/lib/locale/zh-hk.json b/packages/core/src/lib/locale/zh-hk.json new file mode 100644 index 000000000..c3d6dd847 --- /dev/null +++ b/packages/core/src/lib/locale/zh-hk.json @@ -0,0 +1,62 @@ +{ + "modal": { + "wallet": { + "connectYourWallet": "連接你的錢包", + "whatIsAWallet": "咩係錢包?", + "secureAndManage": "保護同管理你的數碼資產", + "safelyStore": "安全儲存同轉移你的加密貨幣同NFT", + "logInToAny": "登入任何 NEAR 應用", + "noNeedToCreate": "無需創建新帳戶或密碼。連接你的錢包,即可開始使用!", + "getAWallet": "獲取新帳戶", + "useAWallet": "使用錢包來保護同管理你的 NEAR 資產,無需用戶名同密碼即可登入任何 NEAR 應用", + "connectionFailed": "連接失敗", + "connectionSuccessful": "連接成功", + "rememberWallet": "記住錢包選擇", + "connected": "已連接", + "connectingTo": "正在連接" + }, + "ledger": { + "connectWithLedger": "連接 Ledger", + "makeSureYourLedger": "確保你的 Ledger 已經安全連接,並且 NEAR 應用已經在你設備上打開", + "continue": "繼續", + "specifyHDPath": "指定 HD 路徑", + "enterYourPreferredHDPath": "輸入你偏好的 HD 路徑,然後為任何活躍帳戶掃描", + "scan": "掃描", + "retry": "重試", + "ledgerIsNotAvailable": "Ledger 不可用", + "accessDeniedToUseLedgerDevice": "訪問 Ledger 設備被拒絕", + "noAccountsFound": "沒有找到账戶", + "selectYourAccounts": "選擇你的帳戶", + "connecting1Account": "正在連接1個帳戶", + "cantFindAnyAccount": "未能找到任何與這個 Ledger 相關聯的帳戶。請於", + "orConnectAnAnotherLedger.": "或連接另一個 Ledger", + "connecting": "正在連接", + "ofAccounts": "個帳戶", + "failedToAutomatically": "無法自動找到账戶ID,請主動提供:", + "overviewTheListOfAuthorized": "請查看已授權的帳戶列表,點擊以下按鈕完成登入", + "finish": "完成" + }, + "install": { + "youllNeedToInstall": "你將需要安裝", + "toContinueAfterInstalling": "以繼續。安裝完", + "refreshThePage": "請刷新頁面", + "open": "打開" + }, + "qr": { + "copiedToClipboard": "複製到剪貼板", + "failedToCopy": "複製到剪貼板失敗", + "scanWithYourMobile": "用你的手機掃描", + "copyToClipboard": "複製到剪貼板", + "preferTheOfficial": "希望使用官方對話框於", + "open": "打開" + }, + "walletTypes": { + "hardware": "硬件錢包", + "browser": "瀏覽器錢包", + "injected": "錢包擴展", + "bridge": "橋接錢包", + "mobile": "流動錢包", + "instant-link": "即時錢包" + } + } +} diff --git a/packages/core/src/lib/locale/zh.json b/packages/core/src/lib/locale/zh.json index 09e4ab781..e999aa782 100644 --- a/packages/core/src/lib/locale/zh.json +++ b/packages/core/src/lib/locale/zh.json @@ -51,12 +51,12 @@ "open": "打开" }, "walletTypes": { - "hardware": "Hardware Wallet", - "browser": "Browser Wallet", - "injected": "Wallet Extension", - "bridge": "Bridge Wallet", - "mobile": "Mobile Wallet", - "instant-link": "Instant Wallet" + "hardware": "硬件钱包", + "browser": "浏览器钱包", + "injected": "钱包扩展", + "bridge": "桥接钱包", + "mobile": "移动钱包", + "instant-link": "即时钱包" } } } diff --git a/packages/ethereum-wallets/README.md b/packages/ethereum-wallets/README.md index 011ca94ba..93e3b33ba 100644 --- a/packages/ethereum-wallets/README.md +++ b/packages/ethereum-wallets/README.md @@ -17,7 +17,7 @@ NEP-518 doesn't support multiple actions within the same transaction, so when mu NEP-518 rpc relayer uses a FunctionCall access key to execute transactions on behalf of the user by calling `rlp_execute`. If this key is not yet added, the wallet will be onboarded before the first transaction is made. -`signMessage` and `verifyOwner` are not implemented because Ethereum wallets are not compatible with these standards, instead a dApp can use `eth_sign` or `eth_signTypedData_v4` to authenticate the wallet by interacting with it directly. +`signMessage` and `verifyOwner` are not implemented because Ethereum wallets are not compatible with these standards, instead a dApp can use `personal_sign` or `eth_signTypedData_v4` to authenticate the wallet by interacting with it directly. ## Installation and Usage @@ -79,6 +79,7 @@ Project ID is required, please obtain it from [walletconnect.com](https://wallet - `iconUrl` (`string?`): Image URL for the icon shown in the modal. This can also be a relative path or base64 encoded image. Defaults to `./assets/ethereum-wallets-icon.png`. - `wagmiCore` (`typeof import("@wagmi/core")?`): Optional, @wagmi/core functions can be overidden by the dapp to interract with the wallet. - `alwaysOnboardDuringSignIn` (`boolean?`): A dapp without SignIn access key will not onboard the relayer by default, this option does the relayer onboarding during login. +- `nearNodeUrl` (`string?`): NEAR node url to query the NEAR transaction status and onboarding access key. Developent options (before the NEAR protocol upgrade to support 0x accounts natively): diff --git a/packages/ethereum-wallets/package.json b/packages/ethereum-wallets/package.json index 8eb842c44..f11e43cf3 100644 --- a/packages/ethereum-wallets/package.json +++ b/packages/ethereum-wallets/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/ethereum-wallets", - "version": "1.0.0", + "version": "8.9.13", "description": "Ethereum wallets package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/ethereum-wallets/src/lib/index.ts b/packages/ethereum-wallets/src/lib/index.ts index 8ff973315..92efa1fec 100644 --- a/packages/ethereum-wallets/src/lib/index.ts +++ b/packages/ethereum-wallets/src/lib/index.ts @@ -64,6 +64,7 @@ export interface EthereumWalletsParams { devMode?: boolean; devModeAccount?: string; deprecated?: boolean; + nearNodeUrl?: string; } interface EthereumWalletsState { @@ -103,6 +104,7 @@ const EthereumWallets: WalletBehaviourFactory< alwaysOnboardDuringSignIn = false, devMode, devModeAccount = "eth-wallet.testnet", + nearNodeUrl, }, }) => { if (!wagmiCore) { @@ -123,6 +125,17 @@ const EthereumWallets: WalletBehaviourFactory< if (!nearExplorer) { throw new Error("Failed to parse NEAR explorer url from wagmiConfig."); } + // NOTE: use a custom provider because the failover provider doesn't give error details. + const nearProvider = new JsonRpcProvider( + nearNodeUrl ?? + // @ts-expect-error + provider.provider.connection ?? + // @ts-expect-error + provider.provider.providers[ + // @ts-expect-error + provider.provider.currentProviderIndex + ].connection + ); const getAccounts = async (): Promise> => { const address = wagmiCore!.getAccount(wagmiConfig).address?.toLowerCase(); @@ -279,8 +292,9 @@ const EthereumWallets: WalletBehaviourFactory< throw new Error("Invalid action type"); } } - const { request } = await wagmiCore!.simulateContract(wagmiConfig, ethTx); - const result = await wagmiCore!.writeContract(wagmiConfig, request); + // NOTE: re-add simulateContract and parse errors after eth_call implements errors. + // const { request } = await wagmiCore!.simulateContract(wagmiConfig, ethTx); + const result = await wagmiCore!.writeContract(wagmiConfig, ethTx); return result; }; @@ -422,7 +436,7 @@ const EthereumWallets: WalletBehaviourFactory< throw new Error("Failed to fetch the relayer's public key."); } try { - const key = await provider.query({ + const key = await nearProvider.query({ request_type: "view_access_key", finality: "final", account_id: accountId, @@ -439,6 +453,8 @@ const EthereumWallets: WalletBehaviourFactory< logger.error(error); if ( !error.message?.includes("does not exist while viewing") && + !error.message?.includes("doesn't exist") && + !error.message?.includes("does not exist") && !error.message?.includes("has never been observed on the node") ) { throw new Error( @@ -505,7 +521,7 @@ const EthereumWallets: WalletBehaviourFactory< if (accountLogIn.publicKey && nearTxs.length) { let accessKeyUsable; try { - const accessKey = await provider.query({ + const accessKey = await nearProvider.query({ request_type: "view_access_key", finality: "final", account_id: accountLogIn.accountId, @@ -528,7 +544,9 @@ const EthereumWallets: WalletBehaviourFactory< ); const results: Array = []; for (let i = 0; i < signedTransactions.length; i += 1) { - const nearTx = await provider.sendTransaction(signedTransactions[i]); + const nearTx = await nearProvider.sendTransaction( + signedTransactions[i] + ); logger.log("NEAR transaction:", nearTx); if ( typeof nearTx.status === "object" && @@ -651,10 +669,6 @@ const EthereumWallets: WalletBehaviourFactory< } } logger.log("Receipt:", receipt); - const nearProvider = new JsonRpcProvider( - // @ts-expect-error - provider.provider.connection - ); let nearTx; while (!nearTx) { try { @@ -711,7 +725,7 @@ const EthereumWallets: WalletBehaviourFactory< if (accountLogIn.publicKey) { try { // Check that the key exists before making a transaction. - await provider.query({ + await nearProvider.query({ request_type: "view_access_key", finality: "final", account_id: accountLogIn.accountId, @@ -842,7 +856,7 @@ const EthereumWallets: WalletBehaviourFactory< let reUseKeyPair = false; if (keyPair) { try { - await provider.query({ + await nearProvider.query({ request_type: "view_access_key", finality: "final", account_id: accountId, @@ -936,14 +950,14 @@ const EthereumWallets: WalletBehaviourFactory< async verifyOwner({ message }) { logger.log("EthereumWallets:verifyOwner", { message }); throw new Error( - "Not implemented: ed25519 N/A, use eth_sign or eth_signTypedData_v4 instead." + "Not implemented: ed25519 N/A, '\x19Ethereum Signed Message:\n' prefix is not compatible, use personal_sign or eth_signTypedData_v4 instead." ); }, async signMessage({ message, nonce, recipient }) { logger.log("EthereumWallets:signMessage", { message, nonce, recipient }); throw new Error( - "Not implemented: ed25519 N/A, use eth_sign or eth_signTypedData_v4 instead." + "Not implemented: ed25519 N/A, '\x19Ethereum Signed Message:\n' prefix is not compatible, use personal_sign or eth_signTypedData_v4 instead." ); }, diff --git a/packages/here-wallet/package.json b/packages/here-wallet/package.json index 28f5b8bc1..c2fbc5295 100644 --- a/packages/here-wallet/package.json +++ b/packages/here-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/here-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Here wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/ledger/package.json b/packages/ledger/package.json index 980c52b33..7594aa8ff 100644 --- a/packages/ledger/package.json +++ b/packages/ledger/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/ledger", - "version": "8.9.12", + "version": "8.9.13", "description": "Ledger package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/math-wallet/package.json b/packages/math-wallet/package.json index 5972ee816..6e0726b16 100644 --- a/packages/math-wallet/package.json +++ b/packages/math-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/math-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Math wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/meteor-wallet/package.json b/packages/meteor-wallet/package.json index 180143e75..68c487d62 100644 --- a/packages/meteor-wallet/package.json +++ b/packages/meteor-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/meteor-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Meteor wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/mintbase-wallet/package.json b/packages/mintbase-wallet/package.json index efd4d57b4..c1793b815 100644 --- a/packages/mintbase-wallet/package.json +++ b/packages/mintbase-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/mintbase-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Mintbase wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/modal-ui-js/package.json b/packages/modal-ui-js/package.json index 8815d0cd7..97819b23c 100644 --- a/packages/modal-ui-js/package.json +++ b/packages/modal-ui-js/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/modal-ui-js", - "version": "8.9.12", + "version": "8.9.13", "description": "Modal UI package for NEAR wallet Selector", "keywords": [ "near", diff --git a/packages/modal-ui/package.json b/packages/modal-ui/package.json index 29b097cc3..0da355ac7 100644 --- a/packages/modal-ui/package.json +++ b/packages/modal-ui/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/modal-ui", - "version": "8.9.12", + "version": "8.9.13", "description": "Modal UI package for NEAR wallet Selector", "keywords": [ "near", diff --git a/packages/my-near-wallet/package.json b/packages/my-near-wallet/package.json index ef9ad790a..12f11f6d9 100644 --- a/packages/my-near-wallet/package.json +++ b/packages/my-near-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/my-near-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "My Near Wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/narwallets/package.json b/packages/narwallets/package.json index c48c776a2..3263a0848 100644 --- a/packages/narwallets/package.json +++ b/packages/narwallets/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/narwallets", - "version": "8.9.12", + "version": "8.9.13", "description": "This is the Narwallets package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/near-mobile-wallet/package.json b/packages/near-mobile-wallet/package.json index f90b6b093..6c36d958b 100644 --- a/packages/near-mobile-wallet/package.json +++ b/packages/near-mobile-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/near-mobile-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "NEAR Mobile wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/near-snap/package.json b/packages/near-snap/package.json index b9ba2708d..687d64634 100644 --- a/packages/near-snap/package.json +++ b/packages/near-snap/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/near-snap", - "version": "8.9.12", + "version": "8.9.13", "description": "Metamask snap to interact with Near dapps.", "keywords": [ "near", diff --git a/packages/nearfi/package.json b/packages/nearfi/package.json index a92d43589..0704ffb2e 100644 --- a/packages/nearfi/package.json +++ b/packages/nearfi/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/nearfi", - "version": "8.9.12", + "version": "8.9.13", "description": "Nearfi package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/neth/package.json b/packages/neth/package.json index 78f727bd8..8f0da4770 100644 --- a/packages/neth/package.json +++ b/packages/neth/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/neth", - "version": "8.9.12", + "version": "8.9.13", "description": "Control NEAR accounts with ETH accounts", "author": "mattlockyer", "keywords": [ diff --git a/packages/nightly/package.json b/packages/nightly/package.json index a8ad257b3..5f3aa2230 100644 --- a/packages/nightly/package.json +++ b/packages/nightly/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/nightly", - "version": "8.9.12", + "version": "8.9.13", "description": "Nightly wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/okx-wallet/package.json b/packages/okx-wallet/package.json index a7e2f343e..78f7f5ca7 100644 --- a/packages/okx-wallet/package.json +++ b/packages/okx-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/okx-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "OKX Wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/ramper-wallet/package.json b/packages/ramper-wallet/package.json index 839a549cb..61f51927b 100644 --- a/packages/ramper-wallet/package.json +++ b/packages/ramper-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/ramper-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Ramper wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/sender/package.json b/packages/sender/package.json index 962526de6..995ec220b 100644 --- a/packages/sender/package.json +++ b/packages/sender/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/sender", - "version": "8.9.12", + "version": "8.9.13", "description": "Sender wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/wallet-connect/package.json b/packages/wallet-connect/package.json index c88eabb95..1fef3775a 100644 --- a/packages/wallet-connect/package.json +++ b/packages/wallet-connect/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/wallet-connect", - "version": "8.9.12", + "version": "8.9.13", "description": "Wallet Connect package for NEAR Wallet Selector.", "keywords": [ "near", @@ -20,5 +20,8 @@ "bugs": { "url": "https://github.com/near/wallet-selector/issues" }, - "homepage": "https://github.com/near/wallet-selector/tree/main/packages/wallet-connect" + "homepage": "https://github.com/near/wallet-selector/tree/main/packages/wallet-connect", + "peerDependencies": { + "near-api-js": "4.0.3" + } } diff --git a/packages/wallet-utils/package.json b/packages/wallet-utils/package.json index ff2127af2..00d477ac4 100644 --- a/packages/wallet-utils/package.json +++ b/packages/wallet-utils/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/wallet-utils", - "version": "8.9.12", + "version": "8.9.13", "description": "Wallet utils package for NEAR Wallet Selector.", "keywords": [ "near", @@ -18,5 +18,8 @@ "bugs": { "url": "https://github.com/near/wallet-selector/issues" }, - "homepage": "https://github.com/near/wallet-selector/tree/main/packages/wallet-utils" + "homepage": "https://github.com/near/wallet-selector/tree/main/packages/wallet-utils", + "peerDependencies": { + "near-api-js": "4.0.3" + } } diff --git a/packages/welldone-wallet/package.json b/packages/welldone-wallet/package.json index aea6e9dcf..52a7a2efd 100644 --- a/packages/welldone-wallet/package.json +++ b/packages/welldone-wallet/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/welldone-wallet", - "version": "8.9.12", + "version": "8.9.13", "description": "Welldone wallet package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/packages/xdefi/package.json b/packages/xdefi/package.json index 97910782a..a8b45f5ab 100644 --- a/packages/xdefi/package.json +++ b/packages/xdefi/package.json @@ -1,6 +1,6 @@ { "name": "@near-wallet-selector/xdefi", - "version": "8.9.12", + "version": "8.9.13", "description": "This is the XDEFI package for NEAR Wallet Selector.", "keywords": [ "near", diff --git a/scripts/release-packages.bash b/scripts/release-packages.bash index 52cf146ec..39e221eb6 100644 --- a/scripts/release-packages.bash +++ b/scripts/release-packages.bash @@ -30,3 +30,4 @@ npm publish dist/packages/bitte-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/bitget-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/okx-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/ethereum-wallets --tag "${TAG}" --otp "${OTP}" +npm publish dist/packages/arepa-wallet --tag "${TAG}" --otp "${OTP}" diff --git a/tsconfig.base.json b/tsconfig.base.json index b175e61fc..702d746c7 100644 --- a/tsconfig.base.json +++ b/tsconfig.base.json @@ -30,6 +30,9 @@ "@near-wallet-selector/account-export": [ "packages/account-export/src/index.ts" ], + "@near-wallet-selector/arepa-wallet": [ + "packages/arepa-wallet/src/index.ts" + ], "@near-wallet-selector/bitget-wallet": [ "packages/bitget-wallet/src/index.ts" ], diff --git a/yarn.lock b/yarn.lock index 6b84573ad..60c24d448 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3625,10 +3625,10 @@ "@jridgewell/resolve-uri" "^3.1.0" "@jridgewell/sourcemap-codec" "^1.4.14" -"@jscutlery/semver@5.2.2": - version "5.2.2" - resolved "https://registry.yarnpkg.com/@jscutlery/semver/-/semver-5.2.2.tgz#5e1eec2554e38d449c2de4a6c5a41abeb3bc9d7f" - integrity sha512-lhklWnwa5X4N6aiBLbybdsZ37agtxa0EBRdXmjOFA+LzViVR6QIYZpk+/X/XLw/TB6z1rLrmFp/MakmNyaJiYg== +"@jscutlery/semver@5.3.1": + version "5.3.1" + resolved "https://registry.yarnpkg.com/@jscutlery/semver/-/semver-5.3.1.tgz#6a7f0ba7ce40802e0101ea8ac5b155b0031e0c74" + integrity sha512-LJk85tsYnISmRBQid4fjavBYUN8W5QwVQrcZ9KuTv+/D8Qy1A3wbMcc0kfBnnsGwFcKjYTwr4/eGJ/i1HgVk2Q== dependencies: chalk "4.1.2" conventional-changelog "^5.1.0" @@ -4061,14 +4061,14 @@ nanoid "3.3.6" query-string "^7.1.3" -"@mintbase-js/wallet@0.6.0-beta.10": - version "0.6.0-beta.10" - resolved "https://registry.yarnpkg.com/@mintbase-js/wallet/-/wallet-0.6.0-beta.10.tgz#26a6ef1d9a46c117dc4389441b2f780c292afd43" - integrity sha512-i0U5cGLu7WySdfzOPlPO+eN/iQlVaPWo0E12UPWFNjAUrn76WJFvHM0RDHZYg9p+Ex5VTp2lU0vkJu6KtJO9Tw== +"@mintbase-js/wallet@0.6.1": + version "0.6.1" + resolved "https://registry.yarnpkg.com/@mintbase-js/wallet/-/wallet-0.6.1.tgz#09c4feaa5832a33c8e12623572d0edc0596e02c2" + integrity sha512-qU0Pgf7qN7Bs2G7wtUsOueUs77Yvd2CW2zLZWFHpzVstSI3IkYc0NwmW1u6dqXWYHqPinYMiicHtAq4xHbNgug== dependencies: - "@near-wallet-selector/wallet-utils" "^8.9.5" - bn.js "^5.2.1" - near-api-js "^3.0.0" + "@near-wallet-selector/core" "8.9.12" + "@near-wallet-selector/wallet-utils" "^8.9.12" + near-api-js "^4.0.3" "@mischnic/json-sourcemap@^0.1.0": version "0.1.1" @@ -4223,25 +4223,6 @@ uint8-varint "^2.0.1" uint8arrays "^5.0.0" -"@near-js/accounts@1.0.4": - version "1.0.4" - resolved "https://registry.yarnpkg.com/@near-js/accounts/-/accounts-1.0.4.tgz#b699dc1c63ffccc1598481b4260dfaf2507f0a69" - integrity sha512-6zgSwq/rQ9ggPOIkGUx9RoEurbJiojqA/axeh6o1G+46GqUBI7SUcDooyVvZjeiOvUPObnTQptDYpbV+XZji8g== - dependencies: - "@near-js/crypto" "1.2.1" - "@near-js/providers" "0.1.1" - "@near-js/signers" "0.1.1" - "@near-js/transactions" "1.1.2" - "@near-js/types" "0.0.4" - "@near-js/utils" "0.1.0" - ajv "8.11.2" - ajv-formats "2.1.1" - bn.js "5.2.1" - borsh "1.0.0" - depd "2.0.0" - lru_map "0.4.1" - near-abi "0.1.1" - "@near-js/accounts@1.2.1", "@near-js/accounts@^1.2.1": version "1.2.1" resolved "https://registry.yarnpkg.com/@near-js/accounts/-/accounts-1.2.1.tgz#6e5c0315a07997bbaacbe7b9021ac23974a80ea0" @@ -4259,17 +4240,22 @@ lru_map "0.4.1" near-abi "0.1.1" -"@near-js/crypto@1.2.1": - version "1.2.1" - resolved "https://registry.yarnpkg.com/@near-js/crypto/-/crypto-1.2.1.tgz#aa18bed171e68653dae9f82114636eba34ece32a" - integrity sha512-iJOHaGKvdudYfR8nEtRhGlgcTEHeVmxMoT0JVXmuP3peG96v/sSnA03CE6MZBeCC8txKAQOffagxE7oU6hJp9g== +"@near-js/accounts@1.2.2": + version "1.2.2" + resolved "https://registry.yarnpkg.com/@near-js/accounts/-/accounts-1.2.2.tgz#c0ba5a4644c4438c0f339d842dec8d4d55d35cfb" + integrity sha512-8XInUVl8WwQyitRkG1HffZKhDmAXUwOaxurgkTYocDUUUp+ZB8NPxidg2uvj6f2wqnC8KAkjpm73wPoyRm6+yQ== dependencies: - "@near-js/types" "0.0.4" - "@near-js/utils" "0.1.0" - "@noble/curves" "1.2.0" - bn.js "5.2.1" + "@near-js/crypto" "1.3.0" + "@near-js/providers" "0.2.3" + "@near-js/signers" "0.1.5" + "@near-js/transactions" "1.2.3" + "@near-js/types" "0.2.1" + "@near-js/utils" "0.3.0" borsh "1.0.0" - randombytes "2.1.0" + depd "2.0.0" + is-my-json-valid "^2.20.6" + lru_map "0.4.1" + near-abi "0.1.1" "@near-js/crypto@1.2.4", "@near-js/crypto@^1.2.4": version "1.2.4" @@ -4282,6 +4268,18 @@ borsh "1.0.0" randombytes "2.1.0" +"@near-js/crypto@1.3.0": + version "1.3.0" + resolved "https://registry.yarnpkg.com/@near-js/crypto/-/crypto-1.3.0.tgz#ddcfc2a1dc2ad9ac30df5f7ebd36d3408ac379bf" + integrity sha512-BIKO6v+rbYCzzrjsSV4KgClVgRiPluIXQ89B4ozIG8RjjBe/7IPFYF9tIxsXUyLzPFhISzeNQkL09ksHHmnymg== + dependencies: + "@near-js/types" "0.2.1" + "@near-js/utils" "0.3.0" + "@noble/curves" "1.2.0" + borsh "1.0.0" + randombytes "2.1.0" + secp256k1 "5.0.0" + "@near-js/keystores-browser@0.0.12": version "0.0.12" resolved "https://registry.yarnpkg.com/@near-js/keystores-browser/-/keystores-browser-0.0.12.tgz#2a9794a27d1e55ccb549125b29e183eb967fe52c" @@ -4290,13 +4288,13 @@ "@near-js/crypto" "1.2.4" "@near-js/keystores" "0.0.12" -"@near-js/keystores-browser@0.0.9": - version "0.0.9" - resolved "https://registry.yarnpkg.com/@near-js/keystores-browser/-/keystores-browser-0.0.9.tgz#4d6211ad617613124aeee78ede5771b153e3bcdd" - integrity sha512-JzPj+RHJN2G3CEm/LyfbtZDQy/wxgOlqfh52voqPGijUHg93b27KBqtZShazAgJNkhzRbWcoluWQnd2jL8vF7A== +"@near-js/keystores-browser@0.1.0": + version "0.1.0" + resolved "https://registry.yarnpkg.com/@near-js/keystores-browser/-/keystores-browser-0.1.0.tgz#1cd5e08340067c6156c7d402859b70843afba948" + integrity sha512-v/4uFHKnbEXY4UcOAVCUSb3GKsVdrwv4uXBSPluvE16H9oxjB1+gfcz5qejwKp2cifYNCO0KfAWLnZas66Ohcg== dependencies: - "@near-js/crypto" "1.2.1" - "@near-js/keystores" "0.0.9" + "@near-js/crypto" "1.3.0" + "@near-js/keystores" "0.1.0" "@near-js/keystores-node@0.0.12": version "0.0.12" @@ -4306,13 +4304,13 @@ "@near-js/crypto" "1.2.4" "@near-js/keystores" "0.0.12" -"@near-js/keystores-node@0.0.9": - version "0.0.9" - resolved "https://registry.yarnpkg.com/@near-js/keystores-node/-/keystores-node-0.0.9.tgz#c2fd2f5bfbca1c75699dd7324e300cfd12e790ed" - integrity sha512-2B9MYz6uIhysG1fhQSjvaPYCM7gM+UAeDchX0J8QRauXIeN8TGzpcdgkdkMUnWNTIdt3Iblh0ZuCs+FY02dTXg== +"@near-js/keystores-node@0.0.13": + version "0.0.13" + resolved "https://registry.yarnpkg.com/@near-js/keystores-node/-/keystores-node-0.0.13.tgz#408952cbc9e8b5db419c7a6c89ebbf08185abaae" + integrity sha512-cnk2mwIRr7bCPgqz7KHU1Bqxm0u9J+FIubZ0AllFpMVMv8TJVVbs7FcsVIk282oeM7xxikjVJjs35DG6//Fehw== dependencies: - "@near-js/crypto" "1.2.1" - "@near-js/keystores" "0.0.9" + "@near-js/crypto" "1.3.0" + "@near-js/keystores" "0.1.0" "@near-js/keystores@0.0.12": version "0.0.12" @@ -4322,27 +4320,13 @@ "@near-js/crypto" "1.2.4" "@near-js/types" "0.2.1" -"@near-js/keystores@0.0.9": - version "0.0.9" - resolved "https://registry.yarnpkg.com/@near-js/keystores/-/keystores-0.0.9.tgz#768aaaab1beb7f797432513cb1bbf9430e305a85" - integrity sha512-j8ySgVEcm2Gg6zxkSdadNtPlIqhJZdPGfWWM3tPtEoowNS9snhwZn5NRFPrgmX0+MzpF7E091CRcY90MvRVhsg== - dependencies: - "@near-js/crypto" "1.2.1" - "@near-js/types" "0.0.4" - -"@near-js/providers@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@near-js/providers/-/providers-0.1.1.tgz#7489eb5a4248562fe98fdbc4cb55ea3f6d787e0a" - integrity sha512-0M/Vz2Ac34ShKVoe2ftVJ5Qg4eSbEqNXDbCDOdVj/2qbLWZa7Wpe+me5ei4TMY2ZhGdawhgJUPrYwdJzOCyf8w== +"@near-js/keystores@0.1.0": + version "0.1.0" + resolved "https://registry.yarnpkg.com/@near-js/keystores/-/keystores-0.1.0.tgz#3c07fb4d2ec549598bc2db488d05e9fac8df1169" + integrity sha512-89EwYFDvPg7GnJAKmBDASKUSTXny0ZqgqDnSdhp7oJ78bXNlCs9xx0WnkK34TxFBnrL4c9szLjTkfGRcFT07NQ== dependencies: - "@near-js/transactions" "1.1.2" - "@near-js/types" "0.0.4" - "@near-js/utils" "0.1.0" - bn.js "5.2.1" - borsh "1.0.0" - http-errors "1.7.2" - optionalDependencies: - node-fetch "2.6.7" + "@near-js/crypto" "1.3.0" + "@near-js/types" "0.2.1" "@near-js/providers@0.2.2": version "0.2.2" @@ -4357,14 +4341,18 @@ optionalDependencies: node-fetch "2.6.7" -"@near-js/signers@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@near-js/signers/-/signers-0.1.1.tgz#6d32b262eac9b03fab5fc1ee93d2c4055c86980f" - integrity sha512-focJgs04dBUfawMnyGg3yIjaMawuVz2OeLRKC4t5IQDmO4PLfdIraEuwgS7tckMq3GdrJ7nqkwkpSNYpdt7I5Q== +"@near-js/providers@0.2.3": + version "0.2.3" + resolved "https://registry.yarnpkg.com/@near-js/providers/-/providers-0.2.3.tgz#e7d77fbdd8d6e024c0cf361b96663767bf4cb0f7" + integrity sha512-JBSze9fdoRXkOsFeLiooPWGm3vemY2dgHT0u0HoJCjpQtt41v7tr+6sWpxGWCaDwrzIwhm7og4qkGv4K9IxFVw== dependencies: - "@near-js/crypto" "1.2.1" - "@near-js/keystores" "0.0.9" - "@noble/hashes" "1.3.3" + "@near-js/transactions" "1.2.3" + "@near-js/types" "0.2.1" + "@near-js/utils" "0.3.0" + borsh "1.0.0" + http-errors "1.7.2" + optionalDependencies: + node-fetch "2.6.7" "@near-js/signers@0.1.4": version "0.1.4" @@ -4375,18 +4363,14 @@ "@near-js/keystores" "0.0.12" "@noble/hashes" "1.3.3" -"@near-js/transactions@1.1.2": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@near-js/transactions/-/transactions-1.1.2.tgz#7dec18b463cd336e325ee61b1e1c39a6192d9e81" - integrity sha512-AqYA56ncwgrWjIu+bNaWjTPRZb0O+SfpWIP7U+1FKNKxNYMCtkt6zp7SlQeZn743shKVq9qMzA9+ous/KCb0QQ== +"@near-js/signers@0.1.5": + version "0.1.5" + resolved "https://registry.yarnpkg.com/@near-js/signers/-/signers-0.1.5.tgz#4ad10d624f1b13579ce9db95e52a9a8b48251655" + integrity sha512-UldCktmR6HF6N2gPbgiUS8QPYCcDwjyzpdi3ukKezfY2NGA++F068ZwP50S+aQrtcwEBpECTo/Ps6pZq7cSVeQ== dependencies: - "@near-js/crypto" "1.2.1" - "@near-js/signers" "0.1.1" - "@near-js/types" "0.0.4" - "@near-js/utils" "0.1.0" + "@near-js/crypto" "1.3.0" + "@near-js/keystores" "0.1.0" "@noble/hashes" "1.3.3" - bn.js "5.2.1" - borsh "1.0.0" "@near-js/transactions@1.2.2": version "1.2.2" @@ -4400,29 +4384,23 @@ "@noble/hashes" "1.3.3" borsh "1.0.0" -"@near-js/types@0.0.4": - version "0.0.4" - resolved "https://registry.yarnpkg.com/@near-js/types/-/types-0.0.4.tgz#d941689df41c850aeeeaeb9d498418acec515404" - integrity sha512-8TTMbLMnmyG06R5YKWuS/qFG1tOA3/9lX4NgBqQPsvaWmDsa+D+QwOkrEHDegped0ZHQwcjAXjKML1S1TyGYKg== +"@near-js/transactions@1.2.3": + version "1.2.3" + resolved "https://registry.yarnpkg.com/@near-js/transactions/-/transactions-1.2.3.tgz#c666a475ecfa9cfe3f0d14ad9717f46d0c206f04" + integrity sha512-wwkUupWrmKfdZmv6TmnTrskysX37F2SVHcns6BVwPjp6nFD29NAhul71I6u++8496Lq2FrgM1Kb8pEIpG9TV9w== dependencies: - bn.js "5.2.1" + "@near-js/crypto" "1.3.0" + "@near-js/signers" "0.1.5" + "@near-js/types" "0.2.1" + "@near-js/utils" "0.3.0" + "@noble/hashes" "1.3.3" + borsh "1.0.0" "@near-js/types@0.2.1", "@near-js/types@^0.2.1": version "0.2.1" resolved "https://registry.yarnpkg.com/@near-js/types/-/types-0.2.1.tgz#a298f0e70dbe059ee8c762dfac05c2eae3e0ae0e" integrity sha512-YygQEGMdFe6d2e/6dtNZer9paH396XeAdIKEhY/RPXDUnjDdfiDQ5DK4mM130sEeID2bAH9X1LQ+7vXGRjvyWw== -"@near-js/utils@0.1.0": - version "0.1.0" - resolved "https://registry.yarnpkg.com/@near-js/utils/-/utils-0.1.0.tgz#1368f59008c39df1e903bd3e0f308eedcdf25c1d" - integrity sha512-kOVAXmJzaC8ElJD3RLEoBuqOK+d5s7jc0JkvhyEtbuEmXYHHAy9Q17/YkDcX9tyr01L85iOt66z0cODqzgtQwA== - dependencies: - "@near-js/types" "0.0.4" - bn.js "5.2.1" - bs58 "4.0.0" - depd "2.0.0" - mustache "4.0.0" - "@near-js/utils@0.2.2", "@near-js/utils@^0.2.2": version "0.2.2" resolved "https://registry.yarnpkg.com/@near-js/utils/-/utils-0.2.2.tgz#a42c29db9ccd5a02ad583319028fdb7231821ab2" @@ -4433,20 +4411,15 @@ depd "2.0.0" mustache "4.0.0" -"@near-js/wallet-account@1.1.1": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@near-js/wallet-account/-/wallet-account-1.1.1.tgz#e66e8d10fb51f71f7cb722bdff63fb98e2b0d486" - integrity sha512-NnoJKtogBQ7Qz+AP+LdF70BP8Az6UXQori7OjPqJLMo73bn6lh5Ywvegwd1EB7ZEVe4BRt9+f9QkbU5M8ANfAw== - dependencies: - "@near-js/accounts" "1.0.4" - "@near-js/crypto" "1.2.1" - "@near-js/keystores" "0.0.9" - "@near-js/signers" "0.1.1" - "@near-js/transactions" "1.1.2" - "@near-js/types" "0.0.4" - "@near-js/utils" "0.1.0" - bn.js "5.2.1" - borsh "1.0.0" +"@near-js/utils@0.3.0": + version "0.3.0" + resolved "https://registry.yarnpkg.com/@near-js/utils/-/utils-0.3.0.tgz#7add9ea4d42c21a55a8346c1146f44b0e7d709fc" + integrity sha512-ExeWqP0b4subLcQuLDIixAZs6tiCWifDBz2OwU9ycntyjZslUUh4EKBaSS3mAEqhJ/t1B9WX80BntE/5PQ+JTg== + dependencies: + "@near-js/types" "0.2.1" + bs58 "4.0.0" + depd "2.0.0" + mustache "4.0.0" "@near-js/wallet-account@1.2.2": version "1.2.2" @@ -4463,6 +4436,21 @@ "@near-js/utils" "0.2.2" borsh "1.0.0" +"@near-js/wallet-account@1.2.3": + version "1.2.3" + resolved "https://registry.yarnpkg.com/@near-js/wallet-account/-/wallet-account-1.2.3.tgz#48f8cdb75964428a6db1126b2484fa10cd29cdcf" + integrity sha512-yuYKKA8D06ztmbTvbajD8HBjP50x2NbMRPInsSSgNjBnvFA9f2J82SarzDLg+nTsayhMJdFGfArnKgIlO+bUaw== + dependencies: + "@near-js/accounts" "1.2.2" + "@near-js/crypto" "1.3.0" + "@near-js/keystores" "0.1.0" + "@near-js/providers" "0.2.3" + "@near-js/signers" "0.1.5" + "@near-js/transactions" "1.2.3" + "@near-js/types" "0.2.1" + "@near-js/utils" "0.3.0" + borsh "1.0.0" + "@near-snap/sdk@0.6.0": version "0.6.0" resolved "https://registry.yarnpkg.com/@near-snap/sdk/-/sdk-0.6.0.tgz#2c889dcb5c9e08c63363d600db3f66f7c7b40242" @@ -4470,7 +4458,19 @@ dependencies: "@near-wallet-selector/core" "^8.2.0" -"@near-wallet-selector/core@8.9.10", "@near-wallet-selector/core@^8.2.0": +"@near-wallet-selector/core@8.9.12": + version "8.9.12" + resolved "https://registry.yarnpkg.com/@near-wallet-selector/core/-/core-8.9.12.tgz#6ce355fa70f4102122e812365726f82f884472a9" + integrity sha512-S23/IDi07kCr6JN28jxQZPQOwtp3MwZgMVbtwqZz2BP2N1puAFHIvKpUDrS2l2iZPBImHnU3tdOBvw6Yec7DjQ== + dependencies: + "@near-js/providers" "0.2.2" + borsh "0.7.0" + events "3.3.0" + js-sha256 "0.9.0" + near-api-js "4.0.3" + rxjs "7.8.1" + +"@near-wallet-selector/core@^8.2.0": version "8.9.10" resolved "https://registry.yarnpkg.com/@near-wallet-selector/core/-/core-8.9.10.tgz#0e19b22bbe69208c9e82b149682be37f6f9b76c5" integrity sha512-do+DDahRHPzr5VKiFS7NWKyNbspXu64/w7CuSBi8IUDsDsclmV7Os6Hp5HcVAq+X3Whi//NxKGX6mPMb+SRPqw== @@ -4480,13 +4480,13 @@ js-sha256 "0.9.0" rxjs "7.8.1" -"@near-wallet-selector/wallet-utils@^8.9.5": - version "8.9.10" - resolved "https://registry.yarnpkg.com/@near-wallet-selector/wallet-utils/-/wallet-utils-8.9.10.tgz#1e6d97464d995cccb4ec34314a1dd90e63901c39" - integrity sha512-Jq00IUAMvltaH8lvkaI8SRP6JWhqE4c0427ODSv+X10NwlkM8WKul9ZNZMxeCTC2ncZH23kDyaA+3MiYTX+DUg== +"@near-wallet-selector/wallet-utils@^8.9.12": + version "8.9.12" + resolved "https://registry.yarnpkg.com/@near-wallet-selector/wallet-utils/-/wallet-utils-8.9.12.tgz#fd36a2cedf43b7b78da3f9790b09f00d9d30daee" + integrity sha512-3KcZlaaiQ3OyQAqI48Px0dM7Bz3/6gLOgnNepk7BVEygX9h7CuDyVh5Ug3qgObbsDQ59vCLCDey0y0eI4BxkKQ== dependencies: - "@near-wallet-selector/core" "8.9.10" - bn.js "5.2.1" + "@near-wallet-selector/core" "8.9.12" + near-api-js "4.0.3" "@next/env@13.3.0": version "13.3.0" @@ -9024,16 +9024,6 @@ ajv-keywords@^5.1.0: dependencies: fast-deep-equal "^3.1.3" -ajv@8.11.2: - version "8.11.2" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.11.2.tgz#aecb20b50607acf2569b6382167b65a96008bb78" - integrity sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg== - dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" - ajv@8.12.0: version "8.12.0" resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1" @@ -9718,10 +9708,10 @@ before-after-hook@^2.2.0: resolved "https://registry.yarnpkg.com/before-after-hook/-/before-after-hook-2.2.3.tgz#c51e809c81a4e354084422b9b26bad88249c517c" integrity sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ== -better-sqlite3@11.1.2: - version "11.1.2" - resolved "https://registry.yarnpkg.com/better-sqlite3/-/better-sqlite3-11.1.2.tgz#6c9d064c9f1ff2a7f507477648ca0ba67bf564a3" - integrity sha512-gujtFwavWU4MSPT+h9B+4pkvZdyOUkH54zgLdIrMmmmd4ZqiBIrRNBzNzYVFO417xo882uP5HBu4GjOfaSrIQw== +better-sqlite3@11.2.1: + version "11.2.1" + resolved "https://registry.yarnpkg.com/better-sqlite3/-/better-sqlite3-11.2.1.tgz#3c6b8a8e2e12444d380e811796b59c8aba012e03" + integrity sha512-Xbt1d68wQnUuFIEVsbt6V+RG30zwgbtCGQ4QOcXVrOH0FE4eHk64FWZ9NUfRHS4/x1PXqwz/+KOrnXD7f0WieA== dependencies: bindings "^1.5.0" prebuild-install "^7.1.1" @@ -9825,16 +9815,16 @@ bluebird@^3.7.2: resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== -bn.js@5.2.1, bn.js@^5.0.0, bn.js@^5.2.0, bn.js@^5.2.1: - version "5.2.1" - resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.1.tgz#0bc527a6a0d18d0aa8d5b0538ce4a77dccfa7b70" - integrity sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ== - bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.11.9: version "4.12.0" resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== +bn.js@^5.0.0, bn.js@^5.2.0, bn.js@^5.2.1: + version "5.2.1" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.1.tgz#0bc527a6a0d18d0aa8d5b0538ce4a77dccfa7b70" + integrity sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ== + body-parser@1.20.2: version "1.20.2" resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.2.tgz#6feb0e21c4724d06de7ff38da36dad4f57a747fd" @@ -17778,26 +17768,23 @@ near-api-js@4.0.3, near-api-js@^4.0.0: near-abi "0.1.1" node-fetch "2.6.7" -near-api-js@^3.0.0: - version "3.0.4" - resolved "https://registry.yarnpkg.com/near-api-js/-/near-api-js-3.0.4.tgz#5ee094ce53e30239cc817ca942ec3e9739296dbb" - integrity sha512-qKWjnugoB7kSFhzZ5GXyH/eABspCQYWBmWnM4hpV5ctnQBt89LqgEu9yD1z4sa89MvUu8BuCxwb1m00BE8iofg== - dependencies: - "@near-js/accounts" "1.0.4" - "@near-js/crypto" "1.2.1" - "@near-js/keystores" "0.0.9" - "@near-js/keystores-browser" "0.0.9" - "@near-js/keystores-node" "0.0.9" - "@near-js/providers" "0.1.1" - "@near-js/signers" "0.1.1" - "@near-js/transactions" "1.1.2" - "@near-js/types" "0.0.4" - "@near-js/utils" "0.1.0" - "@near-js/wallet-account" "1.1.1" +near-api-js@^4.0.3: + version "4.0.4" + resolved "https://registry.yarnpkg.com/near-api-js/-/near-api-js-4.0.4.tgz#e04ef1fa051d3291c1a9bf1b4f07f880c49f80ca" + integrity sha512-IG+6NAMtn854palu/cIbVgey0OsIzllcajc3fbEbh7cb2pyPNMsfsBIO5WqsV+rY+7Tqr6lqYQ8f+4BHGUttyg== + dependencies: + "@near-js/accounts" "1.2.2" + "@near-js/crypto" "1.3.0" + "@near-js/keystores" "0.1.0" + "@near-js/keystores-browser" "0.1.0" + "@near-js/keystores-node" "0.0.13" + "@near-js/providers" "0.2.3" + "@near-js/signers" "0.1.5" + "@near-js/transactions" "1.2.3" + "@near-js/types" "0.2.1" + "@near-js/utils" "0.3.0" + "@near-js/wallet-account" "1.2.3" "@noble/curves" "1.2.0" - ajv "8.11.2" - ajv-formats "2.1.1" - bn.js "5.2.1" borsh "1.0.0" depd "2.0.0" http-errors "1.7.2" @@ -20160,6 +20147,15 @@ qrcode@1.5.3: pngjs "^5.0.0" yargs "^15.3.1" +qrcode@1.5.4: + version "1.5.4" + resolved "https://registry.yarnpkg.com/qrcode/-/qrcode-1.5.4.tgz#5cb81d86eb57c675febb08cf007fff963405da88" + integrity sha512-1ca71Zgiu6ORjHqFBDpnSMTR2ReToX4l1Au1VFLyVeBTFavzQnv5JxMFr3ukHVKpSrSA2MCk0lNJSykjUfz7Zg== + dependencies: + dijkstrajs "^1.0.1" + pngjs "^5.0.0" + yargs "^15.3.1" + qs@6.11.0: version "6.11.0" resolved "https://registry.yarnpkg.com/qs/-/qs-6.11.0.tgz#fd0d963446f7a65e1367e01abd85429453f0c37a" @@ -21055,7 +21051,7 @@ scrypt-js@3.0.1: resolved "https://registry.yarnpkg.com/scrypt-js/-/scrypt-js-3.0.1.tgz#d314a57c2aef69d1ad98a138a21fe9eafa9ee312" integrity sha512-cdwTTnqPu0Hyvf5in5asVdZocVDTNRmR7XEcJuIzMjJeSHybHl7vpB66AzwTaIg6CLSbtjcxc8fqcySfnTkccA== -secp256k1@^5.0.0: +secp256k1@5.0.0, secp256k1@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/secp256k1/-/secp256k1-5.0.0.tgz#be6f0c8c7722e2481e9773336d351de8cddd12f7" integrity sha512-TKWX8xvoGHrxVdqbYeZM9w+izTF4b9z3NhSaDkdn81btvuh+ivbIMGT/zQvDtTFWhRlThpoz6LEYTr7n8A5GcA== @@ -22577,10 +22573,10 @@ tslib@2.5.3: resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.5.3.tgz#24944ba2d990940e6e982c4bea147aba80209913" integrity sha512-mSxlJJwl3BMEQCUNnxXBU9jP4JBktcEGhURcPR6VQVlnP0FdDEsIaz0C35dXNGLyRfrATNofF0F5p2KPxQgB+w== -tslib@2.6.3, tslib@^2.0.0, tslib@^2.0.3, tslib@^2.1.0, tslib@^2.3.0, tslib@^2.3.1, tslib@^2.4.0: - version "2.6.3" - resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.3.tgz#0438f810ad7a9edcde7a241c3d80db693c8cbfe0" - integrity sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ== +tslib@2.7.0, tslib@^2.0.0, tslib@^2.0.3, tslib@^2.1.0, tslib@^2.3.0, tslib@^2.3.1, tslib@^2.4.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.7.0.tgz#d9b40c5c40ab59e8738f297df3087bf1a2690c01" + integrity sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA== tsutils@^3.21.0: version "3.21.0"