Skip to content

Commit

Permalink
feature: migrate from ethers to viem (wip)
Browse files Browse the repository at this point in the history
  • Loading branch information
piotr-roslaniec committed Dec 21, 2023
1 parent 70b5794 commit 1fb32bd
Show file tree
Hide file tree
Showing 66 changed files with 1,447 additions and 706 deletions.
2 changes: 2 additions & 0 deletions .eslintignore
Original file line number Diff line number Diff line change
@@ -1 +1,3 @@
*.md
**/dist/**
**/build/**
9 changes: 6 additions & 3 deletions demos/taco-demo/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,9 @@
"build": "pnpm clean && webpack --mode production --progress",
"clean": "rimraf build",
"check": "pnpm type-check && pnpm build",
"type-check": "tsc --noEmit"
"type-check": "tsc --noEmit",
"lint": "eslint --ext .ts src",
"lint:fix": "pnpm lint --fix"
},
"dependencies": {
"@nucypher/taco": "^0.1.0-rc.6",
Expand All @@ -21,7 +23,8 @@
"react": "^18.2.0",
"react-copy-to-clipboard": "^5.1.0",
"react-dom": "^18.2.0",
"react-spinners": "^0.13.6"
"react-spinners": "^0.13.6",
"viem": "^1.19.9"
},
"devDependencies": {
"@pmmmwh/react-refresh-webpack-plugin": "^0.5.7",
Expand All @@ -34,7 +37,7 @@
"react-refresh": "^0.14.0",
"rimraf": "^5.0.5",
"stream-browserify": "^3.0.0",
"typescript": "^4.8.3",
"typescript": "^5.2.2",
"webpack": "^5.89.0",
"webpack-cli": "^5.1.4",
"webpack-dev-server": "^4.11.1"
Expand Down
36 changes: 28 additions & 8 deletions demos/taco-demo/src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,16 @@ import {
ThresholdMessageKit,
} from '@nucypher/taco';
import { Mumbai, useEthers } from '@usedapp/core';
import { ethers } from 'ethers';
import React, { useEffect, useState } from 'react';
import 'viem/window';

import { createPublicClient, createWalletClient, custom } from 'viem';

import { ConditionBuilder } from './ConditionBuilder';
import { DEFAULT_DOMAIN, DEFAULT_RITUAL_ID } from './config';
import { Decrypt } from './Decrypt';
import { Encrypt } from './Encrypt';
import { Spinner } from './Spinner';
import { DEFAULT_DOMAIN, DEFAULT_RITUAL_ID } from './config';

export default function App() {
const { activateBrowserWallet, deactivate, account, switchNetwork } =
Expand All @@ -36,42 +38,60 @@ export default function App() {
}, []);

const encryptMessage = async (message: string) => {
if (!window.ethereum) {
console.error('You need to connect to your wallet first');
return;
}
if (!condition) {
return;
}
setLoading(true);

await switchNetwork(Mumbai.chainId);

const provider = new ethers.providers.Web3Provider(window.ethereum);
const publicClient = createPublicClient({
transport: custom(window.ethereum),
});
const walletClient = createWalletClient({
transport: custom(window.ethereum),
});
const encryptedMessage = await encrypt(
provider,
publicClient,
domain,
message,
condition,
ritualId,
provider.getSigner(),
walletClient,
);

setEncryptedMessage(encryptedMessage);
setLoading(false);
};

const decryptMessage = async (encryptedMessage: ThresholdMessageKit) => {
if (!window.ethereum) {
console.error('You need to connect to your wallet first');
return;
}
if (!condition) {
return;
}
setLoading(true);
setDecryptedMessage('');
setDecryptionErrors([]);

const provider = new ethers.providers.Web3Provider(window.ethereum);
const publicClient = createPublicClient({
transport: custom(window.ethereum),
});
const walletClient = createWalletClient({
transport: custom(window.ethereum),
});
const decryptedMessage = await decrypt(
provider,
publicClient,
domain,
encryptedMessage,
getPorterUri(domain),
provider.getSigner(),
walletClient,
);

setDecryptedMessage(new TextDecoder().decode(decryptedMessage));
Expand Down
5 changes: 0 additions & 5 deletions demos/taco-demo/src/react-app-env.d.ts

This file was deleted.

4 changes: 2 additions & 2 deletions demos/taco-demo/webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ module.exports = {
DEFAULT_RITUAL_ID: JSON.stringify(process.env.DEFAULT_RITUAL_ID),
DEFAULT_DOMAIN: JSON.stringify(process.env.DEFAULT_DOMAIN),
},
}
})
},
}),
].filter(Boolean),
module: {
rules: [
Expand Down
9 changes: 6 additions & 3 deletions demos/taco-nft-demo/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,9 @@
"build": "pnpm clean && webpack --mode production --progress",
"clean": "rimraf build",
"check": "pnpm type-check && pnpm build",
"type-check": "tsc --noEmit"
"type-check": "tsc --noEmit",
"lint": "eslint --ext .ts src",
"lint:fix": "pnpm lint --fix"
},
"dependencies": {
"@nucypher/taco": "^0.1.0-rc.6",
Expand All @@ -21,7 +23,8 @@
"react": "^18.2.0",
"react-copy-to-clipboard": "^5.1.0",
"react-dom": "^18.2.0",
"react-spinners": "^0.13.6"
"react-spinners": "^0.13.6",
"viem": "^1.19.9"
},
"devDependencies": {
"@pmmmwh/react-refresh-webpack-plugin": "^0.5.7",
Expand All @@ -34,7 +37,7 @@
"react-refresh": "^0.14.0",
"rimraf": "^5.0.5",
"stream-browserify": "^3.0.0",
"typescript": "^4.8.3",
"typescript": "^5.2.2",
"webpack": "^5.89.0",
"webpack-cli": "^5.1.4",
"webpack-dev-server": "^4.11.1"
Expand Down
33 changes: 26 additions & 7 deletions demos/taco-nft-demo/src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,9 @@ import {
ThresholdMessageKit,
} from '@nucypher/taco';
import { Mumbai, useEthers } from '@usedapp/core';
import { ethers } from 'ethers';
import React, { useEffect, useState } from 'react';
import 'viem/window';
import { createPublicClient, createWalletClient, custom } from 'viem';

import { Decrypt } from './Decrypt';
import { Encrypt } from './Encrypt';
Expand All @@ -35,42 +36,60 @@ export default function App() {
}, []);

const encryptMessage = async (message: string) => {
if (!window.ethereum) {
console.error('You need to connect to your wallet first');
return;
}
if (!condition) {
return;
}
setLoading(true);

await switchNetwork(Mumbai.chainId);

const provider = new ethers.providers.Web3Provider(window.ethereum);
const publicClient = createPublicClient({
transport: custom(window.ethereum),
});
const walletClient = createWalletClient({
transport: custom(window.ethereum),
});
const encryptedMessage = await encrypt(
provider,
publicClient,
domain,
message,
condition,
ritualId,
provider.getSigner(),
walletClient,
);

setEncryptedMessage(encryptedMessage);
setLoading(false);
};

const decryptMessage = async (encryptedMessage: ThresholdMessageKit) => {
if (!window.ethereum) {
console.error('You need to connect to your wallet first');
return;
}
if (!condition) {
return;
}
setLoading(true);
setDecryptedMessage('');
setDecryptionErrors([]);

const provider = new ethers.providers.Web3Provider(window.ethereum);
const publicClient = createPublicClient({
transport: custom(window.ethereum),
});
const walletClient = createWalletClient({
transport: custom(window.ethereum),
});
const decryptedMessage = await decrypt(
provider,
publicClient,
domain,
encryptedMessage,
getPorterUri(domain),
provider.getSigner(),
walletClient,
);

setDecryptedMessage(new TextDecoder().decode(decryptedMessage));
Expand Down
5 changes: 0 additions & 5 deletions demos/taco-nft-demo/src/react-app-env.d.ts

This file was deleted.

4 changes: 2 additions & 2 deletions demos/taco-nft-demo/webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ module.exports = {
DEFAULT_RITUAL_ID: JSON.stringify(process.env.DEFAULT_RITUAL_ID),
DEFAULT_DOMAIN: JSON.stringify(process.env.DEFAULT_DOMAIN),
},
}
})
},
}),
].filter(Boolean),
module: {
rules: [
Expand Down
6 changes: 6 additions & 0 deletions examples/pre/nextjs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,12 @@
},
"dependencies": {
"@nucypher/pre": "workspace:*",
"next": "14.0.3",
"react": "18.2.0",
"react-dom": "18.2.0",
"viem": "^1.19.9"
},
"devDependencies": {
"@types/node": "20.10.0",
"@types/react": "18.2.45",
"@types/react-dom": "18.2.14",
Expand Down
35 changes: 15 additions & 20 deletions examples/pre/nextjs/src/app/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,18 +9,13 @@ import {
SecretKey,
toHexString,
} from '@nucypher/pre';
import { ethers } from 'ethers';
import { hexlify } from "ethers/lib/utils";
import { useEffect, useState } from 'react';

// eslint-disable-next-line @typescript-eslint/no-explicit-any
declare const window: any;
import { createWalletClient, custom, toHex, WalletClient } from 'viem';
import 'viem/window';

function App() {
const [isInit, setIsInit] = useState<boolean>(false);
const [provider, setProvider] = useState<
ethers.providers.Web3Provider | undefined
>();
const [walletClient, setWalletClient] = useState<WalletClient | undefined>();
const [alice, setAlice] = useState<Alice | undefined>();
const [bob, setBob] = useState<Bob | undefined>();
const [policy, setPolicy] = useState<EnactedPolicy>();
Expand All @@ -30,32 +25,33 @@ function App() {
setIsInit(true);
};

const loadWeb3Provider = async () => {
const loadWalletClient = async () => {
if (!window.ethereum) {
console.error('You need to connect to your wallet first');
return;
}
const provider = new ethers.providers.Web3Provider(window.ethereum, 'any');

const { chainId } = await provider.getNetwork();
const walletClient = createWalletClient({
transport: custom(window.ethereum),
});
const chainId = await walletClient.getChainId();
const mumbaiChainId = 80001;
if (chainId !== mumbaiChainId) {
// Switch to Polygon Mumbai testnet
await window.ethereum.request({
method: 'wallet_switchEthereumChain',
params: [{ chainId: hexlify(mumbaiChainId) }],
params: [{ chainId: toHex(mumbaiChainId) }],
});
}

await provider.send('eth_requestAccounts', []);
setProvider(provider);
setWalletClient(walletClient);
};

useEffect(() => {
initNucypher();
loadWeb3Provider();
loadWalletClient();
}, []);

if (!isInit || !provider) {
if (!isInit || !walletClient) {
return <div>Loading...</div>;
}

Expand All @@ -82,7 +78,7 @@ function App() {
const getRandomLabel = () => `label-${new Date().getTime()}`;

const runExample = async () => {
if (!provider) {
if (!walletClient) {
console.error('You need to connect to your wallet first');
return;
}
Expand All @@ -106,8 +102,7 @@ function App() {
endDate,
};
const policy = await alice.grant(
provider,
provider.getSigner(),
walletClient,
domains.TESTNET,
getPorterUri(domains.TESTNET),
policyParams,
Expand Down
6 changes: 4 additions & 2 deletions examples/pre/nodejs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,9 @@
},
"dependencies": {
"@nucypher/pre": "workspace:*",
"dotenv": "^16.3.1",
"ethers": "^5.7.2"
"viem": "^1.19.9"
},
"devDependencies": {
"dotenv": "^16.3.1"
}
}
Loading

0 comments on commit 1fb32bd

Please sign in to comment.