@noir-wallet/sdk 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,121 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+
5
+ // src/chains/zcash/provider.ts
6
+ function getZcashProvider() {
7
+ if (typeof window === "undefined") return null;
8
+ const rheaWallet = window.rheawallet;
9
+ return rheaWallet?.zcash || null;
10
+ }
11
+ async function detectProvider(timeout = 3e3) {
12
+ return new Promise((resolve, reject) => {
13
+ if (typeof window === "undefined") {
14
+ return reject(new Error("window is undefined"));
15
+ }
16
+ const provider = getZcashProvider();
17
+ if (provider) {
18
+ return resolve(provider);
19
+ }
20
+ let handled = false;
21
+ const handleProvider = () => {
22
+ if (handled) return;
23
+ handled = true;
24
+ const provider2 = getZcashProvider();
25
+ if (provider2) {
26
+ resolve(provider2);
27
+ } else {
28
+ reject(new Error("RHEA Wallet is not installed"));
29
+ }
30
+ };
31
+ window.addEventListener("rheawallet#initialized", handleProvider, { once: true });
32
+ setTimeout(() => {
33
+ handleProvider();
34
+ }, timeout);
35
+ });
36
+ }
37
+ function getProvider() {
38
+ return getZcashProvider();
39
+ }
40
+
41
+ // src/chains/zcash/wallet.ts
42
+ var ZcashWallet = class {
43
+ constructor() {
44
+ __publicField(this, "provider", null);
45
+ __publicField(this, "_connected", false);
46
+ }
47
+ async connect() {
48
+ this.provider = await detectProvider();
49
+ if (!this.provider) {
50
+ throw new Error("RHEA Wallet provider not available");
51
+ }
52
+ const accounts = await this.provider.request({ method: "zcash_requestAccounts" });
53
+ this._connected = true;
54
+ return accounts;
55
+ }
56
+ async getAddresses() {
57
+ if (!this.provider || !this._connected) {
58
+ throw new Error("Wallet not connected");
59
+ }
60
+ return this.provider.request({ method: "zcash_getAddresses" });
61
+ }
62
+ async getBalance() {
63
+ if (!this.provider || !this._connected) {
64
+ throw new Error("Wallet not connected");
65
+ }
66
+ return this.provider.request({ method: "zcash_getBalance" });
67
+ }
68
+ async sendTransaction(params) {
69
+ if (!this.provider || !this._connected) {
70
+ throw new Error("Wallet not connected");
71
+ }
72
+ return this.provider.request({
73
+ method: "zcash_sendTransaction",
74
+ params: [params]
75
+ });
76
+ }
77
+ async signMessage(message) {
78
+ if (!this.provider || !this._connected) {
79
+ throw new Error("Wallet not connected");
80
+ }
81
+ return this.provider.request({
82
+ method: "zcash_signMessage",
83
+ params: [{ message }]
84
+ });
85
+ }
86
+ async switchNetwork(network) {
87
+ if (!this.provider || !this._connected) {
88
+ throw new Error("Wallet not connected");
89
+ }
90
+ return this.provider.request({
91
+ method: "zcash_switchNetwork",
92
+ params: [{ network }]
93
+ });
94
+ }
95
+ on(event, handler) {
96
+ if (!this.provider) {
97
+ throw new Error("Wallet not connected");
98
+ }
99
+ this.provider.on(event, handler);
100
+ }
101
+ removeListener(event, handler) {
102
+ if (!this.provider?.removeListener) {
103
+ return;
104
+ }
105
+ this.provider.removeListener(event, handler);
106
+ }
107
+ disconnect() {
108
+ this._connected = false;
109
+ this.provider = null;
110
+ }
111
+ get connected() {
112
+ return this._connected;
113
+ }
114
+ };
115
+
116
+ export {
117
+ getZcashProvider,
118
+ detectProvider,
119
+ getProvider,
120
+ ZcashWallet
121
+ };
@@ -0,0 +1,183 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+
5
+ // src/chains/zcash/provider.ts
6
+ function getZcashProvider() {
7
+ if (typeof window === "undefined") return null;
8
+ const rheaWallet = window.rheawallet;
9
+ return rheaWallet?.zcash || null;
10
+ }
11
+ async function detectProvider(timeout = 3e3) {
12
+ return new Promise((resolve, reject) => {
13
+ if (typeof window === "undefined") {
14
+ return reject(new Error("window is undefined"));
15
+ }
16
+ const provider = getZcashProvider();
17
+ if (provider) {
18
+ return resolve(provider);
19
+ }
20
+ let handled = false;
21
+ const handleProvider = () => {
22
+ if (handled) return;
23
+ handled = true;
24
+ const provider2 = getZcashProvider();
25
+ if (provider2) {
26
+ resolve(provider2);
27
+ } else {
28
+ reject(new Error("RHEA Wallet is not installed"));
29
+ }
30
+ };
31
+ window.addEventListener("rheawallet#initialized", handleProvider, { once: true });
32
+ setTimeout(() => {
33
+ handleProvider();
34
+ }, timeout);
35
+ });
36
+ }
37
+ function getProvider() {
38
+ return getZcashProvider();
39
+ }
40
+
41
+ // src/chains/zcash/api.ts
42
+ var ZcashAPI = class {
43
+ constructor(provider) {
44
+ __publicField(this, "provider");
45
+ this.provider = provider;
46
+ }
47
+ async connect() {
48
+ return this.provider.request({ method: "zcash_requestAccounts" });
49
+ }
50
+ async getAccounts() {
51
+ return this.provider.request({ method: "zcash_getAccounts" });
52
+ }
53
+ async getBalance() {
54
+ return this.provider.request({ method: "zcash_getBalance" });
55
+ }
56
+ async getPublicKey() {
57
+ return this.provider.request({ method: "zcash_getPublicKey" });
58
+ }
59
+ async sendTransaction(params) {
60
+ return this.provider.request({
61
+ method: "zcash_sendTransaction",
62
+ params: [params]
63
+ });
64
+ }
65
+ async signMessage(message) {
66
+ return this.provider.request({
67
+ method: "zcash_signMessage",
68
+ params: [message]
69
+ });
70
+ }
71
+ async switchNetwork(network) {
72
+ return this.provider.request({
73
+ method: "zcash_switchNetwork",
74
+ params: [{ network }]
75
+ });
76
+ }
77
+ async disconnect() {
78
+ await this.provider.request({ method: "zcash_disconnect" });
79
+ }
80
+ on(event, handler) {
81
+ this.provider.on(event, handler);
82
+ }
83
+ removeListener(event, handler) {
84
+ this.provider.removeListener?.(event, handler);
85
+ }
86
+ };
87
+
88
+ // src/chains/zcash/utils.ts
89
+ import bs58 from "bs58";
90
+ import * as hashjs from "hash.js";
91
+ var MAINNET_P2PKH_PREFIX = new Uint8Array([28, 184]);
92
+ var TESTNET_P2PKH_PREFIX = new Uint8Array([29, 37]);
93
+ function sha2562(data) {
94
+ return new Uint8Array(hashjs.sha256().update(Array.from(data)).digest());
95
+ }
96
+ function ripemd1602(data) {
97
+ return new Uint8Array(hashjs.ripemd160().update(Array.from(data)).digest());
98
+ }
99
+ function hash160(data) {
100
+ return ripemd1602(sha2562(data));
101
+ }
102
+ function hexToUint8Array(hex) {
103
+ const bytes = new Uint8Array(hex.length / 2);
104
+ for (let i = 0; i < hex.length; i += 2) {
105
+ bytes[i / 2] = parseInt(hex.substr(i, 2), 16);
106
+ }
107
+ return bytes;
108
+ }
109
+ function concatUint8Arrays(...arrays) {
110
+ const totalLength = arrays.reduce((acc, arr) => acc + arr.length, 0);
111
+ const result = new Uint8Array(totalLength);
112
+ let offset = 0;
113
+ for (const arr of arrays) {
114
+ result.set(arr, offset);
115
+ offset += arr.length;
116
+ }
117
+ return result;
118
+ }
119
+ function compressPublicKey(pubkey) {
120
+ if (pubkey.length === 33) {
121
+ return pubkey;
122
+ }
123
+ if (pubkey.length !== 65) {
124
+ throw new Error("Invalid public key length for compression");
125
+ }
126
+ if (pubkey[0] !== 4) {
127
+ throw new Error("Invalid uncompressed public key format");
128
+ }
129
+ const x = pubkey.slice(1, 33);
130
+ const y = pubkey.slice(33, 65);
131
+ const yIsOdd = (y[y.length - 1] & 1) === 1;
132
+ const prefix = yIsOdd ? 3 : 2;
133
+ const compressed = new Uint8Array(33);
134
+ compressed[0] = prefix;
135
+ compressed.set(x, 1);
136
+ return compressed;
137
+ }
138
+ function publicKeyToAddress(pubkeyHex, network = "mainnet") {
139
+ if (!pubkeyHex || typeof pubkeyHex !== "string") {
140
+ throw new Error("Invalid public key: must be a non-empty hex string");
141
+ }
142
+ const cleanHex = pubkeyHex.toLowerCase().replace(/^0x/, "");
143
+ if (!/^[0-9a-f]+$/.test(cleanHex)) {
144
+ throw new Error("Invalid public key: must contain only hexadecimal characters");
145
+ }
146
+ const pubkeyBytes = hexToUint8Array(cleanHex);
147
+ if (pubkeyBytes.length !== 33 && pubkeyBytes.length !== 65) {
148
+ throw new Error(
149
+ `Invalid public key length: expected 33 (compressed) or 65 (uncompressed) bytes, got ${pubkeyBytes.length}`
150
+ );
151
+ }
152
+ if (pubkeyBytes.length === 33) {
153
+ const prefix = pubkeyBytes[0];
154
+ if (prefix !== 2 && prefix !== 3) {
155
+ throw new Error(
156
+ `Invalid compressed public key prefix: expected 0x02 or 0x03, got 0x${prefix.toString(16).padStart(2, "0")}`
157
+ );
158
+ }
159
+ } else if (pubkeyBytes.length === 65) {
160
+ const prefix = pubkeyBytes[0];
161
+ if (prefix !== 4) {
162
+ throw new Error(
163
+ `Invalid uncompressed public key prefix: expected 0x04, got 0x${prefix.toString(16).padStart(2, "0")}`
164
+ );
165
+ }
166
+ }
167
+ const compressedPubkey = compressPublicKey(pubkeyBytes);
168
+ const pubkeyHash = hash160(compressedPubkey);
169
+ const versionPrefix = network === "mainnet" ? MAINNET_P2PKH_PREFIX : TESTNET_P2PKH_PREFIX;
170
+ const payload = concatUint8Arrays(versionPrefix, pubkeyHash);
171
+ const checksum = sha2562(sha2562(payload)).slice(0, 4);
172
+ const addressBytes = concatUint8Arrays(payload, checksum);
173
+ const address = bs58.encode(addressBytes);
174
+ return address;
175
+ }
176
+
177
+ export {
178
+ ZcashAPI,
179
+ getZcashProvider,
180
+ detectProvider,
181
+ getProvider,
182
+ publicKeyToAddress
183
+ };
@@ -0,0 +1,41 @@
1
+ // src/chains/zcash/provider.ts
2
+ function getZcashProvider() {
3
+ if (typeof window === "undefined") return null;
4
+ const rheaWallet = window.rheawallet;
5
+ return rheaWallet?.zcash || null;
6
+ }
7
+ async function detectProvider(timeout = 3e3) {
8
+ return new Promise((resolve, reject) => {
9
+ if (typeof window === "undefined") {
10
+ return reject(new Error("window is undefined"));
11
+ }
12
+ const provider = getZcashProvider();
13
+ if (provider) {
14
+ return resolve(provider);
15
+ }
16
+ let handled = false;
17
+ const handleProvider = () => {
18
+ if (handled) return;
19
+ handled = true;
20
+ const provider2 = getZcashProvider();
21
+ if (provider2) {
22
+ resolve(provider2);
23
+ } else {
24
+ reject(new Error("RHEA Wallet is not installed"));
25
+ }
26
+ };
27
+ window.addEventListener("rheawallet#initialized", handleProvider, { once: true });
28
+ setTimeout(() => {
29
+ handleProvider();
30
+ }, timeout);
31
+ });
32
+ }
33
+ function getProvider() {
34
+ return getZcashProvider();
35
+ }
36
+
37
+ export {
38
+ getZcashProvider,
39
+ detectProvider,
40
+ getProvider
41
+ };
@@ -0,0 +1,173 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+
5
+ // src/chains/zcash/provider.ts
6
+ function getZcashProvider() {
7
+ if (typeof window === "undefined") return null;
8
+ const rheaWallet = window.rheawallet;
9
+ return rheaWallet?.zcash || null;
10
+ }
11
+ async function detectProvider(timeout = 3e3) {
12
+ return new Promise((resolve, reject) => {
13
+ if (typeof window === "undefined") {
14
+ return reject(new Error("window is undefined"));
15
+ }
16
+ const provider = getZcashProvider();
17
+ if (provider) {
18
+ return resolve(provider);
19
+ }
20
+ let handled = false;
21
+ const handleProvider = () => {
22
+ if (handled) return;
23
+ handled = true;
24
+ const provider2 = getZcashProvider();
25
+ if (provider2) {
26
+ resolve(provider2);
27
+ } else {
28
+ reject(new Error("RHEA Wallet is not installed"));
29
+ }
30
+ };
31
+ window.addEventListener("rheawallet#initialized", handleProvider, { once: true });
32
+ setTimeout(() => {
33
+ handleProvider();
34
+ }, timeout);
35
+ });
36
+ }
37
+ function getProvider() {
38
+ return getZcashProvider();
39
+ }
40
+
41
+ // src/chains/zcash/wallet.ts
42
+ var ZcashWallet = class {
43
+ constructor() {
44
+ __publicField(this, "provider", null);
45
+ __publicField(this, "_connected", false);
46
+ }
47
+ async connect() {
48
+ this.provider = await detectProvider();
49
+ if (!this.provider) {
50
+ throw new Error("RHEA Wallet provider not available");
51
+ }
52
+ const accounts = await this.provider.request({ method: "zcash_requestAccounts" });
53
+ this._connected = true;
54
+ return accounts;
55
+ }
56
+ async getAddresses() {
57
+ if (!this.provider || !this._connected) {
58
+ throw new Error("Wallet not connected");
59
+ }
60
+ return this.provider.request({ method: "zcash_getAddresses" });
61
+ }
62
+ async getBalance() {
63
+ if (!this.provider || !this._connected) {
64
+ throw new Error("Wallet not connected");
65
+ }
66
+ return this.provider.request({ method: "zcash_getBalance" });
67
+ }
68
+ async sendTransaction(params) {
69
+ if (!this.provider || !this._connected) {
70
+ throw new Error("Wallet not connected");
71
+ }
72
+ return this.provider.request({
73
+ method: "zcash_sendTransaction",
74
+ params: [params]
75
+ });
76
+ }
77
+ async signMessage(message) {
78
+ if (!this.provider || !this._connected) {
79
+ throw new Error("Wallet not connected");
80
+ }
81
+ return this.provider.request({
82
+ method: "zcash_signMessage",
83
+ params: [{ message }]
84
+ });
85
+ }
86
+ async switchNetwork(network) {
87
+ if (!this.provider || !this._connected) {
88
+ throw new Error("Wallet not connected");
89
+ }
90
+ return this.provider.request({
91
+ method: "zcash_switchNetwork",
92
+ params: [{ network }]
93
+ });
94
+ }
95
+ on(event, handler) {
96
+ if (!this.provider) {
97
+ throw new Error("Wallet not connected");
98
+ }
99
+ this.provider.on(event, handler);
100
+ }
101
+ removeListener(event, handler) {
102
+ if (!this.provider?.removeListener) {
103
+ return;
104
+ }
105
+ this.provider.removeListener(event, handler);
106
+ }
107
+ async disconnect() {
108
+ if (this._connected && this.provider) {
109
+ try {
110
+ await this.provider.request({ method: "zcash_disconnect" });
111
+ } catch (error) {
112
+ console.warn("Failed to notify extension about disconnect:", error);
113
+ }
114
+ }
115
+ this._connected = false;
116
+ this.provider = null;
117
+ }
118
+ get connected() {
119
+ return this._connected;
120
+ }
121
+ };
122
+
123
+ // src/chains/zcash/api.ts
124
+ var ZcashAPI = class {
125
+ constructor(provider) {
126
+ __publicField(this, "provider");
127
+ this.provider = provider;
128
+ }
129
+ async connect() {
130
+ return this.provider.request({ method: "zcash_requestAccounts" });
131
+ }
132
+ async getAccounts() {
133
+ return this.provider.request({ method: "zcash_getAccounts" });
134
+ }
135
+ async getBalance() {
136
+ return this.provider.request({ method: "zcash_getBalance" });
137
+ }
138
+ async sendTransaction(params) {
139
+ return this.provider.request({
140
+ method: "zcash_sendTransaction",
141
+ params: [params]
142
+ });
143
+ }
144
+ async signMessage(message) {
145
+ return this.provider.request({
146
+ method: "zcash_signMessage",
147
+ params: [message]
148
+ });
149
+ }
150
+ async switchNetwork(network) {
151
+ return this.provider.request({
152
+ method: "zcash_switchNetwork",
153
+ params: [{ network }]
154
+ });
155
+ }
156
+ async disconnect() {
157
+ await this.provider.request({ method: "zcash_disconnect" });
158
+ }
159
+ on(event, handler) {
160
+ this.provider.on(event, handler);
161
+ }
162
+ removeListener(event, handler) {
163
+ this.provider.removeListener?.(event, handler);
164
+ }
165
+ };
166
+
167
+ export {
168
+ ZcashAPI,
169
+ getZcashProvider,
170
+ detectProvider,
171
+ getProvider,
172
+ ZcashWallet
173
+ };
@@ -0,0 +1,163 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+
5
+ // src/chains/zcash/provider.ts
6
+ function getZcashProvider() {
7
+ if (typeof window === "undefined") return null;
8
+ const rheaWallet = window.rheawallet;
9
+ return rheaWallet?.zcash || null;
10
+ }
11
+ async function detectProvider(timeout = 3e3) {
12
+ return new Promise((resolve, reject) => {
13
+ if (typeof window === "undefined") {
14
+ return reject(new Error("window is undefined"));
15
+ }
16
+ const provider = getZcashProvider();
17
+ if (provider) {
18
+ return resolve(provider);
19
+ }
20
+ let handled = false;
21
+ const handleProvider = () => {
22
+ if (handled) return;
23
+ handled = true;
24
+ const provider2 = getZcashProvider();
25
+ if (provider2) {
26
+ resolve(provider2);
27
+ } else {
28
+ reject(new Error("RHEA Wallet is not installed"));
29
+ }
30
+ };
31
+ window.addEventListener("rheawallet#initialized", handleProvider, { once: true });
32
+ setTimeout(() => {
33
+ handleProvider();
34
+ }, timeout);
35
+ });
36
+ }
37
+ function getProvider() {
38
+ return getZcashProvider();
39
+ }
40
+
41
+ // src/chains/zcash/api.ts
42
+ var ZcashAPI = class {
43
+ constructor(provider) {
44
+ __publicField(this, "provider");
45
+ this.provider = provider;
46
+ }
47
+ async connect() {
48
+ return this.provider.request({ method: "zcash_requestAccounts" });
49
+ }
50
+ async getAccounts() {
51
+ return this.provider.request({ method: "zcash_getAccounts" });
52
+ }
53
+ async getBalance() {
54
+ return this.provider.request({ method: "zcash_getBalance" });
55
+ }
56
+ async getPublicKey() {
57
+ return this.provider.request({ method: "zcash_getPublicKey" });
58
+ }
59
+ async sendTransaction(params) {
60
+ return this.provider.request({
61
+ method: "zcash_sendTransaction",
62
+ params: [params]
63
+ });
64
+ }
65
+ async signMessage(message) {
66
+ return this.provider.request({
67
+ method: "zcash_signMessage",
68
+ params: [message]
69
+ });
70
+ }
71
+ async switchNetwork(network) {
72
+ return this.provider.request({
73
+ method: "zcash_switchNetwork",
74
+ params: [{ network }]
75
+ });
76
+ }
77
+ async disconnect() {
78
+ await this.provider.request({ method: "zcash_disconnect" });
79
+ }
80
+ on(event, handler) {
81
+ this.provider.on(event, handler);
82
+ }
83
+ removeListener(event, handler) {
84
+ this.provider.removeListener?.(event, handler);
85
+ }
86
+ };
87
+
88
+ // src/chains/zcash/utils.ts
89
+ import bs58 from "bs58";
90
+ import * as hashjs from "hash.js";
91
+ var MAINNET_P2PKH_PREFIX = new Uint8Array([28, 184]);
92
+ var TESTNET_P2PKH_PREFIX = new Uint8Array([29, 37]);
93
+ function sha2562(data) {
94
+ return new Uint8Array(hashjs.sha256().update(Array.from(data)).digest());
95
+ }
96
+ function ripemd1602(data) {
97
+ return new Uint8Array(hashjs.ripemd160().update(Array.from(data)).digest());
98
+ }
99
+ function hash160(data) {
100
+ return ripemd1602(sha2562(data));
101
+ }
102
+ function hexToUint8Array(hex) {
103
+ const bytes = new Uint8Array(hex.length / 2);
104
+ for (let i = 0; i < hex.length; i += 2) {
105
+ bytes[i / 2] = parseInt(hex.substr(i, 2), 16);
106
+ }
107
+ return bytes;
108
+ }
109
+ function concatUint8Arrays(...arrays) {
110
+ const totalLength = arrays.reduce((acc, arr) => acc + arr.length, 0);
111
+ const result = new Uint8Array(totalLength);
112
+ let offset = 0;
113
+ for (const arr of arrays) {
114
+ result.set(arr, offset);
115
+ offset += arr.length;
116
+ }
117
+ return result;
118
+ }
119
+ function publicKeyToAddress(pubkeyHex, network = "mainnet") {
120
+ if (!pubkeyHex || typeof pubkeyHex !== "string") {
121
+ throw new Error("Invalid public key: must be a non-empty hex string");
122
+ }
123
+ const cleanHex = pubkeyHex.toLowerCase().replace(/^0x/, "");
124
+ if (!/^[0-9a-f]+$/.test(cleanHex)) {
125
+ throw new Error("Invalid public key: must contain only hexadecimal characters");
126
+ }
127
+ const pubkeyBytes = hexToUint8Array(cleanHex);
128
+ if (pubkeyBytes.length !== 33 && pubkeyBytes.length !== 65) {
129
+ throw new Error(
130
+ `Invalid public key length: expected 33 (compressed) or 65 (uncompressed) bytes, got ${pubkeyBytes.length}`
131
+ );
132
+ }
133
+ if (pubkeyBytes.length === 33) {
134
+ const prefix = pubkeyBytes[0];
135
+ if (prefix !== 2 && prefix !== 3) {
136
+ throw new Error(
137
+ `Invalid compressed public key prefix: expected 0x02 or 0x03, got 0x${prefix.toString(16).padStart(2, "0")}`
138
+ );
139
+ }
140
+ } else if (pubkeyBytes.length === 65) {
141
+ const prefix = pubkeyBytes[0];
142
+ if (prefix !== 4) {
143
+ throw new Error(
144
+ `Invalid uncompressed public key prefix: expected 0x04, got 0x${prefix.toString(16).padStart(2, "0")}`
145
+ );
146
+ }
147
+ }
148
+ const pubkeyHash = hash160(pubkeyBytes);
149
+ const versionPrefix = network === "mainnet" ? MAINNET_P2PKH_PREFIX : TESTNET_P2PKH_PREFIX;
150
+ const payload = concatUint8Arrays(versionPrefix, pubkeyHash);
151
+ const checksum = sha2562(sha2562(payload)).slice(0, 4);
152
+ const addressBytes = concatUint8Arrays(payload, checksum);
153
+ const address = bs58.encode(addressBytes);
154
+ return address;
155
+ }
156
+
157
+ export {
158
+ ZcashAPI,
159
+ getZcashProvider,
160
+ detectProvider,
161
+ getProvider,
162
+ publicKeyToAddress
163
+ };