From 50b1d8616fa124b4dd820d684db712962ffb94f7 Mon Sep 17 00:00:00 2001 From: kujtimprenkuSQA Date: Wed, 1 Nov 2023 11:03:11 +0100 Subject: [PATCH] Remove opto wallet from the repo. --- README.md | 5 - examples/angular/project.json | 5 - .../wallet-selector-export.component.ts | 2 - .../wallet-selector.component.ts | 2 - .../react/contexts/WalletSelectorContext.tsx | 4 +- .../contexts/WalletSelectorExportContext.tsx | 2 - examples/react/project.json | 5 - package.json | 2 - packages/opto-wallet/.babelrc | 10 - packages/opto-wallet/.eslintrc.json | 18 -- packages/opto-wallet/README.md | 63 ----- .../opto-wallet/assets/opto-wallet-icon.png | Bin 43577 -> 0 bytes packages/opto-wallet/jest.config.js | 14 - packages/opto-wallet/jest.config.ts | 16 -- packages/opto-wallet/package.json | 27 -- packages/opto-wallet/project.json | 56 ---- packages/opto-wallet/src/index.ts | 2 - packages/opto-wallet/src/lib/icon.ts | 1 - .../opto-wallet/src/lib/opto-wallet.spec.ts | 155 ---------- packages/opto-wallet/src/lib/opto-wallet.ts | 264 ------------------ packages/opto-wallet/tsconfig.json | 19 -- packages/opto-wallet/tsconfig.lib.json | 10 - packages/opto-wallet/tsconfig.spec.json | 9 - .../src/lib/wallet-connect-client.ts | 5 - scripts/release-packages.bash | 1 - tsconfig.base.json | 3 - 26 files changed, 1 insertion(+), 699 deletions(-) delete mode 100644 packages/opto-wallet/.babelrc delete mode 100644 packages/opto-wallet/.eslintrc.json delete mode 100644 packages/opto-wallet/README.md delete mode 100644 packages/opto-wallet/assets/opto-wallet-icon.png delete mode 100644 packages/opto-wallet/jest.config.js delete mode 100644 packages/opto-wallet/jest.config.ts delete mode 100644 packages/opto-wallet/package.json delete mode 100644 packages/opto-wallet/project.json delete mode 100644 packages/opto-wallet/src/index.ts delete mode 100644 packages/opto-wallet/src/lib/icon.ts delete mode 100644 packages/opto-wallet/src/lib/opto-wallet.spec.ts delete mode 100644 packages/opto-wallet/src/lib/opto-wallet.ts delete mode 100644 packages/opto-wallet/tsconfig.json delete mode 100644 packages/opto-wallet/tsconfig.lib.json delete mode 100644 packages/opto-wallet/tsconfig.spec.json diff --git a/README.md b/README.md index e81c263bf..76822660e 100644 --- a/README.md +++ b/README.md @@ -19,7 +19,6 @@ NEAR Wallet Selector makes it easy for users to interact with your dApp by provi - [Nightly Connect](https://www.npmjs.com/package/@near-wallet-selector/nightly-connect) - Bridge wallet. - [Here Wallet](https://www.npmjs.com/package/@near-wallet-selector/here-wallet) - Mobile wallet. - [NearFi Wallet](https://www.npmjs.com/package/@near-wallet-selector/nearfi) - Mobile wallet. -- [Opto Wallet](https://www.npmjs.com/package/@near-wallet-selector/opto-wallet) - Mobile wallet & Browser wallet. - [Ramper Wallet](https://www.npmjs.com/package/@near-wallet-selector/ramper-wallet) - Browser wallet. - [Near Mobile Wallet](https://nearmobile.app/) - Mobile Wallet. @@ -69,7 +68,6 @@ yarn add \ @near-wallet-selector/wallet-connect \ @near-wallet-selector/nightly-connect \ @near-wallet-selector/coin98-wallet \ - @near-wallet-selector/opto-wallet \ @near-wallet-selector/neth \ @near-wallet-selector/xdefi \ @near-wallet-selector/ramper-wallet \ @@ -92,7 +90,6 @@ npm install \ @near-wallet-selector/wallet-connect \ @near-wallet-selector/nightly-connect \ @near-wallet-selector/coin98-wallet \ - @near-wallet-selector/opto-wallet \ @near-wallet-selector/neth \ @near-wallet-selector/xdefi \ @near-wallet-selector/ramper-wallet \ @@ -130,7 +127,6 @@ import { setupWalletConnect } from "@near-wallet-selector/wallet-connect"; import { setupNightlyConnect } from "@near-wallet-selector/nightly-connect"; import { setupNearFi } from "@near-wallet-selector/nearfi"; import { setupCoin98Wallet } from "@near-wallet-selector/coin98-wallet"; -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; import { setupNeth } from "@near-wallet-selector/neth"; import { setupXDEFI } from "@near-wallet-selector/xdefi"; import { setupRamperWallet } from "@near-wallet-selector/ramper-wallet"; @@ -152,7 +148,6 @@ const selector = await setupWalletSelector({ setupLedger(), setupNearFi(), setupCoin98Wallet(), - setupOptoWallet(), setupNeth(), setupXDEFI(), setupWalletConnect({ diff --git a/examples/angular/project.json b/examples/angular/project.json index 203eb9fa5..003d6f6e6 100644 --- a/examples/angular/project.json +++ b/examples/angular/project.json @@ -84,11 +84,6 @@ "input": "packages/coin98-wallet/assets/", "output": "assets/" }, - { - "glob": "**/*", - "input": "packages/opto-wallet/assets/", - "output": "assets/" - }, { "glob": "**/*", "input": "packages/finer-wallet/assets/", diff --git a/examples/angular/src/app/pages/wallet-selector-export/wallet-selector-export.component.ts b/examples/angular/src/app/pages/wallet-selector-export/wallet-selector-export.component.ts index 3d271d0d0..fdc608bae 100644 --- a/examples/angular/src/app/pages/wallet-selector-export/wallet-selector-export.component.ts +++ b/examples/angular/src/app/pages/wallet-selector-export/wallet-selector-export.component.ts @@ -14,7 +14,6 @@ import { setupHereWallet } from "@near-wallet-selector/here-wallet"; import { setupCoin98Wallet } from "@near-wallet-selector/coin98-wallet"; import { setupNearFi } from "@near-wallet-selector/nearfi"; import { setupNeth } from "@near-wallet-selector/neth"; -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; import { setupFinerWallet } from "@near-wallet-selector/finer-wallet"; import { setupWalletConnect } from "@near-wallet-selector/wallet-connect"; import { setupNightlyConnect } from "@near-wallet-selector/nightly-connect"; @@ -71,7 +70,6 @@ export class WalletSelectorExportComponent implements OnInit { setupNeth({ bundle: false, }), - setupOptoWallet(), setupFinerWallet(), setupWalletConnect({ projectId: "c4f79cc...", 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 b8f271395..462747134 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 @@ -16,7 +16,6 @@ import { setupCoin98Wallet } from "@near-wallet-selector/coin98-wallet"; import { setupNearFi } from "@near-wallet-selector/nearfi"; import { setupNearSnap } from "@near-wallet-selector/near-snap"; import { setupNeth } from "@near-wallet-selector/neth"; -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; import { setupFinerWallet } from "@near-wallet-selector/finer-wallet"; import { setupWalletConnect } from "@near-wallet-selector/wallet-connect"; import { setupNightlyConnect } from "@near-wallet-selector/nightly-connect"; @@ -74,7 +73,6 @@ export class WalletSelectorComponent implements OnInit { setupNeth({ bundle: false, }), - setupOptoWallet(), setupFinerWallet(), setupWalletConnect({ projectId: "c8cb6204543639c31aef44ea4837a554", // Replace this with your own projectId form WalletConnect. diff --git a/examples/react/contexts/WalletSelectorContext.tsx b/examples/react/contexts/WalletSelectorContext.tsx index 36d0d18c5..a552a3e90 100644 --- a/examples/react/contexts/WalletSelectorContext.tsx +++ b/examples/react/contexts/WalletSelectorContext.tsx @@ -16,7 +16,6 @@ import { setupWalletConnect } from "@near-wallet-selector/wallet-connect"; import { setupWelldoneWallet } from "@near-wallet-selector/welldone-wallet"; import { setupNearSnap } from "@near-wallet-selector/near-snap"; import { setupNeth } from "@near-wallet-selector/neth"; -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; import { setupFinerWallet } from "@near-wallet-selector/finer-wallet"; import { setupMyNearWallet } from "@near-wallet-selector/my-near-wallet"; import { setupLedger } from "@near-wallet-selector/ledger"; @@ -85,11 +84,10 @@ export const WalletSelectorContextProvider: React.FC<{ gas: "300000000000000", bundle: false, }), - setupOptoWallet(), setupFinerWallet(), setupXDEFI(), setupWalletConnect({ - projectId: "c4f79cc...", + projectId: "c8cb6204543639c31aef44ea4837a554", metadata: { name: "NEAR Wallet Selector", description: "Example dApp used by NEAR Wallet Selector", diff --git a/examples/react/contexts/WalletSelectorExportContext.tsx b/examples/react/contexts/WalletSelectorExportContext.tsx index ac232ed49..52ba9cc49 100644 --- a/examples/react/contexts/WalletSelectorExportContext.tsx +++ b/examples/react/contexts/WalletSelectorExportContext.tsx @@ -22,7 +22,6 @@ import { setupNightlyConnect } from "@near-wallet-selector/nightly-connect"; import { setupNearFi } from "@near-wallet-selector/nearfi"; import { setupWalletConnect } from "@near-wallet-selector/wallet-connect"; import { setupCoin98Wallet } from "@near-wallet-selector/coin98-wallet"; -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; import { Loading } from "../components/Loading"; import { setupMyNearWallet } from "@near-wallet-selector/my-near-wallet"; import { setupLedger } from "@near-wallet-selector/ledger"; @@ -70,7 +69,6 @@ export const ExportAccountSelectorContextProvider: React.FC<{ setupHereWallet(), setupCoin98Wallet(), setupNearFi(), - setupOptoWallet(), setupRamperWallet(), setupWalletConnect({ projectId: "c4f79cc...", diff --git a/examples/react/project.json b/examples/react/project.json index aedc4faa6..29575af92 100644 --- a/examples/react/project.json +++ b/examples/react/project.json @@ -77,11 +77,6 @@ "input": "packages/coin98-wallet/assets/", "output": "assets/" }, - { - "glob": "**/*", - "input": "packages/opto-wallet/assets/", - "output": "assets/" - }, { "glob": "**/*", "input": "packages/finer-wallet/assets/", diff --git a/package.json b/package.json index 281f1e6ba..e32f78079 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,6 @@ "nearfi", "meteor-wallet", "welldone-wallet", - "opto-wallet", "finer-wallet", "ramper-wallet", "near-mobile-wallet" @@ -60,7 +59,6 @@ "build:wallet-connect": "nx run-many --target=build --projects=wallet-connect --configuration=production", "build:nightly-connect": "nx run-many --target=build --projects=nightly-connect --configuration=production", "build:narwallets": "nx run-many --target=build --projects=narwallets --configuration=production", - "build:opto-wallet": "nx run-many --target=build --projects=opto-wallet --configuration=production", "build:finer-wallet": "nx run-many --target=build --projects=finer-wallet --configuration=production", "build:xdefi-wallet": "nx run-many --target=build --projects=xdefi --configuration=production", "build:wallet-utils": "nx run-many --target=build --projects=wallet-utils --configuration=production", diff --git a/packages/opto-wallet/.babelrc b/packages/opto-wallet/.babelrc deleted file mode 100644 index b63f0528f..000000000 --- a/packages/opto-wallet/.babelrc +++ /dev/null @@ -1,10 +0,0 @@ -{ - "presets": [ - [ - "@nrwl/js/babel", - { - "useBuiltIns": "usage" - } - ] - ] -} diff --git a/packages/opto-wallet/.eslintrc.json b/packages/opto-wallet/.eslintrc.json deleted file mode 100644 index 9d9c0db55..000000000 --- a/packages/opto-wallet/.eslintrc.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "extends": ["../../.eslintrc.json"], - "ignorePatterns": ["!**/*"], - "overrides": [ - { - "files": ["*.ts", "*.tsx", "*.js", "*.jsx"], - "rules": {} - }, - { - "files": ["*.ts", "*.tsx"], - "rules": {} - }, - { - "files": ["*.js", "*.jsx"], - "rules": {} - } - ] -} diff --git a/packages/opto-wallet/README.md b/packages/opto-wallet/README.md deleted file mode 100644 index 9075406be..000000000 --- a/packages/opto-wallet/README.md +++ /dev/null @@ -1,63 +0,0 @@ -# @near-wallet-selector/opto-wallet - -This is the [Opto Wallet](https://optowallet.com/) 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/opto-wallet - -# Using NPM. -npm install @near-wallet-selector/opto-wallet -``` - -Then use it in your dApp: - -```ts -import { setupWalletSelector } from "@near-wallet-selector/core"; -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; - -// My NEAR Wallet for Wallet Selector can be setup without any params or it can take few optional params, see options below. -const optoWallet = setupOptoWallet({ - walletUrl: "https://app.testnet.optowallet.com", - iconUrl: "https://" // optional -}); - -const selector = await setupWalletSelector({ - network: "testnet", - modules: [optoWallet], -}); -``` - -## 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/opto-wallet-icon.png`. -- `deprecated`: (`boolean?`): Deprecated is optional. Default is `false`. - -## Assets - -Assets such as icons can be found in the `/assets` directory of the package. Below is an example using Webpack: - -```ts -import { setupOptoWallet } from "@near-wallet-selector/opto-wallet"; -import optoWalletIconUrl from "@near-wallet-selector/opto-wallet/assets/opto-wallet-icon.png"; - -const optoWallet = setupOptoWallet({ - iconUrl: optoWalletIconUrl -}); -``` - -## License - -This repository is distributed under the terms of both the MIT license and the Apache License (Version 2.0). diff --git a/packages/opto-wallet/assets/opto-wallet-icon.png b/packages/opto-wallet/assets/opto-wallet-icon.png deleted file mode 100644 index 133b8ca56e18f74b732fb72006eee0e3257af472..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 43577 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 @rd_sU>Qa=^ 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 cBTc/tsconfig.spec.json", - }, - }, - transform: { - "^.+\\.[tj]sx?$": "ts-jest", - }, - moduleFileExtensions: ["ts", "tsx", "js", "jsx"], - coverageDirectory: "../../coverage/packages/opto-wallet", -}; diff --git a/packages/opto-wallet/jest.config.ts b/packages/opto-wallet/jest.config.ts deleted file mode 100644 index ccd374f3b..000000000 --- a/packages/opto-wallet/jest.config.ts +++ /dev/null @@ -1,16 +0,0 @@ -/* eslint-disable */ -export default { - displayName: "opto-wallet", - preset: "../../jest.preset.js", - globals: {}, - transform: { - "^.+\\.[tj]s$": [ - "ts-jest", - { - tsconfig: "/tsconfig.spec.json", - }, - ], - }, - moduleFileExtensions: ["ts", "tsx", "js", "jsx"], - coverageDirectory: "../../coverage/packages/opto-wallet", -}; diff --git a/packages/opto-wallet/package.json b/packages/opto-wallet/package.json deleted file mode 100644 index 3e3749b42..000000000 --- a/packages/opto-wallet/package.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "name": "@near-wallet-selector/opto-wallet", - "version": "8.7.0", - "description": "Opto wallet package for NEAR Wallet Selector.", - "keywords": [ - "near", - "blockchain", - "wallets", - "dapps", - "near-protocol", - "near-blockchain", - "wallet selector", - "browser wallet", - "opto 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/opto-wallet", - "peerDependencies": { - "near-api-js": "^1.0.0 || ^2.0.0" - } -} diff --git a/packages/opto-wallet/project.json b/packages/opto-wallet/project.json deleted file mode 100644 index 61489a20d..000000000 --- a/packages/opto-wallet/project.json +++ /dev/null @@ -1,56 +0,0 @@ -{ - "name": "opto-wallet", - "$schema": "../../node_modules/nx/schemas/project-schema.json", - "sourceRoot": "packages/opto-wallet/src", - "projectType": "library", - "targets": { - "build": { - "executor": "@nrwl/rollup:rollup", - "outputs": ["{options.outputPath}"], - "options": { - "outputPath": "dist/packages/opto-wallet", - "tsConfig": "packages/opto-wallet/tsconfig.lib.json", - "project": "packages/opto-wallet/package.json", - "entryFile": "packages/opto-wallet/src/index.ts", - "buildableProjectDepsInPackageJsonType": "dependencies", - "compiler": "babel", - "format": ["esm", "cjs"], - "assets": [ - { - "glob": "packages/opto-wallet/README.md", - "input": ".", - "output": "." - }, - { - "glob": "packages/opto-wallet/assets/*", - "input": ".", - "output": "assets" - } - ] - } - }, - "lint": { - "executor": "@nx/linter:eslint", - "outputs": ["{options.outputFile}"], - "options": { - "lintFilePatterns": ["packages/opto-wallet/**/*.ts"] - } - }, - "test": { - "executor": "@nx/jest:jest", - "outputs": ["{workspaceRoot}/coverage/packages/opto-wallet"], - "options": { - "jestConfig": "packages/opto-wallet/jest.config.ts", - "passWithNoTests": true - } - }, - "deploy": { - "executor": "ngx-deploy-npm:deploy", - "options": { - "access": "public" - }, - "dependsOn": ["^deploy"] - } - }, - "tags": ["browser-wallet"] -} diff --git a/packages/opto-wallet/src/index.ts b/packages/opto-wallet/src/index.ts deleted file mode 100644 index ef1ade385..000000000 --- a/packages/opto-wallet/src/index.ts +++ /dev/null @@ -1,2 +0,0 @@ -export { setupOptoWallet } from "./lib/opto-wallet"; -export type { OptoWalletParams } from "./lib/opto-wallet"; diff --git a/packages/opto-wallet/src/lib/icon.ts b/packages/opto-wallet/src/lib/icon.ts deleted file mode 100644 index ee9fac43b..000000000 --- a/packages/opto-wallet/src/lib/icon.ts +++ /dev/null @@ -1 +0,0 @@ -export default ``; diff --git a/packages/opto-wallet/src/lib/opto-wallet.spec.ts b/packages/opto-wallet/src/lib/opto-wallet.spec.ts deleted file mode 100644 index 541b1dc4d..000000000 --- a/packages/opto-wallet/src/lib/opto-wallet.spec.ts +++ /dev/null @@ -1,155 +0,0 @@ -/* 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"; - -declare global { - interface Window { - opto: object | undefined; - } -} - -const createOptoWallet = 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 { setupOptoWallet } = require("./opto-wallet"); - const { wallet } = await mockWallet(setupOptoWallet(), deps); - - return { - nearApiJs: require("near-api-js"), - wallet, - walletConnection, - account, - }; -}; - -afterEach(() => { - jest.resetModules(); -}); - -describe("signIn", () => { - it("sign into near wallet", async () => { - window.opto = {}; - const { wallet, nearApiJs } = await createOptoWallet(); - - await wallet.signIn({ contractId: "test.testnet" }); - - expect(nearApiJs.connect).toHaveBeenCalled(); - }); -}); - -describe("signOut", () => { - it("sign out of near wallet", async () => { - window.opto = {}; - const { wallet, walletConnection } = await createOptoWallet(); - - await wallet.signIn({ contractId: "test.testnet" }); - await wallet.signOut(); - - expect(walletConnection.signOut).toHaveBeenCalled(); - }); -}); - -describe("getAccounts", () => { - it("returns array of accounts", async () => { - window.opto = {}; - const { wallet, walletConnection } = await createOptoWallet(); - - 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 () => { - window.opto = {}; - const { wallet, walletConnection, account } = await createOptoWallet(); - - 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); - }); -}); - -describe("verifyOwner", () => { - it("verifies owner", async () => { - window.opto = {}; - const { wallet } = await createOptoWallet(); - - const replace = window.location.replace; - - await wallet.signIn({ contractId: "test.testnet" }); - - Object.defineProperty(window, "location", { - value: { replace: jest.fn() }, - }); - - const result = await wallet.verifyOwner({ - message: "message", - callbackUrl: "http://localhost", - }); - - expect(result).toBe(undefined); - expect(window.location.replace).toHaveBeenCalled(); - - window.location.replace = replace; - }); -}); diff --git a/packages/opto-wallet/src/lib/opto-wallet.ts b/packages/opto-wallet/src/lib/opto-wallet.ts deleted file mode 100644 index 52183ea5d..000000000 --- a/packages/opto-wallet/src/lib/opto-wallet.ts +++ /dev/null @@ -1,264 +0,0 @@ -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"; - -declare global { - interface Window { - opto: object | undefined; - } -} - -export interface OptoWalletParams { - walletUrl?: string; - iconUrl?: string; - deprecated?: boolean; -} - -interface OptoWalletState { - wallet: nearAPI.WalletConnection; - keyStore: nearAPI.keyStores.BrowserLocalStorageKeyStore; -} - -interface OptoWalletExtraOptions { - walletUrl: string; -} - -const resolveWalletUrl = (network: Network, walletUrl?: string) => { - if (walletUrl) { - return walletUrl; - } - - switch (network.networkId) { - case "mainnet": - return "https://app.optowallet.com"; - case "testnet": - return "https://app.testnet.optowallet.com"; - default: - throw new Error("Invalid wallet url"); - } -}; - -const setupWalletState = async ( - params: OptoWalletExtraOptions, - 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 OptoWallet: WalletBehaviourFactory< - BrowserWallet, - { params: OptoWalletExtraOptions } -> = async ({ metadata, options, store, params, logger }) => { - const _state = await setupWalletState(params, options.network); - - const getAccounts = async (): Promise> => { - const accountId: string | null = _state.wallet.getAccountId(); - - if (!accountId) { - return []; - } - - const account = _state.wallet.account(); - - return [ - { - accountId, - publicKey: account - ? ( - await account.connection.signer.getPublicKey( - account.accountId, - options.network.networkId - ) - ).toString() - : undefined, - }, - ]; - }; - - 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 }) { - const existingAccounts = await getAccounts(); - - if (existingAccounts.length) { - return existingAccounts; - } - - await _state.wallet.requestSignIn({ contractId, methodNames }); - - return getAccounts(); - }, - - async signOut() { - if (_state.wallet.isSignedIn()) { - _state.wallet.signOut(); - } - }, - - async getAccounts() { - return getAccounts(); - }, - - async verifyOwner({ message, callbackUrl, meta }) { - logger.log("verifyOwner", { message }); - - const account = _state.wallet.account(); - - if (!account) { - throw new Error("Wallet not signed in"); - } - 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 encodedUrl = encodeURIComponent(url); - const extraMeta = meta ? `&meta=${meta}` : ""; - - window.location.replace( - `${params.walletUrl}/verify-owner?message=${message}&callbackUrl=${encodedUrl}${extraMeta}` - ); - - 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 setupOptoWallet({ - walletUrl, - iconUrl = icon, - deprecated = false, -}: OptoWalletParams = {}): WalletModuleFactory { - return async (moduleOptions) => { - if (!window.opto) { - return null; - } - - return { - id: "opto-wallet", - type: "browser", - metadata: { - name: "OptoWallet", - description: "Have Sign of your Crypto with Opto Wallet.", - iconUrl, - deprecated, - available: true, - walletUrl: resolveWalletUrl(moduleOptions.options.network, walletUrl), - }, - init: (options) => { - return OptoWallet({ - ...options, - params: { - walletUrl: resolveWalletUrl(options.options.network, walletUrl), - }, - }); - }, - }; - }; -} diff --git a/packages/opto-wallet/tsconfig.json b/packages/opto-wallet/tsconfig.json deleted file mode 100644 index 8b6d6acaf..000000000 --- a/packages/opto-wallet/tsconfig.json +++ /dev/null @@ -1,19 +0,0 @@ -{ - "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/opto-wallet/tsconfig.lib.json b/packages/opto-wallet/tsconfig.lib.json deleted file mode 100644 index b3f90c22f..000000000 --- a/packages/opto-wallet/tsconfig.lib.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "extends": "./tsconfig.json", - "compilerOptions": { - "outDir": "../../dist/out-tsc", - "declaration": true, - "types": [] - }, - "include": ["**/*.ts"], - "exclude": ["jest.config.ts", "**/*.spec.ts"] -} diff --git a/packages/opto-wallet/tsconfig.spec.json b/packages/opto-wallet/tsconfig.spec.json deleted file mode 100644 index 546f12877..000000000 --- a/packages/opto-wallet/tsconfig.spec.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "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/wallet-connect/src/lib/wallet-connect-client.ts b/packages/wallet-connect/src/lib/wallet-connect-client.ts index e7a8ee072..8356a73e5 100644 --- a/packages/wallet-connect/src/lib/wallet-connect-client.ts +++ b/packages/wallet-connect/src/lib/wallet-connect-client.ts @@ -7,10 +7,6 @@ import type { WalletEvents, } from "@near-wallet-selector/core"; -// NEAR supported WalletIds from WalletConnect Explorer. -const OPTO_WALLET = - "9504a1c1a86cc0702b2d3e47049e1389b373fb2ff22de3208c748d62912433a4"; - class WalletConnectClient { private client: Client; private emitter: EventEmitterService; @@ -55,7 +51,6 @@ class WalletConnectClient { projectId, chains: [chainId], explorerExcludedWalletIds: "ALL", - explorerRecommendedWalletIds: [OPTO_WALLET], }); return new Promise((resolve, reject) => { diff --git a/scripts/release-packages.bash b/scripts/release-packages.bash index 361dc390d..1a5e28271 100644 --- a/scripts/release-packages.bash +++ b/scripts/release-packages.bash @@ -19,7 +19,6 @@ npm publish dist/packages/meteor-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/here-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/coin98-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/nearfi --tag "${TAG}" --otp "${OTP}" -npm publish dist/packages/opto-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/finer-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/welldone-wallet --tag "${TAG}" --otp "${OTP}" npm publish dist/packages/neth --tag "${TAG}" --otp "${OTP}" diff --git a/tsconfig.base.json b/tsconfig.base.json index f772c226c..934eaa3fd 100644 --- a/tsconfig.base.json +++ b/tsconfig.base.json @@ -77,9 +77,6 @@ "@near-wallet-selector/nightly-connect": [ "packages/nightly-connect/src/index.ts" ], - "@near-wallet-selector/opto-wallet": [ - "packages/opto-wallet/src/index.ts" - ], "@near-wallet-selector/sender": [ "packages/sender/src/index.ts" ],