-
Notifications
You must be signed in to change notification settings - Fork 61
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test(e2e): test signData with drepID
- Loading branch information
1 parent
44c3716
commit 99a5930
Showing
9 changed files
with
194 additions
and
63 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
119 changes: 119 additions & 0 deletions
119
packages/e2e/test/wallet_epoch_0/PersonalWallet/cip30WalletApi.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
import * as Crypto from '@cardano-sdk/crypto'; | ||
import { BaseWallet, cip30 } from '@cardano-sdk/wallet'; | ||
import { Bip32Account, KeyRole, cip8 } from '@cardano-sdk/key-management'; | ||
import { COSEKey, COSESign1 } from '@emurgo/cardano-message-signing-nodejs'; | ||
import { Cardano, util } from '@cardano-sdk/core'; | ||
import { Cip30DataSignature, SenderContext } from '@cardano-sdk/dapp-connector'; | ||
import { HexBlob } from '@cardano-sdk/util'; | ||
import { NEVER, firstValueFrom, of } from 'rxjs'; | ||
import { buildDRepAddressFromDRepKey } from '../../../../wallet/test/util'; | ||
import { getEnv, getWallet, walletReady, walletVariables } from '../../../src'; | ||
import { logger } from '@cardano-sdk/util-dev'; | ||
|
||
const env = getEnv(walletVariables); | ||
|
||
const decodeSignature = (dataSignature: Cip30DataSignature) => { | ||
const coseKey = COSEKey.from_bytes(Buffer.from(dataSignature.key, 'hex')); | ||
const coseSign1 = COSESign1.from_bytes(Buffer.from(dataSignature.signature, 'hex')); | ||
|
||
const publicKeyHeader = coseKey.header(cip8.CoseLabel.x)!; | ||
const publicKeyBytes = publicKeyHeader.as_bytes()!; | ||
const publicKeyHex = util.bytesToHex(publicKeyBytes); | ||
const signedData = coseSign1.signed_data(); | ||
return { coseKey, coseSign1, publicKeyHex, signedData }; | ||
}; | ||
|
||
describe('PersonalWallet/cip30WalletApi', () => { | ||
let wallet: BaseWallet; | ||
let drepKeyHashHex: Crypto.Ed25519KeyHashHex; | ||
let drepPubKey: Crypto.Ed25519PublicKeyHex; | ||
let walletApi: ReturnType<typeof cip30.createWalletApi>; | ||
let bip32Account: Bip32Account; | ||
|
||
beforeEach(async () => { | ||
({ wallet, bip32Account } = await getWallet({ env, logger, name: 'wallet' })); | ||
await walletReady(wallet, 10n); | ||
|
||
drepPubKey = (await wallet.governance.getPubDRepKey())!; | ||
drepKeyHashHex = (await Crypto.Ed25519PublicKey.fromHex(drepPubKey!).hash()).hex(); | ||
|
||
walletApi = cip30.createWalletApi( | ||
of(wallet), | ||
{ | ||
signData: () => Promise.resolve({ cancel$: NEVER }) | ||
} as unknown as cip30.CallbackConfirmation, | ||
{ logger: console } | ||
); | ||
}); | ||
|
||
it('can signData with hex DRepID', async () => { | ||
const signature = await walletApi.signData( | ||
{ sender: '' } as unknown as SenderContext, | ||
drepKeyHashHex, | ||
HexBlob('abc123') | ||
); | ||
|
||
expect(decodeSignature(signature).publicKeyHex).toEqual(drepPubKey); | ||
}); | ||
|
||
it('can signData with bech32 type 6 addr DRepID', async () => { | ||
const drepAddr = (await buildDRepAddressFromDRepKey(drepPubKey))?.toAddress()?.toBech32(); | ||
const signature = await walletApi.signData( | ||
{ sender: '' } as unknown as SenderContext, | ||
drepAddr!, | ||
HexBlob('abc123') | ||
); | ||
|
||
expect(decodeSignature(signature).publicKeyHex).toEqual(drepPubKey); | ||
}); | ||
|
||
it('can signData with bech32 base address', async () => { | ||
const [{ address, index }] = await firstValueFrom(wallet.addresses$); | ||
const paymentKeyHex = (await bip32Account.derivePublicKey({ index, role: KeyRole.External })).hex(); | ||
|
||
const signature = await walletApi.signData({ sender: '' } as unknown as SenderContext, address, HexBlob('abc123')); | ||
|
||
expect(decodeSignature(signature).publicKeyHex).toEqual(paymentKeyHex); | ||
}); | ||
|
||
it('can signData with hex-encoded base address', async () => { | ||
const [{ address, index }] = await firstValueFrom(wallet.addresses$); | ||
const addressHex = Cardano.Address.fromBech32(address).toBytes(); | ||
const paymentKeyHex = (await bip32Account.derivePublicKey({ index, role: KeyRole.External })).hex(); | ||
|
||
const signature = await walletApi.signData( | ||
{ sender: '' } as unknown as SenderContext, | ||
addressHex, | ||
HexBlob('abc123') | ||
); | ||
|
||
expect(decodeSignature(signature).publicKeyHex).toEqual(paymentKeyHex); | ||
}); | ||
|
||
it('can signData with bech32 base address', async () => { | ||
const [{ rewardAccount, index }] = await firstValueFrom(wallet.addresses$); | ||
const stakeKeyHex = (await bip32Account.derivePublicKey({ index, role: KeyRole.Stake })).hex(); | ||
|
||
const signature = await walletApi.signData( | ||
{ sender: '' } as unknown as SenderContext, | ||
rewardAccount, | ||
HexBlob('abc123') | ||
); | ||
|
||
expect(decodeSignature(signature).publicKeyHex).toEqual(stakeKeyHex); | ||
}); | ||
|
||
it('can signData with hex-encoded reward account', async () => { | ||
const [{ rewardAccount, index }] = await firstValueFrom(wallet.addresses$); | ||
const rewardAccountHex = Cardano.Address.fromBech32(rewardAccount).toBytes(); | ||
const stakeKeyHex = (await bip32Account.derivePublicKey({ index, role: KeyRole.Stake })).hex(); | ||
|
||
const signature = await walletApi.signData( | ||
{ sender: '' } as unknown as SenderContext, | ||
rewardAccountHex, | ||
HexBlob('abc123') | ||
); | ||
|
||
expect(decodeSignature(signature).publicKeyHex).toEqual(stakeKeyHex); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters