1 |
|
2 |
|
3 |
|
4 | import nacl from 'tweetnacl';
|
5 | import { u8aToU8a } from '@polkadot/util';
|
6 | import { ed25519Verify as wasmVerify, isReady } from '@polkadot/wasm-crypto';
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 |
|
19 |
|
20 |
|
21 |
|
22 | export function ed25519Verify(message, signature, publicKey, onlyJs) {
|
23 | const messageU8a = u8aToU8a(message);
|
24 | const publicKeyU8a = u8aToU8a(publicKey);
|
25 | const signatureU8a = u8aToU8a(signature);
|
26 | if (publicKeyU8a.length !== 32) {
|
27 | throw new Error(`Invalid publicKey, received ${publicKeyU8a.length}, expected 32`);
|
28 | } else if (signatureU8a.length !== 64) {
|
29 | throw new Error(`Invalid signature, received ${signatureU8a.length} bytes, expected 64`);
|
30 | }
|
31 | return !onlyJs && isReady() ? wasmVerify(signatureU8a, messageU8a, publicKeyU8a) : nacl.sign.detached.verify(messageU8a, signatureU8a, publicKeyU8a);
|
32 | } |
\ | No newline at end of file |