mirror of
https://github.com/Xahau/xahau.js.git
synced 2025-11-04 21:15:47 +00:00
Compare commits
8 Commits
xahau@4.0.
...
expanded-s
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4140cccaca | ||
|
|
082fe492e0 | ||
|
|
993d155cf3 | ||
|
|
1571e30653 | ||
|
|
3b68781a14 | ||
|
|
1fa277676c | ||
|
|
927172a65f | ||
|
|
663415b23f |
@@ -7,6 +7,7 @@ Subscribe to [the **xrpl-announce** mailing list](https://groups.google.com/g/xr
|
||||
* Signing tx with standard currency codes with lowercase and allowed symbols causing an error on decode.
|
||||
|
||||
### Added
|
||||
* Add ExpandedSignerList amendment support
|
||||
* When connected to nft-devnet, Client.fundWallet now defaults to using the nft-devnet faucet instead of requiring specification.
|
||||
|
||||
## 2.3.0 (2022-06-02)
|
||||
|
||||
@@ -61,10 +61,31 @@ interface PathStep {
|
||||
|
||||
export type Path = PathStep[]
|
||||
|
||||
/**
|
||||
* The object that describes the signer in SignerEntries.
|
||||
*/
|
||||
export interface SignerEntry {
|
||||
/**
|
||||
* The object that describes the signer in SignerEntries.
|
||||
*/
|
||||
SignerEntry: {
|
||||
/**
|
||||
* An XRP Ledger address whose signature contributes to the multi-signature.
|
||||
* It does not need to be a funded address in the ledger.
|
||||
*/
|
||||
Account: string
|
||||
/**
|
||||
* The weight of a signature from this signer.
|
||||
* A multi-signature is only valid if the sum weight of the signatures provided meets
|
||||
* or exceeds the signer list's SignerQuorum value.
|
||||
*/
|
||||
SignerWeight: number
|
||||
/**
|
||||
* An arbitrary 256-bit (32-byte) field that can be used to identify the signer, which
|
||||
* may be useful for smart contracts, or for identifying who controls a key in a large
|
||||
* organization.
|
||||
*/
|
||||
WalletLocator?: string
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -20,13 +20,15 @@ export interface SignerListSet extends BaseTransaction {
|
||||
/**
|
||||
* Array of SignerEntry objects, indicating the addresses and weights of
|
||||
* signers in this list. This signer list must have at least 1 member and no
|
||||
* more than 8 members. No address may appear more than once in the list, nor
|
||||
* more than 32 members. No address may appear more than once in the list, nor
|
||||
* may the Account submitting the transaction appear in the list.
|
||||
*/
|
||||
SignerEntries: SignerEntry[]
|
||||
}
|
||||
|
||||
const MAX_SIGNERS = 8
|
||||
const MAX_SIGNERS = 32
|
||||
|
||||
const HEX_WALLET_LOCATOR_REGEX = /^[0-9A-Fa-f]{64}$/u
|
||||
|
||||
/**
|
||||
* Verify the form and type of an SignerListSet at runtime.
|
||||
@@ -61,7 +63,21 @@ export function validateSignerListSet(tx: Record<string, unknown>): void {
|
||||
|
||||
if (tx.SignerEntries.length > MAX_SIGNERS) {
|
||||
throw new ValidationError(
|
||||
'SignerListSet: maximum of 8 members allowed in SignerEntries',
|
||||
`SignerListSet: maximum of ${MAX_SIGNERS} members allowed in SignerEntries`,
|
||||
)
|
||||
}
|
||||
|
||||
if (tx.SignerEntries.length > 0) {
|
||||
for (const entry of tx.SignerEntries) {
|
||||
const signerEntry = entry.SignerEntry
|
||||
if (
|
||||
signerEntry.WalletLocator !== undefined &&
|
||||
!HEX_WALLET_LOCATOR_REGEX.test(signerEntry.WalletLocator)
|
||||
) {
|
||||
throw new ValidationError(
|
||||
`SignerListSet: WalletLocator in SignerEntry must be a 256-bit (32-byte) hexadecimal value`,
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -89,4 +89,127 @@ describe('SignerListSet', function () {
|
||||
'SignerListSet: invalid SignerEntries',
|
||||
)
|
||||
})
|
||||
|
||||
it(`throws w/ maximum of 32 members allowed in SignerEntries`, function () {
|
||||
signerListSetTx.SignerEntries = []
|
||||
const accounts = [
|
||||
'rBFBipte4nAQCTsRxd2czwvSurhCpAf4X6',
|
||||
'r3ijUH32iiy9tYNj3rD7hKWYjy1BFUxngm',
|
||||
'rpwq8vi4Mn3L5kDJmb8Mg59CanPFPzMCnj',
|
||||
'rB72Gzqfejai46nkA4HaKYBHwAnn2yUoT4',
|
||||
'rGqsJSAW71pCfUwDD5m52bLw69RzFg6kMW',
|
||||
'rs8smPRA31Ym4mGxb1wzgwxtU5eVK82Gyk',
|
||||
'rLrugpGxzezUQLDh7Jv1tZpouuV4MQLbU9',
|
||||
'rUQ6zLXQdh1jJLGwMXp9P8rgi42kwuafzs',
|
||||
'rMjY8sPdfxsyRrnVKQcutxr4mTHNXy9dEF',
|
||||
'rUaxYLeFGm6SmMoa2WCqLKSyHwJyvaQmeG',
|
||||
'r9wUfeVtqMfqrcDTfCpNYbNZvs5q9M9Rpo',
|
||||
'rQncVNak5kvJGPUFa6fuKH7t8Usjs7Np1c',
|
||||
'rnwbSSnPbVbUzuBa4etkeYrfy5v7SyhtPu',
|
||||
'rDXh5D3t48MdBJyXByXq47k5P8Kuf1758B',
|
||||
'rh1D4jd2mAiqUPHfAZ2cY9Nbfa3kAkaQXP',
|
||||
'r9T129tXgtnyfGoLeS35c2HctaZAZSQoCH',
|
||||
'rUd2uKsyCWfJP7Ve36mKoJbNCA7RYThnYk',
|
||||
'r326x8PaAFtnaH7uoxaKrcDWuwpeHn4wDa',
|
||||
'rpN3mkXkYhfNadcXPrY4LniM1KpM3egyQM',
|
||||
'rsPKbR155hz1zrA4pSJp5Y2fxasZAatcHb',
|
||||
'rsyWFLaEKTpaoSJusjpcDvGexuHCwMnqss',
|
||||
'rUbc5RXfyF81oLDMgd3d7jpY9YMNMZG4XN',
|
||||
'rGpYHM88BZe1iVKFHm5xiWYYxR74oxJEXf',
|
||||
'rPsetWAtR1KxDtxzgHjRMD7Rc87rvXk5nD',
|
||||
'rwSeNhL6Hi34igr12mCr61jY42psfTkWTq',
|
||||
'r46Mygy98qjkDhVB6qs4sBnqaf7FPiA2vU',
|
||||
'r4s8GmeYN4CiwVate1nMUvwMQbundqf5cW',
|
||||
'rKAr4dQWDYG8cG2hSwJUVp4ry4WNaWiNgp',
|
||||
'rPWXRLp1vqeUHEH3WiSKuyo9GM9XhaENQU',
|
||||
'rPgmdBdRKGmndxNEYxUrrsYCZaS6go9RvW',
|
||||
'rPDJZ9irzgwKRKScfEmuJMvUgrqZAJNCbL',
|
||||
'rDuU2uSXMfEaoxN1qW8sj7aUNFLGEn3Hr2',
|
||||
'rsbjSjA4TCB9gtm7x7SrWbZHB6g4tt9CGU',
|
||||
]
|
||||
signerListSetTx.SignerQuorum = accounts.length
|
||||
for (const acc of accounts) {
|
||||
signerListSetTx.SignerEntries.push({
|
||||
SignerEntry: {
|
||||
Account: acc,
|
||||
SignerWeight: 1,
|
||||
},
|
||||
})
|
||||
}
|
||||
|
||||
const errorMessage =
|
||||
'SignerListSet: maximum of 32 members allowed in SignerEntries'
|
||||
assert.throws(
|
||||
() => validateSignerListSet(signerListSetTx),
|
||||
ValidationError,
|
||||
errorMessage,
|
||||
)
|
||||
assert.throws(
|
||||
() => validate(signerListSetTx),
|
||||
ValidationError,
|
||||
errorMessage,
|
||||
)
|
||||
})
|
||||
|
||||
it(`verifies valid WalletLocator in SignerEntries`, function () {
|
||||
signerListSetTx.SignerQuorum = 3
|
||||
signerListSetTx.SignerEntries = [
|
||||
{
|
||||
SignerEntry: {
|
||||
Account: 'rBFBipte4nAQCTsRxd2czwvSurhCpAf4X6',
|
||||
SignerWeight: 1,
|
||||
WalletLocator:
|
||||
'CAFECAFECAFECAFECAFECAFECAFECAFECAFECAFECAFECAFECAFECAFECAFECAFE',
|
||||
},
|
||||
},
|
||||
{
|
||||
SignerEntry: {
|
||||
Account: 'r3ijUH32iiy9tYNj3rD7hKWYjy1BFUxngm',
|
||||
SignerWeight: 1,
|
||||
},
|
||||
},
|
||||
{
|
||||
SignerEntry: {
|
||||
Account: 'rpwq8vi4Mn3L5kDJmb8Mg59CanPFPzMCnj',
|
||||
SignerWeight: 1,
|
||||
WalletLocator:
|
||||
'00000000000000000000000000000000000000000000000000000000DEADBEEF',
|
||||
},
|
||||
},
|
||||
]
|
||||
|
||||
assert.doesNotThrow(() => validateSignerListSet(signerListSetTx))
|
||||
assert.doesNotThrow(() => validate(signerListSetTx))
|
||||
})
|
||||
|
||||
it(`throws w/ invalid WalletLocator in SignerEntries`, function () {
|
||||
signerListSetTx.SignerQuorum = 2
|
||||
signerListSetTx.SignerEntries = [
|
||||
{
|
||||
SignerEntry: {
|
||||
Account: 'rBFBipte4nAQCTsRxd2czwvSurhCpAf4X6',
|
||||
SignerWeight: 1,
|
||||
WalletLocator: 'not_valid',
|
||||
},
|
||||
},
|
||||
{
|
||||
SignerEntry: {
|
||||
Account: 'r3ijUH32iiy9tYNj3rD7hKWYjy1BFUxngm',
|
||||
SignerWeight: 1,
|
||||
},
|
||||
},
|
||||
]
|
||||
const errorMessage =
|
||||
'SignerListSet: WalletLocator in SignerEntry must be a 256-bit (32-byte) hexadecimal value'
|
||||
assert.throws(
|
||||
() => validateSignerListSet(signerListSetTx),
|
||||
ValidationError,
|
||||
errorMessage,
|
||||
)
|
||||
assert.throws(
|
||||
() => validate(signerListSetTx),
|
||||
ValidationError,
|
||||
errorMessage,
|
||||
)
|
||||
})
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user