@typeberry/lib 0.1.3-6edad4a → 0.1.3-8fd7637
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.
- package/index.cjs +417 -1119
- package/index.d.ts +329 -405
- package/index.js +416 -1118
- package/package.json +1 -1
package/index.cjs
CHANGED
|
@@ -332,6 +332,19 @@ const Result$1 = {
|
|
|
332
332
|
},
|
|
333
333
|
};
|
|
334
334
|
|
|
335
|
+
// about 2GB, the maximum ArrayBuffer length on Chrome confirmed by several sources:
|
|
336
|
+
// - https://issues.chromium.org/issues/40055619
|
|
337
|
+
// - https://stackoverflow.com/a/72124984
|
|
338
|
+
// - https://onnxruntime.ai/docs/tutorials/web/large-models.html#maximum-size-of-arraybuffer
|
|
339
|
+
const MAX_LENGTH$2 = 2145386496;
|
|
340
|
+
function safeAllocUint8Array(length) {
|
|
341
|
+
if (length > MAX_LENGTH$2) {
|
|
342
|
+
// biome-ignore lint/suspicious/noConsole: can't have a dependency on logger here
|
|
343
|
+
console.warn(`Trying to allocate ${length} bytes, which is greater than the maximum of ${MAX_LENGTH$2}.`);
|
|
344
|
+
}
|
|
345
|
+
return new Uint8Array(Math.min(MAX_LENGTH$2, length));
|
|
346
|
+
}
|
|
347
|
+
|
|
335
348
|
/**
|
|
336
349
|
* Utilities for tests.
|
|
337
350
|
*/
|
|
@@ -572,6 +585,7 @@ var index$u = /*#__PURE__*/Object.freeze({
|
|
|
572
585
|
DEFAULT_VERSION: DEFAULT_VERSION,
|
|
573
586
|
ErrorsCollector: ErrorsCollector,
|
|
574
587
|
get GpVersion () { return GpVersion; },
|
|
588
|
+
MAX_LENGTH: MAX_LENGTH$2,
|
|
575
589
|
OK: OK,
|
|
576
590
|
Result: Result$1,
|
|
577
591
|
TEST_COMPARE_USING: TEST_COMPARE_USING,
|
|
@@ -586,6 +600,7 @@ var index$u = /*#__PURE__*/Object.freeze({
|
|
|
586
600
|
isBrowser: isBrowser,
|
|
587
601
|
measure: measure,
|
|
588
602
|
resultToString: resultToString,
|
|
603
|
+
safeAllocUint8Array: safeAllocUint8Array,
|
|
589
604
|
seeThrough: seeThrough,
|
|
590
605
|
workspacePathFix: workspacePathFix
|
|
591
606
|
});
|
|
@@ -609,7 +624,7 @@ class BitVec {
|
|
|
609
624
|
* Create new [`BitVec`] with all values set to `false`.
|
|
610
625
|
*/
|
|
611
626
|
static empty(bitLength) {
|
|
612
|
-
const data =
|
|
627
|
+
const data = safeAllocUint8Array(Math.ceil(bitLength / 8));
|
|
613
628
|
return new BitVec(data, bitLength);
|
|
614
629
|
}
|
|
615
630
|
byteLength;
|
|
@@ -810,7 +825,7 @@ class BytesBlob {
|
|
|
810
825
|
static blobFromParts(v, ...rest) {
|
|
811
826
|
const vArr = v instanceof Uint8Array ? [v] : v;
|
|
812
827
|
const totalLength = vArr.reduce((a, v) => a + v.length, 0) + rest.reduce((a, v) => a + v.length, 0);
|
|
813
|
-
const buffer =
|
|
828
|
+
const buffer = safeAllocUint8Array(totalLength);
|
|
814
829
|
let offset = 0;
|
|
815
830
|
for (const r of vArr) {
|
|
816
831
|
buffer.set(r, offset);
|
|
@@ -883,7 +898,7 @@ class Bytes extends BytesBlob {
|
|
|
883
898
|
}
|
|
884
899
|
/** Create an empty [`Bytes<X>`] of given length. */
|
|
885
900
|
static zero(len) {
|
|
886
|
-
return new Bytes(
|
|
901
|
+
return new Bytes(safeAllocUint8Array(len), len);
|
|
887
902
|
}
|
|
888
903
|
// TODO [ToDr] `fill` should have the argments swapped to align with the rest.
|
|
889
904
|
/** Create a [`Bytes<X>`] with all bytes filled with given input number. */
|
|
@@ -3592,7 +3607,7 @@ async function verify(input) {
|
|
|
3592
3607
|
return Promise.resolve([]);
|
|
3593
3608
|
}
|
|
3594
3609
|
const dataLength = input.reduce((acc, { message, key, signature }) => acc + key.length + signature.length + message.length + 1, 0);
|
|
3595
|
-
const data =
|
|
3610
|
+
const data = safeAllocUint8Array(dataLength);
|
|
3596
3611
|
let offset = 0;
|
|
3597
3612
|
for (const { key, message, signature } of input) {
|
|
3598
3613
|
data.set(key.raw, offset);
|
|
@@ -3639,823 +3654,75 @@ var ed25519 = /*#__PURE__*/Object.freeze({
|
|
|
3639
3654
|
verifyBatch: verifyBatch
|
|
3640
3655
|
});
|
|
3641
3656
|
|
|
3657
|
+
const SEED_SIZE = 32;
|
|
3658
|
+
const ED25519_SECRET_KEY = Bytes.blobFromString("jam_val_key_ed25519");
|
|
3659
|
+
const BANDERSNATCH_SECRET_KEY = Bytes.blobFromString("jam_val_key_bandersnatch");
|
|
3642
3660
|
/**
|
|
3643
|
-
*
|
|
3644
|
-
*
|
|
3645
|
-
* https://graypaper.fluffylabs.dev/#/579bd12/073101073c01
|
|
3661
|
+
* JIP-5: Secret key derivation
|
|
3646
3662
|
*
|
|
3647
|
-
*/
|
|
3648
|
-
const HASH_SIZE = 32;
|
|
3649
|
-
/** A hash without last byte (useful for trie representation). */
|
|
3650
|
-
const TRUNCATED_HASH_SIZE = 31;
|
|
3651
|
-
const ZERO_HASH = Bytes.zero(HASH_SIZE);
|
|
3663
|
+
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md */
|
|
3652
3664
|
/**
|
|
3653
|
-
*
|
|
3654
|
-
*
|
|
3655
|
-
* After calculating the hash these two should be passed together to avoid
|
|
3656
|
-
* unnecessary re-hashing of the data.
|
|
3665
|
+
* Deriving a 32-byte seed from a 32-bit unsigned integer
|
|
3666
|
+
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md#trivial-seeds
|
|
3657
3667
|
*/
|
|
3658
|
-
|
|
3659
|
-
|
|
3660
|
-
|
|
3661
|
-
constructor(hash, data) {
|
|
3662
|
-
super();
|
|
3663
|
-
this.hash = hash;
|
|
3664
|
-
this.data = data;
|
|
3665
|
-
}
|
|
3668
|
+
function trivialSeed(s) {
|
|
3669
|
+
const s_le = u32AsLeBytes(s);
|
|
3670
|
+
return Bytes.fromBlob(BytesBlob.blobFromParts([s_le, s_le, s_le, s_le, s_le, s_le, s_le, s_le]).raw, SEED_SIZE).asOpaque();
|
|
3666
3671
|
}
|
|
3667
3672
|
/**
|
|
3668
|
-
*
|
|
3673
|
+
* Derives a Ed25519 secret key from a seed.
|
|
3674
|
+
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md#derivation-method
|
|
3669
3675
|
*/
|
|
3670
|
-
|
|
3671
|
-
|
|
3672
|
-
constructor(hash, data, encoded) {
|
|
3673
|
-
super(hash, data);
|
|
3674
|
-
this.encoded = encoded;
|
|
3675
|
-
}
|
|
3676
|
-
}
|
|
3677
|
-
|
|
3678
|
-
/** The simplest allocator returning just a fresh copy of bytes each time. */
|
|
3679
|
-
class SimpleAllocator {
|
|
3680
|
-
emptyHash() {
|
|
3681
|
-
return Bytes.zero(HASH_SIZE);
|
|
3682
|
-
}
|
|
3683
|
-
}
|
|
3684
|
-
/** An allocator that works by allocating larger (continuous) pages of memory. */
|
|
3685
|
-
class PageAllocator {
|
|
3686
|
-
hashesPerPage;
|
|
3687
|
-
page = new Uint8Array(0);
|
|
3688
|
-
currentHash = 0;
|
|
3689
|
-
// TODO [ToDr] Benchmark the performance!
|
|
3690
|
-
constructor(hashesPerPage) {
|
|
3691
|
-
this.hashesPerPage = hashesPerPage;
|
|
3692
|
-
check `${hashesPerPage > 0 && hashesPerPage >>> 0 === hashesPerPage} Expected a non-zero integer.`;
|
|
3693
|
-
this.resetPage();
|
|
3694
|
-
}
|
|
3695
|
-
resetPage() {
|
|
3696
|
-
const pageSizeBytes = this.hashesPerPage * HASH_SIZE;
|
|
3697
|
-
this.currentHash = 0;
|
|
3698
|
-
this.page = new Uint8Array(pageSizeBytes);
|
|
3699
|
-
}
|
|
3700
|
-
emptyHash() {
|
|
3701
|
-
const startIdx = this.currentHash * HASH_SIZE;
|
|
3702
|
-
const endIdx = startIdx + HASH_SIZE;
|
|
3703
|
-
this.currentHash += 1;
|
|
3704
|
-
if (this.currentHash >= this.hashesPerPage) {
|
|
3705
|
-
this.resetPage();
|
|
3706
|
-
}
|
|
3707
|
-
return Bytes.fromBlob(this.page.subarray(startIdx, endIdx), HASH_SIZE);
|
|
3708
|
-
}
|
|
3709
|
-
}
|
|
3710
|
-
const defaultAllocator = new SimpleAllocator();
|
|
3711
|
-
|
|
3712
|
-
function getDefaultExportFromCjs (x) {
|
|
3713
|
-
return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
|
|
3714
|
-
}
|
|
3715
|
-
|
|
3716
|
-
var blake2b$3 = {exports: {}};
|
|
3717
|
-
|
|
3718
|
-
var nanoassert;
|
|
3719
|
-
var hasRequiredNanoassert;
|
|
3720
|
-
|
|
3721
|
-
function requireNanoassert () {
|
|
3722
|
-
if (hasRequiredNanoassert) return nanoassert;
|
|
3723
|
-
hasRequiredNanoassert = 1;
|
|
3724
|
-
nanoassert = assert;
|
|
3725
|
-
|
|
3726
|
-
class AssertionError extends Error {}
|
|
3727
|
-
AssertionError.prototype.name = 'AssertionError';
|
|
3728
|
-
|
|
3729
|
-
/**
|
|
3730
|
-
* Minimal assert function
|
|
3731
|
-
* @param {any} t Value to check if falsy
|
|
3732
|
-
* @param {string=} m Optional assertion error message
|
|
3733
|
-
* @throws {AssertionError}
|
|
3734
|
-
*/
|
|
3735
|
-
function assert (t, m) {
|
|
3736
|
-
if (!t) {
|
|
3737
|
-
var err = new AssertionError(m);
|
|
3738
|
-
if (Error.captureStackTrace) Error.captureStackTrace(err, assert);
|
|
3739
|
-
throw err
|
|
3740
|
-
}
|
|
3741
|
-
}
|
|
3742
|
-
return nanoassert;
|
|
3743
|
-
}
|
|
3744
|
-
|
|
3745
|
-
var blake2bWasm = {exports: {}};
|
|
3746
|
-
|
|
3747
|
-
var b4a;
|
|
3748
|
-
var hasRequiredB4a;
|
|
3749
|
-
|
|
3750
|
-
function requireB4a () {
|
|
3751
|
-
if (hasRequiredB4a) return b4a;
|
|
3752
|
-
hasRequiredB4a = 1;
|
|
3753
|
-
function isBuffer (value) {
|
|
3754
|
-
return Buffer.isBuffer(value) || value instanceof Uint8Array
|
|
3755
|
-
}
|
|
3756
|
-
|
|
3757
|
-
function isEncoding (encoding) {
|
|
3758
|
-
return Buffer.isEncoding(encoding)
|
|
3759
|
-
}
|
|
3760
|
-
|
|
3761
|
-
function alloc (size, fill, encoding) {
|
|
3762
|
-
return Buffer.alloc(size, fill, encoding)
|
|
3763
|
-
}
|
|
3764
|
-
|
|
3765
|
-
function allocUnsafe (size) {
|
|
3766
|
-
return Buffer.allocUnsafe(size)
|
|
3767
|
-
}
|
|
3768
|
-
|
|
3769
|
-
function allocUnsafeSlow (size) {
|
|
3770
|
-
return Buffer.allocUnsafeSlow(size)
|
|
3771
|
-
}
|
|
3772
|
-
|
|
3773
|
-
function byteLength (string, encoding) {
|
|
3774
|
-
return Buffer.byteLength(string, encoding)
|
|
3775
|
-
}
|
|
3776
|
-
|
|
3777
|
-
function compare (a, b) {
|
|
3778
|
-
return Buffer.compare(a, b)
|
|
3779
|
-
}
|
|
3780
|
-
|
|
3781
|
-
function concat (buffers, totalLength) {
|
|
3782
|
-
return Buffer.concat(buffers, totalLength)
|
|
3783
|
-
}
|
|
3784
|
-
|
|
3785
|
-
function copy (source, target, targetStart, start, end) {
|
|
3786
|
-
return toBuffer(source).copy(target, targetStart, start, end)
|
|
3787
|
-
}
|
|
3788
|
-
|
|
3789
|
-
function equals (a, b) {
|
|
3790
|
-
return toBuffer(a).equals(b)
|
|
3791
|
-
}
|
|
3792
|
-
|
|
3793
|
-
function fill (buffer, value, offset, end, encoding) {
|
|
3794
|
-
return toBuffer(buffer).fill(value, offset, end, encoding)
|
|
3795
|
-
}
|
|
3796
|
-
|
|
3797
|
-
function from (value, encodingOrOffset, length) {
|
|
3798
|
-
return Buffer.from(value, encodingOrOffset, length)
|
|
3799
|
-
}
|
|
3800
|
-
|
|
3801
|
-
function includes (buffer, value, byteOffset, encoding) {
|
|
3802
|
-
return toBuffer(buffer).includes(value, byteOffset, encoding)
|
|
3803
|
-
}
|
|
3804
|
-
|
|
3805
|
-
function indexOf (buffer, value, byfeOffset, encoding) {
|
|
3806
|
-
return toBuffer(buffer).indexOf(value, byfeOffset, encoding)
|
|
3807
|
-
}
|
|
3808
|
-
|
|
3809
|
-
function lastIndexOf (buffer, value, byteOffset, encoding) {
|
|
3810
|
-
return toBuffer(buffer).lastIndexOf(value, byteOffset, encoding)
|
|
3811
|
-
}
|
|
3812
|
-
|
|
3813
|
-
function swap16 (buffer) {
|
|
3814
|
-
return toBuffer(buffer).swap16()
|
|
3815
|
-
}
|
|
3816
|
-
|
|
3817
|
-
function swap32 (buffer) {
|
|
3818
|
-
return toBuffer(buffer).swap32()
|
|
3819
|
-
}
|
|
3820
|
-
|
|
3821
|
-
function swap64 (buffer) {
|
|
3822
|
-
return toBuffer(buffer).swap64()
|
|
3823
|
-
}
|
|
3824
|
-
|
|
3825
|
-
function toBuffer (buffer) {
|
|
3826
|
-
if (Buffer.isBuffer(buffer)) return buffer
|
|
3827
|
-
return Buffer.from(buffer.buffer, buffer.byteOffset, buffer.byteLength)
|
|
3828
|
-
}
|
|
3829
|
-
|
|
3830
|
-
function toString (buffer, encoding, start, end) {
|
|
3831
|
-
return toBuffer(buffer).toString(encoding, start, end)
|
|
3832
|
-
}
|
|
3833
|
-
|
|
3834
|
-
function write (buffer, string, offset, length, encoding) {
|
|
3835
|
-
return toBuffer(buffer).write(string, offset, length, encoding)
|
|
3836
|
-
}
|
|
3837
|
-
|
|
3838
|
-
function writeDoubleLE (buffer, value, offset) {
|
|
3839
|
-
return toBuffer(buffer).writeDoubleLE(value, offset)
|
|
3840
|
-
}
|
|
3841
|
-
|
|
3842
|
-
function writeFloatLE (buffer, value, offset) {
|
|
3843
|
-
return toBuffer(buffer).writeFloatLE(value, offset)
|
|
3844
|
-
}
|
|
3845
|
-
|
|
3846
|
-
function writeUInt32LE (buffer, value, offset) {
|
|
3847
|
-
return toBuffer(buffer).writeUInt32LE(value, offset)
|
|
3848
|
-
}
|
|
3849
|
-
|
|
3850
|
-
function writeInt32LE (buffer, value, offset) {
|
|
3851
|
-
return toBuffer(buffer).writeInt32LE(value, offset)
|
|
3852
|
-
}
|
|
3853
|
-
|
|
3854
|
-
function readDoubleLE (buffer, offset) {
|
|
3855
|
-
return toBuffer(buffer).readDoubleLE(offset)
|
|
3856
|
-
}
|
|
3857
|
-
|
|
3858
|
-
function readFloatLE (buffer, offset) {
|
|
3859
|
-
return toBuffer(buffer).readFloatLE(offset)
|
|
3860
|
-
}
|
|
3861
|
-
|
|
3862
|
-
function readUInt32LE (buffer, offset) {
|
|
3863
|
-
return toBuffer(buffer).readUInt32LE(offset)
|
|
3864
|
-
}
|
|
3865
|
-
|
|
3866
|
-
function readInt32LE (buffer, offset) {
|
|
3867
|
-
return toBuffer(buffer).readInt32LE(offset)
|
|
3868
|
-
}
|
|
3869
|
-
|
|
3870
|
-
b4a = {
|
|
3871
|
-
isBuffer,
|
|
3872
|
-
isEncoding,
|
|
3873
|
-
alloc,
|
|
3874
|
-
allocUnsafe,
|
|
3875
|
-
allocUnsafeSlow,
|
|
3876
|
-
byteLength,
|
|
3877
|
-
compare,
|
|
3878
|
-
concat,
|
|
3879
|
-
copy,
|
|
3880
|
-
equals,
|
|
3881
|
-
fill,
|
|
3882
|
-
from,
|
|
3883
|
-
includes,
|
|
3884
|
-
indexOf,
|
|
3885
|
-
lastIndexOf,
|
|
3886
|
-
swap16,
|
|
3887
|
-
swap32,
|
|
3888
|
-
swap64,
|
|
3889
|
-
toBuffer,
|
|
3890
|
-
toString,
|
|
3891
|
-
write,
|
|
3892
|
-
writeDoubleLE,
|
|
3893
|
-
writeFloatLE,
|
|
3894
|
-
writeUInt32LE,
|
|
3895
|
-
writeInt32LE,
|
|
3896
|
-
readDoubleLE,
|
|
3897
|
-
readFloatLE,
|
|
3898
|
-
readUInt32LE,
|
|
3899
|
-
readInt32LE
|
|
3900
|
-
};
|
|
3901
|
-
return b4a;
|
|
3676
|
+
function deriveEd25519SecretKey(seed, blake2b) {
|
|
3677
|
+
return blake2b.hashBytes(BytesBlob.blobFromParts([ED25519_SECRET_KEY.raw, seed.raw])).asOpaque();
|
|
3902
3678
|
}
|
|
3903
|
-
|
|
3904
|
-
var blake2b$2;
|
|
3905
|
-
var hasRequiredBlake2b$1;
|
|
3906
|
-
|
|
3907
|
-
function requireBlake2b$1 () {
|
|
3908
|
-
if (hasRequiredBlake2b$1) return blake2b$2;
|
|
3909
|
-
hasRequiredBlake2b$1 = 1;
|
|
3910
|
-
var __commonJS = (cb, mod) => function __require() {
|
|
3911
|
-
return mod || (0, cb[Object.keys(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
3912
|
-
};
|
|
3913
|
-
var __toBinary = /* @__PURE__ */ (() => {
|
|
3914
|
-
var table = new Uint8Array(128);
|
|
3915
|
-
for (var i = 0; i < 64; i++)
|
|
3916
|
-
table[i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i * 4 - 205] = i;
|
|
3917
|
-
return (base64) => {
|
|
3918
|
-
var n = base64.length, bytes2 = new Uint8Array((n - (base64[n - 1] == "=") - (base64[n - 2] == "=")) * 3 / 4 | 0);
|
|
3919
|
-
for (var i2 = 0, j = 0; i2 < n; ) {
|
|
3920
|
-
var c0 = table[base64.charCodeAt(i2++)], c1 = table[base64.charCodeAt(i2++)];
|
|
3921
|
-
var c2 = table[base64.charCodeAt(i2++)], c3 = table[base64.charCodeAt(i2++)];
|
|
3922
|
-
bytes2[j++] = c0 << 2 | c1 >> 4;
|
|
3923
|
-
bytes2[j++] = c1 << 4 | c2 >> 2;
|
|
3924
|
-
bytes2[j++] = c2 << 6 | c3;
|
|
3925
|
-
}
|
|
3926
|
-
return bytes2;
|
|
3927
|
-
};
|
|
3928
|
-
})();
|
|
3929
|
-
|
|
3930
|
-
// wasm-binary:./blake2b.wat
|
|
3931
|
-
var require_blake2b = __commonJS({
|
|
3932
|
-
"wasm-binary:./blake2b.wat"(exports2, module2) {
|
|
3933
|
-
module2.exports = __toBinary("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");
|
|
3934
|
-
}
|
|
3935
|
-
});
|
|
3936
|
-
|
|
3937
|
-
// wasm-module:./blake2b.wat
|
|
3938
|
-
var bytes = require_blake2b();
|
|
3939
|
-
var compiled = WebAssembly.compile(bytes);
|
|
3940
|
-
blake2b$2 = async (imports) => {
|
|
3941
|
-
const instance = await WebAssembly.instantiate(await compiled, imports);
|
|
3942
|
-
return instance.exports;
|
|
3943
|
-
};
|
|
3944
|
-
return blake2b$2;
|
|
3945
|
-
}
|
|
3946
|
-
|
|
3947
|
-
var hasRequiredBlake2bWasm;
|
|
3948
|
-
|
|
3949
|
-
function requireBlake2bWasm () {
|
|
3950
|
-
if (hasRequiredBlake2bWasm) return blake2bWasm.exports;
|
|
3951
|
-
hasRequiredBlake2bWasm = 1;
|
|
3952
|
-
var assert = /*@__PURE__*/ requireNanoassert();
|
|
3953
|
-
var b4a = /*@__PURE__*/ requireB4a();
|
|
3954
|
-
|
|
3955
|
-
var wasm = null;
|
|
3956
|
-
var wasmPromise = typeof WebAssembly !== "undefined" && /*@__PURE__*/ requireBlake2b$1()().then(mod => {
|
|
3957
|
-
wasm = mod;
|
|
3958
|
-
});
|
|
3959
|
-
|
|
3960
|
-
var head = 64;
|
|
3961
|
-
var freeList = [];
|
|
3962
|
-
|
|
3963
|
-
blake2bWasm.exports = Blake2b;
|
|
3964
|
-
var BYTES_MIN = blake2bWasm.exports.BYTES_MIN = 16;
|
|
3965
|
-
var BYTES_MAX = blake2bWasm.exports.BYTES_MAX = 64;
|
|
3966
|
-
blake2bWasm.exports.BYTES = 32;
|
|
3967
|
-
var KEYBYTES_MIN = blake2bWasm.exports.KEYBYTES_MIN = 16;
|
|
3968
|
-
var KEYBYTES_MAX = blake2bWasm.exports.KEYBYTES_MAX = 64;
|
|
3969
|
-
blake2bWasm.exports.KEYBYTES = 32;
|
|
3970
|
-
var SALTBYTES = blake2bWasm.exports.SALTBYTES = 16;
|
|
3971
|
-
var PERSONALBYTES = blake2bWasm.exports.PERSONALBYTES = 16;
|
|
3972
|
-
|
|
3973
|
-
function Blake2b (digestLength, key, salt, personal, noAssert) {
|
|
3974
|
-
if (!(this instanceof Blake2b)) return new Blake2b(digestLength, key, salt, personal, noAssert)
|
|
3975
|
-
if (!wasm) throw new Error('WASM not loaded. Wait for Blake2b.ready(cb)')
|
|
3976
|
-
if (!digestLength) digestLength = 32;
|
|
3977
|
-
|
|
3978
|
-
if (noAssert !== true) {
|
|
3979
|
-
assert(digestLength >= BYTES_MIN, 'digestLength must be at least ' + BYTES_MIN + ', was given ' + digestLength);
|
|
3980
|
-
assert(digestLength <= BYTES_MAX, 'digestLength must be at most ' + BYTES_MAX + ', was given ' + digestLength);
|
|
3981
|
-
if (key != null) {
|
|
3982
|
-
assert(key instanceof Uint8Array, 'key must be Uint8Array or Buffer');
|
|
3983
|
-
assert(key.length >= KEYBYTES_MIN, 'key must be at least ' + KEYBYTES_MIN + ', was given ' + key.length);
|
|
3984
|
-
assert(key.length <= KEYBYTES_MAX, 'key must be at least ' + KEYBYTES_MAX + ', was given ' + key.length);
|
|
3985
|
-
}
|
|
3986
|
-
if (salt != null) {
|
|
3987
|
-
assert(salt instanceof Uint8Array, 'salt must be Uint8Array or Buffer');
|
|
3988
|
-
assert(salt.length === SALTBYTES, 'salt must be exactly ' + SALTBYTES + ', was given ' + salt.length);
|
|
3989
|
-
}
|
|
3990
|
-
if (personal != null) {
|
|
3991
|
-
assert(personal instanceof Uint8Array, 'personal must be Uint8Array or Buffer');
|
|
3992
|
-
assert(personal.length === PERSONALBYTES, 'personal must be exactly ' + PERSONALBYTES + ', was given ' + personal.length);
|
|
3993
|
-
}
|
|
3994
|
-
}
|
|
3995
|
-
|
|
3996
|
-
if (!freeList.length) {
|
|
3997
|
-
freeList.push(head);
|
|
3998
|
-
head += 216;
|
|
3999
|
-
}
|
|
4000
|
-
|
|
4001
|
-
this.digestLength = digestLength;
|
|
4002
|
-
this.finalized = false;
|
|
4003
|
-
this.pointer = freeList.pop();
|
|
4004
|
-
this._memory = new Uint8Array(wasm.memory.buffer);
|
|
4005
|
-
|
|
4006
|
-
this._memory.fill(0, 0, 64);
|
|
4007
|
-
this._memory[0] = this.digestLength;
|
|
4008
|
-
this._memory[1] = key ? key.length : 0;
|
|
4009
|
-
this._memory[2] = 1; // fanout
|
|
4010
|
-
this._memory[3] = 1; // depth
|
|
4011
|
-
|
|
4012
|
-
if (salt) this._memory.set(salt, 32);
|
|
4013
|
-
if (personal) this._memory.set(personal, 48);
|
|
4014
|
-
|
|
4015
|
-
if (this.pointer + 216 > this._memory.length) this._realloc(this.pointer + 216); // we need 216 bytes for the state
|
|
4016
|
-
wasm.blake2b_init(this.pointer, this.digestLength);
|
|
4017
|
-
|
|
4018
|
-
if (key) {
|
|
4019
|
-
this.update(key);
|
|
4020
|
-
this._memory.fill(0, head, head + key.length); // whiteout key
|
|
4021
|
-
this._memory[this.pointer + 200] = 128;
|
|
4022
|
-
}
|
|
4023
|
-
}
|
|
4024
|
-
|
|
4025
|
-
Blake2b.prototype._realloc = function (size) {
|
|
4026
|
-
wasm.memory.grow(Math.max(0, Math.ceil(Math.abs(size - this._memory.length) / 65536)));
|
|
4027
|
-
this._memory = new Uint8Array(wasm.memory.buffer);
|
|
4028
|
-
};
|
|
4029
|
-
|
|
4030
|
-
Blake2b.prototype.update = function (input) {
|
|
4031
|
-
assert(this.finalized === false, 'Hash instance finalized');
|
|
4032
|
-
assert(input instanceof Uint8Array, 'input must be Uint8Array or Buffer');
|
|
4033
|
-
|
|
4034
|
-
if (head + input.length > this._memory.length) this._realloc(head + input.length);
|
|
4035
|
-
this._memory.set(input, head);
|
|
4036
|
-
wasm.blake2b_update(this.pointer, head, head + input.length);
|
|
4037
|
-
return this
|
|
4038
|
-
};
|
|
4039
|
-
|
|
4040
|
-
Blake2b.prototype.digest = function (enc) {
|
|
4041
|
-
assert(this.finalized === false, 'Hash instance finalized');
|
|
4042
|
-
this.finalized = true;
|
|
4043
|
-
|
|
4044
|
-
freeList.push(this.pointer);
|
|
4045
|
-
wasm.blake2b_final(this.pointer);
|
|
4046
|
-
|
|
4047
|
-
if (!enc || enc === 'binary') {
|
|
4048
|
-
return this._memory.slice(this.pointer + 128, this.pointer + 128 + this.digestLength)
|
|
4049
|
-
}
|
|
4050
|
-
|
|
4051
|
-
if (typeof enc === 'string') {
|
|
4052
|
-
return b4a.toString(this._memory, enc, this.pointer + 128, this.pointer + 128 + this.digestLength)
|
|
4053
|
-
}
|
|
4054
|
-
|
|
4055
|
-
assert(enc instanceof Uint8Array && enc.length >= this.digestLength, 'input must be Uint8Array or Buffer');
|
|
4056
|
-
for (var i = 0; i < this.digestLength; i++) {
|
|
4057
|
-
enc[i] = this._memory[this.pointer + 128 + i];
|
|
4058
|
-
}
|
|
4059
|
-
|
|
4060
|
-
return enc
|
|
4061
|
-
};
|
|
4062
|
-
|
|
4063
|
-
// libsodium compat
|
|
4064
|
-
Blake2b.prototype.final = Blake2b.prototype.digest;
|
|
4065
|
-
|
|
4066
|
-
Blake2b.WASM = wasm;
|
|
4067
|
-
Blake2b.SUPPORTED = typeof WebAssembly !== 'undefined';
|
|
4068
|
-
|
|
4069
|
-
Blake2b.ready = function (cb) {
|
|
4070
|
-
if (!cb) cb = noop;
|
|
4071
|
-
if (!wasmPromise) return cb(new Error('WebAssembly not supported'))
|
|
4072
|
-
return wasmPromise.then(() => cb(), cb)
|
|
4073
|
-
};
|
|
4074
|
-
|
|
4075
|
-
Blake2b.prototype.ready = Blake2b.ready;
|
|
4076
|
-
|
|
4077
|
-
Blake2b.prototype.getPartialHash = function () {
|
|
4078
|
-
return this._memory.slice(this.pointer, this.pointer + 216);
|
|
4079
|
-
};
|
|
4080
|
-
|
|
4081
|
-
Blake2b.prototype.setPartialHash = function (ph) {
|
|
4082
|
-
this._memory.set(ph, this.pointer);
|
|
4083
|
-
};
|
|
4084
|
-
|
|
4085
|
-
function noop () {}
|
|
4086
|
-
return blake2bWasm.exports;
|
|
4087
|
-
}
|
|
4088
|
-
|
|
4089
|
-
var hasRequiredBlake2b;
|
|
4090
|
-
|
|
4091
|
-
function requireBlake2b () {
|
|
4092
|
-
if (hasRequiredBlake2b) return blake2b$3.exports;
|
|
4093
|
-
hasRequiredBlake2b = 1;
|
|
4094
|
-
var assert = /*@__PURE__*/ requireNanoassert();
|
|
4095
|
-
var b2wasm = /*@__PURE__*/ requireBlake2bWasm();
|
|
4096
|
-
|
|
4097
|
-
// 64-bit unsigned addition
|
|
4098
|
-
// Sets v[a,a+1] += v[b,b+1]
|
|
4099
|
-
// v should be a Uint32Array
|
|
4100
|
-
function ADD64AA (v, a, b) {
|
|
4101
|
-
var o0 = v[a] + v[b];
|
|
4102
|
-
var o1 = v[a + 1] + v[b + 1];
|
|
4103
|
-
if (o0 >= 0x100000000) {
|
|
4104
|
-
o1++;
|
|
4105
|
-
}
|
|
4106
|
-
v[a] = o0;
|
|
4107
|
-
v[a + 1] = o1;
|
|
4108
|
-
}
|
|
4109
|
-
|
|
4110
|
-
// 64-bit unsigned addition
|
|
4111
|
-
// Sets v[a,a+1] += b
|
|
4112
|
-
// b0 is the low 32 bits of b, b1 represents the high 32 bits
|
|
4113
|
-
function ADD64AC (v, a, b0, b1) {
|
|
4114
|
-
var o0 = v[a] + b0;
|
|
4115
|
-
if (b0 < 0) {
|
|
4116
|
-
o0 += 0x100000000;
|
|
4117
|
-
}
|
|
4118
|
-
var o1 = v[a + 1] + b1;
|
|
4119
|
-
if (o0 >= 0x100000000) {
|
|
4120
|
-
o1++;
|
|
4121
|
-
}
|
|
4122
|
-
v[a] = o0;
|
|
4123
|
-
v[a + 1] = o1;
|
|
4124
|
-
}
|
|
4125
|
-
|
|
4126
|
-
// Little-endian byte access
|
|
4127
|
-
function B2B_GET32 (arr, i) {
|
|
4128
|
-
return (arr[i] ^
|
|
4129
|
-
(arr[i + 1] << 8) ^
|
|
4130
|
-
(arr[i + 2] << 16) ^
|
|
4131
|
-
(arr[i + 3] << 24))
|
|
4132
|
-
}
|
|
4133
|
-
|
|
4134
|
-
// G Mixing function
|
|
4135
|
-
// The ROTRs are inlined for speed
|
|
4136
|
-
function B2B_G (a, b, c, d, ix, iy) {
|
|
4137
|
-
var x0 = m[ix];
|
|
4138
|
-
var x1 = m[ix + 1];
|
|
4139
|
-
var y0 = m[iy];
|
|
4140
|
-
var y1 = m[iy + 1];
|
|
4141
|
-
|
|
4142
|
-
ADD64AA(v, a, b); // v[a,a+1] += v[b,b+1] ... in JS we must store a uint64 as two uint32s
|
|
4143
|
-
ADD64AC(v, a, x0, x1); // v[a, a+1] += x ... x0 is the low 32 bits of x, x1 is the high 32 bits
|
|
4144
|
-
|
|
4145
|
-
// v[d,d+1] = (v[d,d+1] xor v[a,a+1]) rotated to the right by 32 bits
|
|
4146
|
-
var xor0 = v[d] ^ v[a];
|
|
4147
|
-
var xor1 = v[d + 1] ^ v[a + 1];
|
|
4148
|
-
v[d] = xor1;
|
|
4149
|
-
v[d + 1] = xor0;
|
|
4150
|
-
|
|
4151
|
-
ADD64AA(v, c, d);
|
|
4152
|
-
|
|
4153
|
-
// v[b,b+1] = (v[b,b+1] xor v[c,c+1]) rotated right by 24 bits
|
|
4154
|
-
xor0 = v[b] ^ v[c];
|
|
4155
|
-
xor1 = v[b + 1] ^ v[c + 1];
|
|
4156
|
-
v[b] = (xor0 >>> 24) ^ (xor1 << 8);
|
|
4157
|
-
v[b + 1] = (xor1 >>> 24) ^ (xor0 << 8);
|
|
4158
|
-
|
|
4159
|
-
ADD64AA(v, a, b);
|
|
4160
|
-
ADD64AC(v, a, y0, y1);
|
|
4161
|
-
|
|
4162
|
-
// v[d,d+1] = (v[d,d+1] xor v[a,a+1]) rotated right by 16 bits
|
|
4163
|
-
xor0 = v[d] ^ v[a];
|
|
4164
|
-
xor1 = v[d + 1] ^ v[a + 1];
|
|
4165
|
-
v[d] = (xor0 >>> 16) ^ (xor1 << 16);
|
|
4166
|
-
v[d + 1] = (xor1 >>> 16) ^ (xor0 << 16);
|
|
4167
|
-
|
|
4168
|
-
ADD64AA(v, c, d);
|
|
4169
|
-
|
|
4170
|
-
// v[b,b+1] = (v[b,b+1] xor v[c,c+1]) rotated right by 63 bits
|
|
4171
|
-
xor0 = v[b] ^ v[c];
|
|
4172
|
-
xor1 = v[b + 1] ^ v[c + 1];
|
|
4173
|
-
v[b] = (xor1 >>> 31) ^ (xor0 << 1);
|
|
4174
|
-
v[b + 1] = (xor0 >>> 31) ^ (xor1 << 1);
|
|
4175
|
-
}
|
|
4176
|
-
|
|
4177
|
-
// Initialization Vector
|
|
4178
|
-
var BLAKE2B_IV32 = new Uint32Array([
|
|
4179
|
-
0xF3BCC908, 0x6A09E667, 0x84CAA73B, 0xBB67AE85,
|
|
4180
|
-
0xFE94F82B, 0x3C6EF372, 0x5F1D36F1, 0xA54FF53A,
|
|
4181
|
-
0xADE682D1, 0x510E527F, 0x2B3E6C1F, 0x9B05688C,
|
|
4182
|
-
0xFB41BD6B, 0x1F83D9AB, 0x137E2179, 0x5BE0CD19
|
|
4183
|
-
]);
|
|
4184
|
-
|
|
4185
|
-
var SIGMA8 = [
|
|
4186
|
-
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
|
|
4187
|
-
14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3,
|
|
4188
|
-
11, 8, 12, 0, 5, 2, 15, 13, 10, 14, 3, 6, 7, 1, 9, 4,
|
|
4189
|
-
7, 9, 3, 1, 13, 12, 11, 14, 2, 6, 5, 10, 4, 0, 15, 8,
|
|
4190
|
-
9, 0, 5, 7, 2, 4, 10, 15, 14, 1, 11, 12, 6, 8, 3, 13,
|
|
4191
|
-
2, 12, 6, 10, 0, 11, 8, 3, 4, 13, 7, 5, 15, 14, 1, 9,
|
|
4192
|
-
12, 5, 1, 15, 14, 13, 4, 10, 0, 7, 6, 3, 9, 2, 8, 11,
|
|
4193
|
-
13, 11, 7, 14, 12, 1, 3, 9, 5, 0, 15, 4, 8, 6, 2, 10,
|
|
4194
|
-
6, 15, 14, 9, 11, 3, 0, 8, 12, 2, 13, 7, 1, 4, 10, 5,
|
|
4195
|
-
10, 2, 8, 4, 7, 6, 1, 5, 15, 11, 9, 14, 3, 12, 13, 0,
|
|
4196
|
-
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
|
|
4197
|
-
14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3
|
|
4198
|
-
];
|
|
4199
|
-
|
|
4200
|
-
// These are offsets into a uint64 buffer.
|
|
4201
|
-
// Multiply them all by 2 to make them offsets into a uint32 buffer,
|
|
4202
|
-
// because this is Javascript and we don't have uint64s
|
|
4203
|
-
var SIGMA82 = new Uint8Array(SIGMA8.map(function (x) { return x * 2 }));
|
|
4204
|
-
|
|
4205
|
-
// Compression function. 'last' flag indicates last block.
|
|
4206
|
-
// Note we're representing 16 uint64s as 32 uint32s
|
|
4207
|
-
var v = new Uint32Array(32);
|
|
4208
|
-
var m = new Uint32Array(32);
|
|
4209
|
-
function blake2bCompress (ctx, last) {
|
|
4210
|
-
var i = 0;
|
|
4211
|
-
|
|
4212
|
-
// init work variables
|
|
4213
|
-
for (i = 0; i < 16; i++) {
|
|
4214
|
-
v[i] = ctx.h[i];
|
|
4215
|
-
v[i + 16] = BLAKE2B_IV32[i];
|
|
4216
|
-
}
|
|
4217
|
-
|
|
4218
|
-
// low 64 bits of offset
|
|
4219
|
-
v[24] = v[24] ^ ctx.t;
|
|
4220
|
-
v[25] = v[25] ^ (ctx.t / 0x100000000);
|
|
4221
|
-
// high 64 bits not supported, offset may not be higher than 2**53-1
|
|
4222
|
-
|
|
4223
|
-
// last block flag set ?
|
|
4224
|
-
if (last) {
|
|
4225
|
-
v[28] = ~v[28];
|
|
4226
|
-
v[29] = ~v[29];
|
|
4227
|
-
}
|
|
4228
|
-
|
|
4229
|
-
// get little-endian words
|
|
4230
|
-
for (i = 0; i < 32; i++) {
|
|
4231
|
-
m[i] = B2B_GET32(ctx.b, 4 * i);
|
|
4232
|
-
}
|
|
4233
|
-
|
|
4234
|
-
// twelve rounds of mixing
|
|
4235
|
-
for (i = 0; i < 12; i++) {
|
|
4236
|
-
B2B_G(0, 8, 16, 24, SIGMA82[i * 16 + 0], SIGMA82[i * 16 + 1]);
|
|
4237
|
-
B2B_G(2, 10, 18, 26, SIGMA82[i * 16 + 2], SIGMA82[i * 16 + 3]);
|
|
4238
|
-
B2B_G(4, 12, 20, 28, SIGMA82[i * 16 + 4], SIGMA82[i * 16 + 5]);
|
|
4239
|
-
B2B_G(6, 14, 22, 30, SIGMA82[i * 16 + 6], SIGMA82[i * 16 + 7]);
|
|
4240
|
-
B2B_G(0, 10, 20, 30, SIGMA82[i * 16 + 8], SIGMA82[i * 16 + 9]);
|
|
4241
|
-
B2B_G(2, 12, 22, 24, SIGMA82[i * 16 + 10], SIGMA82[i * 16 + 11]);
|
|
4242
|
-
B2B_G(4, 14, 16, 26, SIGMA82[i * 16 + 12], SIGMA82[i * 16 + 13]);
|
|
4243
|
-
B2B_G(6, 8, 18, 28, SIGMA82[i * 16 + 14], SIGMA82[i * 16 + 15]);
|
|
4244
|
-
}
|
|
4245
|
-
|
|
4246
|
-
for (i = 0; i < 16; i++) {
|
|
4247
|
-
ctx.h[i] = ctx.h[i] ^ v[i] ^ v[i + 16];
|
|
4248
|
-
}
|
|
4249
|
-
}
|
|
4250
|
-
|
|
4251
|
-
// reusable parameter_block
|
|
4252
|
-
var parameter_block = new Uint8Array([
|
|
4253
|
-
0, 0, 0, 0, // 0: outlen, keylen, fanout, depth
|
|
4254
|
-
0, 0, 0, 0, // 4: leaf length, sequential mode
|
|
4255
|
-
0, 0, 0, 0, // 8: node offset
|
|
4256
|
-
0, 0, 0, 0, // 12: node offset
|
|
4257
|
-
0, 0, 0, 0, // 16: node depth, inner length, rfu
|
|
4258
|
-
0, 0, 0, 0, // 20: rfu
|
|
4259
|
-
0, 0, 0, 0, // 24: rfu
|
|
4260
|
-
0, 0, 0, 0, // 28: rfu
|
|
4261
|
-
0, 0, 0, 0, // 32: salt
|
|
4262
|
-
0, 0, 0, 0, // 36: salt
|
|
4263
|
-
0, 0, 0, 0, // 40: salt
|
|
4264
|
-
0, 0, 0, 0, // 44: salt
|
|
4265
|
-
0, 0, 0, 0, // 48: personal
|
|
4266
|
-
0, 0, 0, 0, // 52: personal
|
|
4267
|
-
0, 0, 0, 0, // 56: personal
|
|
4268
|
-
0, 0, 0, 0 // 60: personal
|
|
4269
|
-
]);
|
|
4270
|
-
|
|
4271
|
-
// Creates a BLAKE2b hashing context
|
|
4272
|
-
// Requires an output length between 1 and 64 bytes
|
|
4273
|
-
// Takes an optional Uint8Array key
|
|
4274
|
-
function Blake2b (outlen, key, salt, personal) {
|
|
4275
|
-
// zero out parameter_block before usage
|
|
4276
|
-
parameter_block.fill(0);
|
|
4277
|
-
// state, 'param block'
|
|
4278
|
-
|
|
4279
|
-
this.b = new Uint8Array(128);
|
|
4280
|
-
this.h = new Uint32Array(16);
|
|
4281
|
-
this.t = 0; // input count
|
|
4282
|
-
this.c = 0; // pointer within buffer
|
|
4283
|
-
this.outlen = outlen; // output length in bytes
|
|
4284
|
-
|
|
4285
|
-
parameter_block[0] = outlen;
|
|
4286
|
-
if (key) parameter_block[1] = key.length;
|
|
4287
|
-
parameter_block[2] = 1; // fanout
|
|
4288
|
-
parameter_block[3] = 1; // depth
|
|
4289
|
-
|
|
4290
|
-
if (salt) parameter_block.set(salt, 32);
|
|
4291
|
-
if (personal) parameter_block.set(personal, 48);
|
|
4292
|
-
|
|
4293
|
-
// initialize hash state
|
|
4294
|
-
for (var i = 0; i < 16; i++) {
|
|
4295
|
-
this.h[i] = BLAKE2B_IV32[i] ^ B2B_GET32(parameter_block, i * 4);
|
|
4296
|
-
}
|
|
4297
|
-
|
|
4298
|
-
// key the hash, if applicable
|
|
4299
|
-
if (key) {
|
|
4300
|
-
blake2bUpdate(this, key);
|
|
4301
|
-
// at the end
|
|
4302
|
-
this.c = 128;
|
|
4303
|
-
}
|
|
4304
|
-
}
|
|
4305
|
-
|
|
4306
|
-
Blake2b.prototype.update = function (input) {
|
|
4307
|
-
assert(input instanceof Uint8Array, 'input must be Uint8Array or Buffer');
|
|
4308
|
-
blake2bUpdate(this, input);
|
|
4309
|
-
return this
|
|
4310
|
-
};
|
|
4311
|
-
|
|
4312
|
-
Blake2b.prototype.digest = function (out) {
|
|
4313
|
-
var buf = (!out || out === 'binary' || out === 'hex') ? new Uint8Array(this.outlen) : out;
|
|
4314
|
-
assert(buf instanceof Uint8Array, 'out must be "binary", "hex", Uint8Array, or Buffer');
|
|
4315
|
-
assert(buf.length >= this.outlen, 'out must have at least outlen bytes of space');
|
|
4316
|
-
blake2bFinal(this, buf);
|
|
4317
|
-
if (out === 'hex') return hexSlice(buf)
|
|
4318
|
-
return buf
|
|
4319
|
-
};
|
|
4320
|
-
|
|
4321
|
-
Blake2b.prototype.final = Blake2b.prototype.digest;
|
|
4322
|
-
|
|
4323
|
-
Blake2b.ready = function (cb) {
|
|
4324
|
-
b2wasm.ready(function () {
|
|
4325
|
-
cb(); // ignore the error
|
|
4326
|
-
});
|
|
4327
|
-
};
|
|
4328
|
-
|
|
4329
|
-
// Updates a BLAKE2b streaming hash
|
|
4330
|
-
// Requires hash context and Uint8Array (byte array)
|
|
4331
|
-
function blake2bUpdate (ctx, input) {
|
|
4332
|
-
for (var i = 0; i < input.length; i++) {
|
|
4333
|
-
if (ctx.c === 128) { // buffer full ?
|
|
4334
|
-
ctx.t += ctx.c; // add counters
|
|
4335
|
-
blake2bCompress(ctx, false); // compress (not last)
|
|
4336
|
-
ctx.c = 0; // counter to zero
|
|
4337
|
-
}
|
|
4338
|
-
ctx.b[ctx.c++] = input[i];
|
|
4339
|
-
}
|
|
4340
|
-
}
|
|
4341
|
-
|
|
4342
|
-
// Completes a BLAKE2b streaming hash
|
|
4343
|
-
// Returns a Uint8Array containing the message digest
|
|
4344
|
-
function blake2bFinal (ctx, out) {
|
|
4345
|
-
ctx.t += ctx.c; // mark last block offset
|
|
4346
|
-
|
|
4347
|
-
while (ctx.c < 128) { // fill up with zeros
|
|
4348
|
-
ctx.b[ctx.c++] = 0;
|
|
4349
|
-
}
|
|
4350
|
-
blake2bCompress(ctx, true); // final block flag = 1
|
|
4351
|
-
|
|
4352
|
-
for (var i = 0; i < ctx.outlen; i++) {
|
|
4353
|
-
out[i] = ctx.h[i >> 2] >> (8 * (i & 3));
|
|
4354
|
-
}
|
|
4355
|
-
return out
|
|
4356
|
-
}
|
|
4357
|
-
|
|
4358
|
-
function hexSlice (buf) {
|
|
4359
|
-
var str = '';
|
|
4360
|
-
for (var i = 0; i < buf.length; i++) str += toHex(buf[i]);
|
|
4361
|
-
return str
|
|
4362
|
-
}
|
|
4363
|
-
|
|
4364
|
-
function toHex (n) {
|
|
4365
|
-
if (n < 16) return '0' + n.toString(16)
|
|
4366
|
-
return n.toString(16)
|
|
4367
|
-
}
|
|
4368
|
-
|
|
4369
|
-
var Proto = Blake2b;
|
|
4370
|
-
|
|
4371
|
-
blake2b$3.exports = function createHash (outlen, key, salt, personal, noAssert) {
|
|
4372
|
-
if (noAssert !== true) {
|
|
4373
|
-
assert(outlen >= BYTES_MIN, 'outlen must be at least ' + BYTES_MIN + ', was given ' + outlen);
|
|
4374
|
-
assert(outlen <= BYTES_MAX, 'outlen must be at most ' + BYTES_MAX + ', was given ' + outlen);
|
|
4375
|
-
if (key != null) {
|
|
4376
|
-
assert(key instanceof Uint8Array, 'key must be Uint8Array or Buffer');
|
|
4377
|
-
assert(key.length >= KEYBYTES_MIN, 'key must be at least ' + KEYBYTES_MIN + ', was given ' + key.length);
|
|
4378
|
-
assert(key.length <= KEYBYTES_MAX, 'key must be at most ' + KEYBYTES_MAX + ', was given ' + key.length);
|
|
4379
|
-
}
|
|
4380
|
-
if (salt != null) {
|
|
4381
|
-
assert(salt instanceof Uint8Array, 'salt must be Uint8Array or Buffer');
|
|
4382
|
-
assert(salt.length === SALTBYTES, 'salt must be exactly ' + SALTBYTES + ', was given ' + salt.length);
|
|
4383
|
-
}
|
|
4384
|
-
if (personal != null) {
|
|
4385
|
-
assert(personal instanceof Uint8Array, 'personal must be Uint8Array or Buffer');
|
|
4386
|
-
assert(personal.length === PERSONALBYTES, 'personal must be exactly ' + PERSONALBYTES + ', was given ' + personal.length);
|
|
4387
|
-
}
|
|
4388
|
-
}
|
|
4389
|
-
|
|
4390
|
-
return new Proto(outlen, key, salt, personal)
|
|
4391
|
-
};
|
|
4392
|
-
|
|
4393
|
-
blake2b$3.exports.ready = function (cb) {
|
|
4394
|
-
b2wasm.ready(function () { // ignore errors
|
|
4395
|
-
cb();
|
|
4396
|
-
});
|
|
4397
|
-
};
|
|
4398
|
-
|
|
4399
|
-
blake2b$3.exports.WASM_SUPPORTED = b2wasm.SUPPORTED;
|
|
4400
|
-
blake2b$3.exports.WASM_LOADED = false;
|
|
4401
|
-
|
|
4402
|
-
var BYTES_MIN = blake2b$3.exports.BYTES_MIN = 16;
|
|
4403
|
-
var BYTES_MAX = blake2b$3.exports.BYTES_MAX = 64;
|
|
4404
|
-
blake2b$3.exports.BYTES = 32;
|
|
4405
|
-
var KEYBYTES_MIN = blake2b$3.exports.KEYBYTES_MIN = 16;
|
|
4406
|
-
var KEYBYTES_MAX = blake2b$3.exports.KEYBYTES_MAX = 64;
|
|
4407
|
-
blake2b$3.exports.KEYBYTES = 32;
|
|
4408
|
-
var SALTBYTES = blake2b$3.exports.SALTBYTES = 16;
|
|
4409
|
-
var PERSONALBYTES = blake2b$3.exports.PERSONALBYTES = 16;
|
|
4410
|
-
|
|
4411
|
-
b2wasm.ready(function (err) {
|
|
4412
|
-
if (!err) {
|
|
4413
|
-
blake2b$3.exports.WASM_LOADED = true;
|
|
4414
|
-
blake2b$3.exports = b2wasm;
|
|
4415
|
-
}
|
|
4416
|
-
});
|
|
4417
|
-
return blake2b$3.exports;
|
|
4418
|
-
}
|
|
4419
|
-
|
|
4420
|
-
var blake2bExports = /*@__PURE__*/ requireBlake2b();
|
|
4421
|
-
var blake2b$1 = /*@__PURE__*/getDefaultExportFromCjs(blake2bExports);
|
|
4422
|
-
|
|
4423
3679
|
/**
|
|
4424
|
-
*
|
|
4425
|
-
*
|
|
4426
|
-
* If empty array is given a zero-hash is returned.
|
|
3680
|
+
* Derives a Bandersnatch secret key from a seed.
|
|
3681
|
+
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md#derivation-method
|
|
4427
3682
|
*/
|
|
4428
|
-
function
|
|
4429
|
-
|
|
4430
|
-
if (r.length === 0) {
|
|
4431
|
-
return out.asOpaque();
|
|
4432
|
-
}
|
|
4433
|
-
const hasher = blake2b$1(HASH_SIZE);
|
|
4434
|
-
for (const v of r) {
|
|
4435
|
-
hasher?.update(v instanceof BytesBlob ? v.raw : v);
|
|
4436
|
-
}
|
|
4437
|
-
hasher?.digest(out.raw);
|
|
4438
|
-
return out.asOpaque();
|
|
3683
|
+
function deriveBandersnatchSecretKey(seed, blake2b) {
|
|
3684
|
+
return blake2b.hashBytes(BytesBlob.blobFromParts([BANDERSNATCH_SECRET_KEY.raw, seed.raw])).asOpaque();
|
|
4439
3685
|
}
|
|
4440
|
-
/**
|
|
4441
|
-
|
|
4442
|
-
|
|
4443
|
-
|
|
4444
|
-
|
|
4445
|
-
const out = allocator.emptyHash();
|
|
4446
|
-
hasher?.digest(out.raw);
|
|
4447
|
-
return out;
|
|
3686
|
+
/**
|
|
3687
|
+
* Derive Ed25519 public key from secret seed
|
|
3688
|
+
*/
|
|
3689
|
+
async function deriveEd25519PublicKey(seed) {
|
|
3690
|
+
return (await privateKey(seed)).pubKey;
|
|
4448
3691
|
}
|
|
4449
|
-
/**
|
|
4450
|
-
|
|
4451
|
-
|
|
3692
|
+
/**
|
|
3693
|
+
* Derive Bandersnatch public key from secret seed
|
|
3694
|
+
*/
|
|
3695
|
+
function deriveBandersnatchPublicKey(seed) {
|
|
3696
|
+
return publicKey(seed.raw);
|
|
4452
3697
|
}
|
|
4453
3698
|
|
|
4454
|
-
var
|
|
3699
|
+
var keyDerivation = /*#__PURE__*/Object.freeze({
|
|
3700
|
+
__proto__: null,
|
|
3701
|
+
SEED_SIZE: SEED_SIZE,
|
|
3702
|
+
deriveBandersnatchPublicKey: deriveBandersnatchPublicKey,
|
|
3703
|
+
deriveBandersnatchSecretKey: deriveBandersnatchSecretKey,
|
|
3704
|
+
deriveEd25519PublicKey: deriveEd25519PublicKey,
|
|
3705
|
+
deriveEd25519SecretKey: deriveEd25519SecretKey,
|
|
3706
|
+
trivialSeed: trivialSeed
|
|
3707
|
+
});
|
|
3708
|
+
|
|
3709
|
+
var index$p = /*#__PURE__*/Object.freeze({
|
|
4455
3710
|
__proto__: null,
|
|
4456
|
-
|
|
4457
|
-
|
|
4458
|
-
|
|
3711
|
+
BANDERSNATCH_KEY_BYTES: BANDERSNATCH_KEY_BYTES,
|
|
3712
|
+
BANDERSNATCH_PROOF_BYTES: BANDERSNATCH_PROOF_BYTES,
|
|
3713
|
+
BANDERSNATCH_RING_ROOT_BYTES: BANDERSNATCH_RING_ROOT_BYTES,
|
|
3714
|
+
BANDERSNATCH_VRF_SIGNATURE_BYTES: BANDERSNATCH_VRF_SIGNATURE_BYTES,
|
|
3715
|
+
BLS_KEY_BYTES: BLS_KEY_BYTES,
|
|
3716
|
+
ED25519_KEY_BYTES: ED25519_KEY_BYTES,
|
|
3717
|
+
ED25519_PRIV_KEY_BYTES: ED25519_PRIV_KEY_BYTES,
|
|
3718
|
+
ED25519_SIGNATURE_BYTES: ED25519_SIGNATURE_BYTES,
|
|
3719
|
+
Ed25519Pair: Ed25519Pair,
|
|
3720
|
+
SEED_SIZE: SEED_SIZE,
|
|
3721
|
+
bandersnatch: bandersnatch,
|
|
3722
|
+
bandersnatchWasm: bandersnatch_exports,
|
|
3723
|
+
ed25519: ed25519,
|
|
3724
|
+
initWasm: initAll,
|
|
3725
|
+
keyDerivation: keyDerivation
|
|
4459
3726
|
});
|
|
4460
3727
|
|
|
4461
3728
|
/*!
|
|
@@ -4816,7 +4083,78 @@ function WASMInterface(binary, hashLength) {
|
|
|
4816
4083
|
|
|
4817
4084
|
new Mutex();
|
|
4818
4085
|
|
|
4086
|
+
var name$j = "blake2b";
|
|
4087
|
+
var data$j = "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";
|
|
4088
|
+
var hash$j = "c6f286e6";
|
|
4089
|
+
var wasmJson$j = {
|
|
4090
|
+
name: name$j,
|
|
4091
|
+
data: data$j,
|
|
4092
|
+
hash: hash$j
|
|
4093
|
+
};
|
|
4094
|
+
|
|
4819
4095
|
new Mutex();
|
|
4096
|
+
function validateBits$4(bits) {
|
|
4097
|
+
if (!Number.isInteger(bits) || bits < 8 || bits > 512 || bits % 8 !== 0) {
|
|
4098
|
+
return new Error("Invalid variant! Valid values: 8, 16, ..., 512");
|
|
4099
|
+
}
|
|
4100
|
+
return null;
|
|
4101
|
+
}
|
|
4102
|
+
function getInitParam$1(outputBits, keyBits) {
|
|
4103
|
+
return outputBits | (keyBits << 16);
|
|
4104
|
+
}
|
|
4105
|
+
/**
|
|
4106
|
+
* Creates a new BLAKE2b hash instance
|
|
4107
|
+
* @param bits Number of output bits, which has to be a number
|
|
4108
|
+
* divisible by 8, between 8 and 512. Defaults to 512.
|
|
4109
|
+
* @param key Optional key (string, Buffer or TypedArray). Maximum length is 64 bytes.
|
|
4110
|
+
*/
|
|
4111
|
+
function createBLAKE2b(bits = 512, key = null) {
|
|
4112
|
+
if (validateBits$4(bits)) {
|
|
4113
|
+
return Promise.reject(validateBits$4(bits));
|
|
4114
|
+
}
|
|
4115
|
+
let keyBuffer = null;
|
|
4116
|
+
let initParam = bits;
|
|
4117
|
+
if (key !== null) {
|
|
4118
|
+
keyBuffer = getUInt8Buffer(key);
|
|
4119
|
+
if (keyBuffer.length > 64) {
|
|
4120
|
+
return Promise.reject(new Error("Max key length is 64 bytes"));
|
|
4121
|
+
}
|
|
4122
|
+
initParam = getInitParam$1(bits, keyBuffer.length);
|
|
4123
|
+
}
|
|
4124
|
+
const outputSize = bits / 8;
|
|
4125
|
+
return WASMInterface(wasmJson$j, outputSize).then((wasm) => {
|
|
4126
|
+
if (initParam > 512) {
|
|
4127
|
+
wasm.writeMemory(keyBuffer);
|
|
4128
|
+
}
|
|
4129
|
+
wasm.init(initParam);
|
|
4130
|
+
const obj = {
|
|
4131
|
+
init: initParam > 512
|
|
4132
|
+
? () => {
|
|
4133
|
+
wasm.writeMemory(keyBuffer);
|
|
4134
|
+
wasm.init(initParam);
|
|
4135
|
+
return obj;
|
|
4136
|
+
}
|
|
4137
|
+
: () => {
|
|
4138
|
+
wasm.init(initParam);
|
|
4139
|
+
return obj;
|
|
4140
|
+
},
|
|
4141
|
+
update: (data) => {
|
|
4142
|
+
wasm.update(data);
|
|
4143
|
+
return obj;
|
|
4144
|
+
},
|
|
4145
|
+
// biome-ignore lint/suspicious/noExplicitAny: Conflict with IHasher type
|
|
4146
|
+
digest: (outputType) => wasm.digest(outputType),
|
|
4147
|
+
save: () => wasm.save(),
|
|
4148
|
+
load: (data) => {
|
|
4149
|
+
wasm.load(data);
|
|
4150
|
+
return obj;
|
|
4151
|
+
},
|
|
4152
|
+
blockSize: 128,
|
|
4153
|
+
digestSize: outputSize,
|
|
4154
|
+
};
|
|
4155
|
+
return obj;
|
|
4156
|
+
});
|
|
4157
|
+
}
|
|
4820
4158
|
|
|
4821
4159
|
new Mutex();
|
|
4822
4160
|
|
|
@@ -4906,6 +4244,79 @@ new Mutex();
|
|
|
4906
4244
|
|
|
4907
4245
|
new Mutex();
|
|
4908
4246
|
|
|
4247
|
+
/**
|
|
4248
|
+
* Size of the output of the hash functions.
|
|
4249
|
+
*
|
|
4250
|
+
* https://graypaper.fluffylabs.dev/#/579bd12/073101073c01
|
|
4251
|
+
*
|
|
4252
|
+
*/
|
|
4253
|
+
const HASH_SIZE = 32;
|
|
4254
|
+
/** A hash without last byte (useful for trie representation). */
|
|
4255
|
+
const TRUNCATED_HASH_SIZE = 31;
|
|
4256
|
+
const ZERO_HASH = Bytes.zero(HASH_SIZE);
|
|
4257
|
+
/**
|
|
4258
|
+
* Container for some object with a hash that is related to this object.
|
|
4259
|
+
*
|
|
4260
|
+
* After calculating the hash these two should be passed together to avoid
|
|
4261
|
+
* unnecessary re-hashing of the data.
|
|
4262
|
+
*/
|
|
4263
|
+
class WithHash extends WithDebug {
|
|
4264
|
+
hash;
|
|
4265
|
+
data;
|
|
4266
|
+
constructor(hash, data) {
|
|
4267
|
+
super();
|
|
4268
|
+
this.hash = hash;
|
|
4269
|
+
this.data = data;
|
|
4270
|
+
}
|
|
4271
|
+
}
|
|
4272
|
+
/**
|
|
4273
|
+
* Extension of [`WithHash`] additionally containing an encoded version of the object.
|
|
4274
|
+
*/
|
|
4275
|
+
class WithHashAndBytes extends WithHash {
|
|
4276
|
+
encoded;
|
|
4277
|
+
constructor(hash, data, encoded) {
|
|
4278
|
+
super(hash, data);
|
|
4279
|
+
this.encoded = encoded;
|
|
4280
|
+
}
|
|
4281
|
+
}
|
|
4282
|
+
|
|
4283
|
+
const zero$1 = Bytes.zero(HASH_SIZE);
|
|
4284
|
+
class Blake2b {
|
|
4285
|
+
hasher;
|
|
4286
|
+
static async createHasher() {
|
|
4287
|
+
return new Blake2b(await createBLAKE2b(HASH_SIZE * 8));
|
|
4288
|
+
}
|
|
4289
|
+
constructor(hasher) {
|
|
4290
|
+
this.hasher = hasher;
|
|
4291
|
+
}
|
|
4292
|
+
/**
|
|
4293
|
+
* Hash given collection of blobs.
|
|
4294
|
+
*
|
|
4295
|
+
* If empty array is given a zero-hash is returned.
|
|
4296
|
+
*/
|
|
4297
|
+
hashBlobs(r) {
|
|
4298
|
+
if (r.length === 0) {
|
|
4299
|
+
return zero$1.asOpaque();
|
|
4300
|
+
}
|
|
4301
|
+
const hasher = this.hasher.init();
|
|
4302
|
+
for (const v of r) {
|
|
4303
|
+
hasher.update(v instanceof BytesBlob ? v.raw : v);
|
|
4304
|
+
}
|
|
4305
|
+
return Bytes.fromBlob(hasher.digest("binary"), HASH_SIZE).asOpaque();
|
|
4306
|
+
}
|
|
4307
|
+
/** Hash given blob of bytes. */
|
|
4308
|
+
hashBytes(blob) {
|
|
4309
|
+
const hasher = this.hasher.init();
|
|
4310
|
+
const bytes = blob instanceof BytesBlob ? blob.raw : blob;
|
|
4311
|
+
hasher.update(bytes);
|
|
4312
|
+
return Bytes.fromBlob(hasher.digest("binary"), HASH_SIZE).asOpaque();
|
|
4313
|
+
}
|
|
4314
|
+
/** Convert given string into bytes and hash it. */
|
|
4315
|
+
hashString(str) {
|
|
4316
|
+
return this.hashBytes(BytesBlob.blobFromString(str));
|
|
4317
|
+
}
|
|
4318
|
+
}
|
|
4319
|
+
|
|
4909
4320
|
class KeccakHasher {
|
|
4910
4321
|
hasher;
|
|
4911
4322
|
static async create() {
|
|
@@ -4930,91 +4341,61 @@ var keccak = /*#__PURE__*/Object.freeze({
|
|
|
4930
4341
|
hashBlobs: hashBlobs
|
|
4931
4342
|
});
|
|
4932
4343
|
|
|
4933
|
-
|
|
4344
|
+
// TODO [ToDr] (#213) this should most likely be moved to a separate
|
|
4345
|
+
// package to avoid pulling in unnecessary deps.
|
|
4346
|
+
|
|
4347
|
+
var index$o = /*#__PURE__*/Object.freeze({
|
|
4934
4348
|
__proto__: null,
|
|
4349
|
+
Blake2b: Blake2b,
|
|
4935
4350
|
HASH_SIZE: HASH_SIZE,
|
|
4936
|
-
PageAllocator: PageAllocator,
|
|
4937
|
-
SimpleAllocator: SimpleAllocator,
|
|
4938
4351
|
TRUNCATED_HASH_SIZE: TRUNCATED_HASH_SIZE,
|
|
4939
4352
|
WithHash: WithHash,
|
|
4940
4353
|
WithHashAndBytes: WithHashAndBytes,
|
|
4941
4354
|
ZERO_HASH: ZERO_HASH,
|
|
4942
|
-
blake2b: blake2b,
|
|
4943
|
-
defaultAllocator: defaultAllocator,
|
|
4944
4355
|
keccak: keccak
|
|
4945
4356
|
});
|
|
4946
4357
|
|
|
4947
|
-
const SEED_SIZE = 32;
|
|
4948
|
-
const ED25519_SECRET_KEY = Bytes.blobFromString("jam_val_key_ed25519");
|
|
4949
|
-
const BANDERSNATCH_SECRET_KEY = Bytes.blobFromString("jam_val_key_bandersnatch");
|
|
4950
|
-
/**
|
|
4951
|
-
* JIP-5: Secret key derivation
|
|
4952
|
-
*
|
|
4953
|
-
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md */
|
|
4954
|
-
/**
|
|
4955
|
-
* Deriving a 32-byte seed from a 32-bit unsigned integer
|
|
4956
|
-
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md#trivial-seeds
|
|
4957
|
-
*/
|
|
4958
|
-
function trivialSeed(s) {
|
|
4959
|
-
const s_le = u32AsLeBytes(s);
|
|
4960
|
-
return Bytes.fromBlob(BytesBlob.blobFromParts([s_le, s_le, s_le, s_le, s_le, s_le, s_le, s_le]).raw, SEED_SIZE).asOpaque();
|
|
4961
|
-
}
|
|
4962
|
-
/**
|
|
4963
|
-
* Derives a Ed25519 secret key from a seed.
|
|
4964
|
-
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md#derivation-method
|
|
4965
|
-
*/
|
|
4966
|
-
function deriveEd25519SecretKey(seed, allocator = new SimpleAllocator()) {
|
|
4967
|
-
return hashBytes(BytesBlob.blobFromParts([ED25519_SECRET_KEY.raw, seed.raw]), allocator).asOpaque();
|
|
4968
|
-
}
|
|
4969
|
-
/**
|
|
4970
|
-
* Derives a Bandersnatch secret key from a seed.
|
|
4971
|
-
* https://github.com/polkadot-fellows/JIPs/blob/7048f79edf4f4eb8bfe6fb42e6bbf61900f44c65/JIP-5.md#derivation-method
|
|
4972
|
-
*/
|
|
4973
|
-
function deriveBandersnatchSecretKey(seed, allocator = new SimpleAllocator()) {
|
|
4974
|
-
return hashBytes(BytesBlob.blobFromParts([BANDERSNATCH_SECRET_KEY.raw, seed.raw]), allocator).asOpaque();
|
|
4975
|
-
}
|
|
4976
4358
|
/**
|
|
4977
|
-
*
|
|
4359
|
+
* A utility class providing a readonly view over a portion of an array without copying it.
|
|
4978
4360
|
*/
|
|
4979
|
-
|
|
4980
|
-
|
|
4981
|
-
|
|
4982
|
-
|
|
4983
|
-
|
|
4984
|
-
|
|
4985
|
-
|
|
4986
|
-
|
|
4361
|
+
class ArrayView {
|
|
4362
|
+
start;
|
|
4363
|
+
end;
|
|
4364
|
+
source;
|
|
4365
|
+
length;
|
|
4366
|
+
constructor(source, start, end) {
|
|
4367
|
+
this.start = start;
|
|
4368
|
+
this.end = end;
|
|
4369
|
+
this.source = source;
|
|
4370
|
+
this.length = end - start;
|
|
4371
|
+
}
|
|
4372
|
+
static from(source, start = 0, end = source.length) {
|
|
4373
|
+
check `
|
|
4374
|
+
${start >= 0 && end <= source.length && start <= end}
|
|
4375
|
+
Invalid start (${start})/end (${end}) for ArrayView
|
|
4376
|
+
`;
|
|
4377
|
+
return new ArrayView(source, start, end);
|
|
4378
|
+
}
|
|
4379
|
+
get(i) {
|
|
4380
|
+
check `
|
|
4381
|
+
${i >= 0 && i < this.length}
|
|
4382
|
+
Index out of bounds: ${i} < ${this.length}
|
|
4383
|
+
`;
|
|
4384
|
+
return this.source[this.start + i];
|
|
4385
|
+
}
|
|
4386
|
+
subview(from, to = this.length) {
|
|
4387
|
+
return ArrayView.from(this.source, this.start + from, this.start + to);
|
|
4388
|
+
}
|
|
4389
|
+
toArray() {
|
|
4390
|
+
return this.source.slice(this.start, this.end);
|
|
4391
|
+
}
|
|
4392
|
+
*[Symbol.iterator]() {
|
|
4393
|
+
for (let i = this.start; i < this.end; i++) {
|
|
4394
|
+
yield this.source[i];
|
|
4395
|
+
}
|
|
4396
|
+
}
|
|
4987
4397
|
}
|
|
4988
4398
|
|
|
4989
|
-
var keyDerivation = /*#__PURE__*/Object.freeze({
|
|
4990
|
-
__proto__: null,
|
|
4991
|
-
SEED_SIZE: SEED_SIZE,
|
|
4992
|
-
deriveBandersnatchPublicKey: deriveBandersnatchPublicKey,
|
|
4993
|
-
deriveBandersnatchSecretKey: deriveBandersnatchSecretKey,
|
|
4994
|
-
deriveEd25519PublicKey: deriveEd25519PublicKey,
|
|
4995
|
-
deriveEd25519SecretKey: deriveEd25519SecretKey,
|
|
4996
|
-
trivialSeed: trivialSeed
|
|
4997
|
-
});
|
|
4998
|
-
|
|
4999
|
-
var index$o = /*#__PURE__*/Object.freeze({
|
|
5000
|
-
__proto__: null,
|
|
5001
|
-
BANDERSNATCH_KEY_BYTES: BANDERSNATCH_KEY_BYTES,
|
|
5002
|
-
BANDERSNATCH_PROOF_BYTES: BANDERSNATCH_PROOF_BYTES,
|
|
5003
|
-
BANDERSNATCH_RING_ROOT_BYTES: BANDERSNATCH_RING_ROOT_BYTES,
|
|
5004
|
-
BANDERSNATCH_VRF_SIGNATURE_BYTES: BANDERSNATCH_VRF_SIGNATURE_BYTES,
|
|
5005
|
-
BLS_KEY_BYTES: BLS_KEY_BYTES,
|
|
5006
|
-
ED25519_KEY_BYTES: ED25519_KEY_BYTES,
|
|
5007
|
-
ED25519_PRIV_KEY_BYTES: ED25519_PRIV_KEY_BYTES,
|
|
5008
|
-
ED25519_SIGNATURE_BYTES: ED25519_SIGNATURE_BYTES,
|
|
5009
|
-
Ed25519Pair: Ed25519Pair,
|
|
5010
|
-
SEED_SIZE: SEED_SIZE,
|
|
5011
|
-
bandersnatch: bandersnatch,
|
|
5012
|
-
bandersnatchWasm: bandersnatch_exports,
|
|
5013
|
-
ed25519: ed25519,
|
|
5014
|
-
initWasm: initAll,
|
|
5015
|
-
keyDerivation: keyDerivation
|
|
5016
|
-
});
|
|
5017
|
-
|
|
5018
4399
|
/** A map which uses hashes as keys. */
|
|
5019
4400
|
class HashDictionary {
|
|
5020
4401
|
// TODO [ToDr] [crit] We can't use `TrieHash` directly in the map,
|
|
@@ -5602,6 +4983,7 @@ class TruncatedHashDictionary {
|
|
|
5602
4983
|
|
|
5603
4984
|
var index$n = /*#__PURE__*/Object.freeze({
|
|
5604
4985
|
__proto__: null,
|
|
4986
|
+
ArrayView: ArrayView,
|
|
5605
4987
|
FixedSizeArray: FixedSizeArray,
|
|
5606
4988
|
HashDictionary: HashDictionary,
|
|
5607
4989
|
HashSet: HashSet,
|
|
@@ -8563,43 +7945,43 @@ var stateKeys;
|
|
|
8563
7945
|
}
|
|
8564
7946
|
stateKeys.serviceInfo = serviceInfo;
|
|
8565
7947
|
/** https://graypaper.fluffylabs.dev/#/1c979cb/3bba033bba03?v=0.7.1 */
|
|
8566
|
-
function serviceStorage(serviceId, key) {
|
|
7948
|
+
function serviceStorage(blake2b, serviceId, key) {
|
|
8567
7949
|
if (Compatibility.isLessThan(GpVersion.V0_6_7)) {
|
|
8568
7950
|
const out = Bytes.zero(HASH_SIZE);
|
|
8569
7951
|
out.raw.set(u32AsLeBytes(tryAsU32(2 ** 32 - 1)), 0);
|
|
8570
7952
|
out.raw.set(key.raw.subarray(0, HASH_SIZE - U32_BYTES), U32_BYTES);
|
|
8571
7953
|
return legacyServiceNested(serviceId, out);
|
|
8572
7954
|
}
|
|
8573
|
-
return serviceNested(serviceId, tryAsU32(2 ** 32 - 1), key);
|
|
7955
|
+
return serviceNested(blake2b, serviceId, tryAsU32(2 ** 32 - 1), key);
|
|
8574
7956
|
}
|
|
8575
7957
|
stateKeys.serviceStorage = serviceStorage;
|
|
8576
7958
|
/** https://graypaper.fluffylabs.dev/#/1c979cb/3bd7033bd703?v=0.7.1 */
|
|
8577
|
-
function servicePreimage(serviceId, hash) {
|
|
7959
|
+
function servicePreimage(blake2b, serviceId, hash) {
|
|
8578
7960
|
if (Compatibility.isLessThan(GpVersion.V0_6_7)) {
|
|
8579
7961
|
const out = Bytes.zero(HASH_SIZE);
|
|
8580
7962
|
out.raw.set(u32AsLeBytes(tryAsU32(2 ** 32 - 2)), 0);
|
|
8581
7963
|
out.raw.set(hash.raw.subarray(1, HASH_SIZE - U32_BYTES + 1), U32_BYTES);
|
|
8582
7964
|
return legacyServiceNested(serviceId, out);
|
|
8583
7965
|
}
|
|
8584
|
-
return serviceNested(serviceId, tryAsU32(2 ** 32 - 2), hash);
|
|
7966
|
+
return serviceNested(blake2b, serviceId, tryAsU32(2 ** 32 - 2), hash);
|
|
8585
7967
|
}
|
|
8586
7968
|
stateKeys.servicePreimage = servicePreimage;
|
|
8587
7969
|
/** https://graypaper.fluffylabs.dev/#/1c979cb/3b0a043b0a04?v=0.7.1 */
|
|
8588
|
-
function serviceLookupHistory(serviceId, hash, preimageLength) {
|
|
7970
|
+
function serviceLookupHistory(blake2b, serviceId, hash, preimageLength) {
|
|
8589
7971
|
if (Compatibility.isLessThan(GpVersion.V0_6_7)) {
|
|
8590
|
-
const doubleHash = hashBytes(hash);
|
|
7972
|
+
const doubleHash = blake2b.hashBytes(hash);
|
|
8591
7973
|
const out = Bytes.zero(HASH_SIZE);
|
|
8592
7974
|
out.raw.set(u32AsLeBytes(preimageLength), 0);
|
|
8593
7975
|
out.raw.set(doubleHash.raw.subarray(2, HASH_SIZE - U32_BYTES + 2), U32_BYTES);
|
|
8594
7976
|
return legacyServiceNested(serviceId, out);
|
|
8595
7977
|
}
|
|
8596
|
-
return serviceNested(serviceId, preimageLength, hash);
|
|
7978
|
+
return serviceNested(blake2b, serviceId, preimageLength, hash);
|
|
8597
7979
|
}
|
|
8598
7980
|
stateKeys.serviceLookupHistory = serviceLookupHistory;
|
|
8599
7981
|
/** https://graypaper.fluffylabs.dev/#/1c979cb/3b88003b8800?v=0.7.1 */
|
|
8600
|
-
function serviceNested(serviceId, numberPrefix, hash) {
|
|
7982
|
+
function serviceNested(blake2b, serviceId, numberPrefix, hash) {
|
|
8601
7983
|
const inputToHash = BytesBlob.blobFromParts(u32AsLeBytes(numberPrefix), hash.raw);
|
|
8602
|
-
const newHash = hashBytes(inputToHash).raw.subarray(0, 28);
|
|
7984
|
+
const newHash = blake2b.hashBytes(inputToHash).raw.subarray(0, 28);
|
|
8603
7985
|
const key = Bytes.zero(HASH_SIZE);
|
|
8604
7986
|
let i = 0;
|
|
8605
7987
|
for (const byte of u32AsLeBytes(serviceId)) {
|
|
@@ -8660,12 +8042,6 @@ function accumulationOutputComparator(a, b) {
|
|
|
8660
8042
|
return Ordering.Equal;
|
|
8661
8043
|
}
|
|
8662
8044
|
|
|
8663
|
-
const codecWithHash = (val) => Descriptor.withView(val.name, val.sizeHint, (e, elem) => val.encode(e, elem.data), (d) => {
|
|
8664
|
-
const decoder2 = d.clone();
|
|
8665
|
-
const encoded = val.skipEncoded(decoder2);
|
|
8666
|
-
const hash = hashBytes(encoded);
|
|
8667
|
-
return new WithHash(hash.asOpaque(), val.decode(d));
|
|
8668
|
-
}, val.skip, val.View);
|
|
8669
8045
|
/**
|
|
8670
8046
|
* Assignment of particular work report to a core.
|
|
8671
8047
|
*
|
|
@@ -8678,7 +8054,7 @@ class AvailabilityAssignment extends WithDebug {
|
|
|
8678
8054
|
workReport;
|
|
8679
8055
|
timeout;
|
|
8680
8056
|
static Codec = codec$1.Class(AvailabilityAssignment, {
|
|
8681
|
-
workReport:
|
|
8057
|
+
workReport: WorkReport.Codec,
|
|
8682
8058
|
timeout: codec$1.u32.asOpaque(),
|
|
8683
8059
|
});
|
|
8684
8060
|
static create({ workReport, timeout }) {
|
|
@@ -8731,6 +8107,10 @@ class DisputesRecords {
|
|
|
8731
8107
|
static create({ goodSet, badSet, wonkySet, punishSet }) {
|
|
8732
8108
|
return new DisputesRecords(goodSet, badSet, wonkySet, punishSet);
|
|
8733
8109
|
}
|
|
8110
|
+
goodSetDict;
|
|
8111
|
+
badSetDict;
|
|
8112
|
+
wonkySetDict;
|
|
8113
|
+
punishSetDict;
|
|
8734
8114
|
constructor(
|
|
8735
8115
|
/** `goodSet`: all work-reports hashes which were judged to be correct */
|
|
8736
8116
|
goodSet,
|
|
@@ -8744,6 +8124,18 @@ class DisputesRecords {
|
|
|
8744
8124
|
this.badSet = badSet;
|
|
8745
8125
|
this.wonkySet = wonkySet;
|
|
8746
8126
|
this.punishSet = punishSet;
|
|
8127
|
+
this.goodSetDict = HashSet.from(goodSet.array);
|
|
8128
|
+
this.badSetDict = HashSet.from(badSet.array);
|
|
8129
|
+
this.wonkySetDict = HashSet.from(wonkySet.array);
|
|
8130
|
+
this.punishSetDict = HashSet.from(punishSet.array);
|
|
8131
|
+
}
|
|
8132
|
+
asDictionaries() {
|
|
8133
|
+
return {
|
|
8134
|
+
goodSet: this.goodSetDict,
|
|
8135
|
+
badSet: this.badSetDict,
|
|
8136
|
+
wonkySet: this.wonkySetDict,
|
|
8137
|
+
punishSet: this.punishSetDict,
|
|
8138
|
+
};
|
|
8747
8139
|
}
|
|
8748
8140
|
static fromSortedArrays({ goodSet, badSet, wonkySet, punishSet, }) {
|
|
8749
8141
|
return new DisputesRecords(SortedSet.fromSortedArray(hashComparator, goodSet), SortedSet.fromSortedArray(hashComparator, badSet), SortedSet.fromSortedArray(hashComparator, wonkySet), SortedSet.fromSortedArray(hashComparator, punishSet));
|
|
@@ -9110,6 +8502,23 @@ const zeroSizeHint = {
|
|
|
9110
8502
|
};
|
|
9111
8503
|
/** 0-byte read, return given default value */
|
|
9112
8504
|
const ignoreValueWithDefault = (defaultValue) => Descriptor.new("ignoreValue", zeroSizeHint, (_e, _v) => { }, (_d) => defaultValue, (_s) => { });
|
|
8505
|
+
/** Encode and decode object with leading version number. */
|
|
8506
|
+
const codecWithVersion = (val) => Descriptor.new("withVersion", {
|
|
8507
|
+
bytes: val.sizeHint.bytes + 8,
|
|
8508
|
+
isExact: false,
|
|
8509
|
+
}, (e, v) => {
|
|
8510
|
+
e.varU64(0n);
|
|
8511
|
+
val.encode(e, v);
|
|
8512
|
+
}, (d) => {
|
|
8513
|
+
const version = d.varU64();
|
|
8514
|
+
if (version !== 0n) {
|
|
8515
|
+
throw new Error("Non-zero version is not supported!");
|
|
8516
|
+
}
|
|
8517
|
+
return val.decode(d);
|
|
8518
|
+
}, (s) => {
|
|
8519
|
+
s.varU64();
|
|
8520
|
+
val.skip(s);
|
|
8521
|
+
});
|
|
9113
8522
|
/**
|
|
9114
8523
|
* Service account details.
|
|
9115
8524
|
*
|
|
@@ -10119,6 +9528,7 @@ var index$g = /*#__PURE__*/Object.freeze({
|
|
|
10119
9528
|
ValidatorStatistics: ValidatorStatistics,
|
|
10120
9529
|
accumulationOutputComparator: accumulationOutputComparator,
|
|
10121
9530
|
codecPerCore: codecPerCore,
|
|
9531
|
+
codecWithVersion: codecWithVersion,
|
|
10122
9532
|
hashComparator: hashComparator,
|
|
10123
9533
|
ignoreValueWithDefault: ignoreValueWithDefault,
|
|
10124
9534
|
serviceDataCodec: serviceDataCodec,
|
|
@@ -10279,21 +9689,23 @@ var serialize;
|
|
|
10279
9689
|
/** C(255, s): https://graypaper.fluffylabs.dev/#/85129da/383103383103?v=0.6.3 */
|
|
10280
9690
|
serialize.serviceData = (serviceId) => ({
|
|
10281
9691
|
key: stateKeys.serviceInfo(serviceId),
|
|
10282
|
-
Codec:
|
|
9692
|
+
Codec: Compatibility.isGreaterOrEqual(GpVersion.V0_7_1)
|
|
9693
|
+
? codecWithVersion(ServiceAccountInfo.Codec)
|
|
9694
|
+
: ServiceAccountInfo.Codec,
|
|
10283
9695
|
});
|
|
10284
9696
|
/** https://graypaper.fluffylabs.dev/#/85129da/384803384803?v=0.6.3 */
|
|
10285
|
-
serialize.serviceStorage = (serviceId, key) => ({
|
|
10286
|
-
key: stateKeys.serviceStorage(serviceId, key),
|
|
9697
|
+
serialize.serviceStorage = (blake2b, serviceId, key) => ({
|
|
9698
|
+
key: stateKeys.serviceStorage(blake2b, serviceId, key),
|
|
10287
9699
|
Codec: dumpCodec,
|
|
10288
9700
|
});
|
|
10289
9701
|
/** https://graypaper.fluffylabs.dev/#/85129da/385b03385b03?v=0.6.3 */
|
|
10290
|
-
serialize.servicePreimages = (serviceId, hash) => ({
|
|
10291
|
-
key: stateKeys.servicePreimage(serviceId, hash),
|
|
9702
|
+
serialize.servicePreimages = (blake2b, serviceId, hash) => ({
|
|
9703
|
+
key: stateKeys.servicePreimage(blake2b, serviceId, hash),
|
|
10292
9704
|
Codec: dumpCodec,
|
|
10293
9705
|
});
|
|
10294
9706
|
/** https://graypaper.fluffylabs.dev/#/85129da/387603387603?v=0.6.3 */
|
|
10295
|
-
serialize.serviceLookupHistory = (serviceId, hash, len) => ({
|
|
10296
|
-
key: stateKeys.serviceLookupHistory(serviceId, hash, len),
|
|
9707
|
+
serialize.serviceLookupHistory = (blake2b, serviceId, hash, len) => ({
|
|
9708
|
+
key: stateKeys.serviceLookupHistory(blake2b, serviceId, hash, len),
|
|
10297
9709
|
Codec: readonlyArray(codec$1.sequenceVarLen(codec$1.u32)),
|
|
10298
9710
|
});
|
|
10299
9711
|
})(serialize || (serialize = {}));
|
|
@@ -10316,20 +9728,22 @@ const dumpCodec = Descriptor.new("Dump", { bytes: 64, isExact: false }, (e, v) =
|
|
|
10316
9728
|
*/
|
|
10317
9729
|
class SerializedState {
|
|
10318
9730
|
spec;
|
|
9731
|
+
blake2b;
|
|
10319
9732
|
backend;
|
|
10320
9733
|
_recentServiceIds;
|
|
10321
9734
|
/** Create a state-like object from collection of serialized entries. */
|
|
10322
|
-
static fromStateEntries(spec, state, recentServices = []) {
|
|
10323
|
-
return new SerializedState(spec, state, recentServices);
|
|
9735
|
+
static fromStateEntries(spec, blake2b, state, recentServices = []) {
|
|
9736
|
+
return new SerializedState(spec, blake2b, state, recentServices);
|
|
10324
9737
|
}
|
|
10325
9738
|
/** Create a state-like object backed by some DB. */
|
|
10326
|
-
static new(spec, db, recentServices = []) {
|
|
10327
|
-
return new SerializedState(spec, db, recentServices);
|
|
9739
|
+
static new(spec, blake2b, db, recentServices = []) {
|
|
9740
|
+
return new SerializedState(spec, blake2b, db, recentServices);
|
|
10328
9741
|
}
|
|
10329
|
-
constructor(spec, backend,
|
|
9742
|
+
constructor(spec, blake2b, backend,
|
|
10330
9743
|
/** Best-effort list of recently active services. */
|
|
10331
9744
|
_recentServiceIds) {
|
|
10332
9745
|
this.spec = spec;
|
|
9746
|
+
this.blake2b = blake2b;
|
|
10333
9747
|
this.backend = backend;
|
|
10334
9748
|
this._recentServiceIds = _recentServiceIds;
|
|
10335
9749
|
}
|
|
@@ -10353,7 +9767,7 @@ class SerializedState {
|
|
|
10353
9767
|
if (!this._recentServiceIds.includes(id)) {
|
|
10354
9768
|
this._recentServiceIds.push(id);
|
|
10355
9769
|
}
|
|
10356
|
-
return new SerializedService(id, serviceData, (key) => this.retrieveOptional(key));
|
|
9770
|
+
return new SerializedService(this.blake2b, id, serviceData, (key) => this.retrieveOptional(key));
|
|
10357
9771
|
}
|
|
10358
9772
|
retrieve({ key, Codec }, description) {
|
|
10359
9773
|
const bytes = this.backend.get(key);
|
|
@@ -10429,12 +9843,14 @@ class SerializedState {
|
|
|
10429
9843
|
}
|
|
10430
9844
|
/** Service data representation on a serialized state. */
|
|
10431
9845
|
class SerializedService {
|
|
9846
|
+
blake2b;
|
|
10432
9847
|
serviceId;
|
|
10433
9848
|
accountInfo;
|
|
10434
9849
|
retrieveOptional;
|
|
10435
|
-
constructor(
|
|
9850
|
+
constructor(blake2b,
|
|
10436
9851
|
/** Service id */
|
|
10437
9852
|
serviceId, accountInfo, retrieveOptional) {
|
|
9853
|
+
this.blake2b = blake2b;
|
|
10438
9854
|
this.serviceId = serviceId;
|
|
10439
9855
|
this.accountInfo = accountInfo;
|
|
10440
9856
|
this.retrieveOptional = retrieveOptional;
|
|
@@ -10447,13 +9863,13 @@ class SerializedService {
|
|
|
10447
9863
|
getStorage(rawKey) {
|
|
10448
9864
|
if (Compatibility.isLessThan(GpVersion.V0_6_7)) {
|
|
10449
9865
|
const SERVICE_ID_BYTES = 4;
|
|
10450
|
-
const serviceIdAndKey =
|
|
9866
|
+
const serviceIdAndKey = safeAllocUint8Array(SERVICE_ID_BYTES + rawKey.length);
|
|
10451
9867
|
serviceIdAndKey.set(u32AsLeBytes(this.serviceId));
|
|
10452
9868
|
serviceIdAndKey.set(rawKey.raw, SERVICE_ID_BYTES);
|
|
10453
|
-
const key = asOpaqueType(BytesBlob.blobFrom(hashBytes(serviceIdAndKey).raw));
|
|
10454
|
-
return this.retrieveOptional(serialize.serviceStorage(this.serviceId, key)) ?? null;
|
|
9869
|
+
const key = asOpaqueType(BytesBlob.blobFrom(this.blake2b.hashBytes(serviceIdAndKey).raw));
|
|
9870
|
+
return this.retrieveOptional(serialize.serviceStorage(this.blake2b, this.serviceId, key)) ?? null;
|
|
10455
9871
|
}
|
|
10456
|
-
return this.retrieveOptional(serialize.serviceStorage(this.serviceId, rawKey)) ?? null;
|
|
9872
|
+
return this.retrieveOptional(serialize.serviceStorage(this.blake2b, this.serviceId, rawKey)) ?? null;
|
|
10457
9873
|
}
|
|
10458
9874
|
/**
|
|
10459
9875
|
* Check if preimage is present in the DB.
|
|
@@ -10462,15 +9878,15 @@ class SerializedService {
|
|
|
10462
9878
|
*/
|
|
10463
9879
|
hasPreimage(hash) {
|
|
10464
9880
|
// TODO [ToDr] consider optimizing to avoid fetching the whole data.
|
|
10465
|
-
return this.retrieveOptional(serialize.servicePreimages(this.serviceId, hash)) !== undefined;
|
|
9881
|
+
return this.retrieveOptional(serialize.servicePreimages(this.blake2b, this.serviceId, hash)) !== undefined;
|
|
10466
9882
|
}
|
|
10467
9883
|
/** Retrieve preimage from the DB. */
|
|
10468
9884
|
getPreimage(hash) {
|
|
10469
|
-
return this.retrieveOptional(serialize.servicePreimages(this.serviceId, hash)) ?? null;
|
|
9885
|
+
return this.retrieveOptional(serialize.servicePreimages(this.blake2b, this.serviceId, hash)) ?? null;
|
|
10470
9886
|
}
|
|
10471
9887
|
/** Retrieve preimage lookup history. */
|
|
10472
9888
|
getLookupHistory(hash, len) {
|
|
10473
|
-
const rawSlots = this.retrieveOptional(serialize.serviceLookupHistory(this.serviceId, hash, len));
|
|
9889
|
+
const rawSlots = this.retrieveOptional(serialize.serviceLookupHistory(this.blake2b, this.serviceId, hash, len));
|
|
10474
9890
|
if (rawSlots === undefined) {
|
|
10475
9891
|
return null;
|
|
10476
9892
|
}
|
|
@@ -10532,7 +9948,7 @@ class TrieNode {
|
|
|
10532
9948
|
raw;
|
|
10533
9949
|
constructor(
|
|
10534
9950
|
/** Exactly 512 bits / 64 bytes */
|
|
10535
|
-
raw =
|
|
9951
|
+
raw = safeAllocUint8Array(TRIE_NODE_BYTES)) {
|
|
10536
9952
|
this.raw = raw;
|
|
10537
9953
|
}
|
|
10538
9954
|
/** Returns the type of the node */
|
|
@@ -11107,11 +10523,13 @@ var index$f = /*#__PURE__*/Object.freeze({
|
|
|
11107
10523
|
parseInputKey: parseInputKey
|
|
11108
10524
|
});
|
|
11109
10525
|
|
|
11110
|
-
|
|
11111
|
-
|
|
11112
|
-
|
|
11113
|
-
|
|
11114
|
-
}
|
|
10526
|
+
function getBlake2bTrieHasher(hasher) {
|
|
10527
|
+
return {
|
|
10528
|
+
hashConcat(n, rest = []) {
|
|
10529
|
+
return hasher.hashBlobs([n, ...rest]);
|
|
10530
|
+
},
|
|
10531
|
+
};
|
|
10532
|
+
}
|
|
11115
10533
|
|
|
11116
10534
|
/** What should be done with that key? */
|
|
11117
10535
|
var StateEntryUpdateAction;
|
|
@@ -11123,14 +10541,14 @@ var StateEntryUpdateAction;
|
|
|
11123
10541
|
})(StateEntryUpdateAction || (StateEntryUpdateAction = {}));
|
|
11124
10542
|
const EMPTY_BLOB = BytesBlob.empty();
|
|
11125
10543
|
/** Serialize given state update into a series of key-value pairs. */
|
|
11126
|
-
function* serializeStateUpdate(spec, update) {
|
|
10544
|
+
function* serializeStateUpdate(spec, blake2b, update) {
|
|
11127
10545
|
// first let's serialize all of the simple entries (if present!)
|
|
11128
10546
|
yield* serializeBasicKeys(spec, update);
|
|
11129
10547
|
const encode = (codec, val) => Encoder.encodeObject(codec, val, spec);
|
|
11130
10548
|
// then let's proceed with service updates
|
|
11131
|
-
yield* serializeServiceUpdates(update.servicesUpdates, encode);
|
|
11132
|
-
yield* serializePreimages(update.preimages, encode);
|
|
11133
|
-
yield* serializeStorage(update.storage);
|
|
10549
|
+
yield* serializeServiceUpdates(update.servicesUpdates, encode, blake2b);
|
|
10550
|
+
yield* serializePreimages(update.preimages, encode, blake2b);
|
|
10551
|
+
yield* serializeStorage(update.storage, blake2b);
|
|
11134
10552
|
yield* serializeRemovedServices(update.servicesRemoved);
|
|
11135
10553
|
}
|
|
11136
10554
|
function* serializeRemovedServices(servicesRemoved) {
|
|
@@ -11140,18 +10558,18 @@ function* serializeRemovedServices(servicesRemoved) {
|
|
|
11140
10558
|
yield [StateEntryUpdateAction.Remove, codec.key, EMPTY_BLOB];
|
|
11141
10559
|
}
|
|
11142
10560
|
}
|
|
11143
|
-
function* serializeStorage(storage) {
|
|
10561
|
+
function* serializeStorage(storage, blake2b) {
|
|
11144
10562
|
for (const { action, serviceId } of storage ?? []) {
|
|
11145
10563
|
switch (action.kind) {
|
|
11146
10564
|
case UpdateStorageKind.Set: {
|
|
11147
10565
|
const key = action.storage.key;
|
|
11148
|
-
const codec = serialize.serviceStorage(serviceId, key);
|
|
10566
|
+
const codec = serialize.serviceStorage(blake2b, serviceId, key);
|
|
11149
10567
|
yield [StateEntryUpdateAction.Insert, codec.key, action.storage.value];
|
|
11150
10568
|
break;
|
|
11151
10569
|
}
|
|
11152
10570
|
case UpdateStorageKind.Remove: {
|
|
11153
10571
|
const key = action.key;
|
|
11154
|
-
const codec = serialize.serviceStorage(serviceId, key);
|
|
10572
|
+
const codec = serialize.serviceStorage(blake2b, serviceId, key);
|
|
11155
10573
|
yield [StateEntryUpdateAction.Remove, codec.key, EMPTY_BLOB];
|
|
11156
10574
|
break;
|
|
11157
10575
|
}
|
|
@@ -11160,15 +10578,15 @@ function* serializeStorage(storage) {
|
|
|
11160
10578
|
}
|
|
11161
10579
|
}
|
|
11162
10580
|
}
|
|
11163
|
-
function* serializePreimages(preimages, encode) {
|
|
10581
|
+
function* serializePreimages(preimages, encode, blake2b) {
|
|
11164
10582
|
for (const { action, serviceId } of preimages ?? []) {
|
|
11165
10583
|
switch (action.kind) {
|
|
11166
10584
|
case UpdatePreimageKind.Provide: {
|
|
11167
10585
|
const { hash, blob } = action.preimage;
|
|
11168
|
-
const codec = serialize.servicePreimages(serviceId, hash);
|
|
10586
|
+
const codec = serialize.servicePreimages(blake2b, serviceId, hash);
|
|
11169
10587
|
yield [StateEntryUpdateAction.Insert, codec.key, blob];
|
|
11170
10588
|
if (action.slot !== null) {
|
|
11171
|
-
const codec2 = serialize.serviceLookupHistory(serviceId, hash, tryAsU32(blob.length));
|
|
10589
|
+
const codec2 = serialize.serviceLookupHistory(blake2b, serviceId, hash, tryAsU32(blob.length));
|
|
11172
10590
|
yield [
|
|
11173
10591
|
StateEntryUpdateAction.Insert,
|
|
11174
10592
|
codec2.key,
|
|
@@ -11179,15 +10597,15 @@ function* serializePreimages(preimages, encode) {
|
|
|
11179
10597
|
}
|
|
11180
10598
|
case UpdatePreimageKind.UpdateOrAdd: {
|
|
11181
10599
|
const { hash, length, slots } = action.item;
|
|
11182
|
-
const codec = serialize.serviceLookupHistory(serviceId, hash, length);
|
|
10600
|
+
const codec = serialize.serviceLookupHistory(blake2b, serviceId, hash, length);
|
|
11183
10601
|
yield [StateEntryUpdateAction.Insert, codec.key, encode(codec.Codec, slots)];
|
|
11184
10602
|
break;
|
|
11185
10603
|
}
|
|
11186
10604
|
case UpdatePreimageKind.Remove: {
|
|
11187
10605
|
const { hash, length } = action;
|
|
11188
|
-
const codec = serialize.servicePreimages(serviceId, hash);
|
|
10606
|
+
const codec = serialize.servicePreimages(blake2b, serviceId, hash);
|
|
11189
10607
|
yield [StateEntryUpdateAction.Remove, codec.key, EMPTY_BLOB];
|
|
11190
|
-
const codec2 = serialize.serviceLookupHistory(serviceId, hash, length);
|
|
10608
|
+
const codec2 = serialize.serviceLookupHistory(blake2b, serviceId, hash, length);
|
|
11191
10609
|
yield [StateEntryUpdateAction.Remove, codec2.key, EMPTY_BLOB];
|
|
11192
10610
|
break;
|
|
11193
10611
|
}
|
|
@@ -11196,7 +10614,7 @@ function* serializePreimages(preimages, encode) {
|
|
|
11196
10614
|
}
|
|
11197
10615
|
}
|
|
11198
10616
|
}
|
|
11199
|
-
function* serializeServiceUpdates(servicesUpdates, encode) {
|
|
10617
|
+
function* serializeServiceUpdates(servicesUpdates, encode, blake2b) {
|
|
11200
10618
|
for (const { action, serviceId } of servicesUpdates ?? []) {
|
|
11201
10619
|
// new service being created or updated
|
|
11202
10620
|
const codec = serialize.serviceData(serviceId);
|
|
@@ -11204,7 +10622,7 @@ function* serializeServiceUpdates(servicesUpdates, encode) {
|
|
|
11204
10622
|
// additional lookup history update
|
|
11205
10623
|
if (action.kind === UpdateServiceKind.Create && action.lookupHistory !== null) {
|
|
11206
10624
|
const { lookupHistory } = action;
|
|
11207
|
-
const codec2 = serialize.serviceLookupHistory(serviceId, lookupHistory.hash, lookupHistory.length);
|
|
10625
|
+
const codec2 = serialize.serviceLookupHistory(blake2b, serviceId, lookupHistory.hash, lookupHistory.length);
|
|
11208
10626
|
yield [StateEntryUpdateAction.Insert, codec2.key, encode(codec2.Codec, lookupHistory.slots)];
|
|
11209
10627
|
}
|
|
11210
10628
|
}
|
|
@@ -11299,8 +10717,8 @@ class StateEntries {
|
|
|
11299
10717
|
},
|
|
11300
10718
|
}, (e, v) => stateEntriesSequenceCodec.encode(e, Array.from(v.entries)), (d) => StateEntries.fromEntriesUnsafe(stateEntriesSequenceCodec.decode(d)), (s) => stateEntriesSequenceCodec.skip(s));
|
|
11301
10719
|
/** Turn in-memory state into it's serialized form. */
|
|
11302
|
-
static serializeInMemory(spec, state) {
|
|
11303
|
-
return new StateEntries(convertInMemoryStateToDictionary(spec, state));
|
|
10720
|
+
static serializeInMemory(spec, blake2b, state) {
|
|
10721
|
+
return new StateEntries(convertInMemoryStateToDictionary(spec, blake2b, state));
|
|
11304
10722
|
}
|
|
11305
10723
|
/**
|
|
11306
10724
|
* Wrap a collection of truncated state entries and treat it as state.
|
|
@@ -11349,7 +10767,8 @@ class StateEntries {
|
|
|
11349
10767
|
}
|
|
11350
10768
|
}
|
|
11351
10769
|
/** https://graypaper.fluffylabs.dev/#/68eaa1f/391600391600?v=0.6.4 */
|
|
11352
|
-
getRootHash() {
|
|
10770
|
+
getRootHash(blake2b) {
|
|
10771
|
+
const blake2bTrieHasher = getBlake2bTrieHasher(blake2b);
|
|
11353
10772
|
const leaves = SortedSet.fromArray(leafComparator);
|
|
11354
10773
|
for (const [key, value] of this) {
|
|
11355
10774
|
leaves.insert(InMemoryTrie.constructLeaf(blake2bTrieHasher, key.asOpaque(), value));
|
|
@@ -11358,7 +10777,7 @@ class StateEntries {
|
|
|
11358
10777
|
}
|
|
11359
10778
|
}
|
|
11360
10779
|
/** https://graypaper.fluffylabs.dev/#/68eaa1f/38a50038a500?v=0.6.4 */
|
|
11361
|
-
function convertInMemoryStateToDictionary(spec, state) {
|
|
10780
|
+
function convertInMemoryStateToDictionary(spec, blake2b, state) {
|
|
11362
10781
|
const serialized = TruncatedHashDictionary.fromEntries([]);
|
|
11363
10782
|
function doSerialize(codec) {
|
|
11364
10783
|
serialized.set(codec.key, Encoder.encodeObject(codec.Codec, codec.extract(state), spec));
|
|
@@ -11386,18 +10805,18 @@ function convertInMemoryStateToDictionary(spec, state) {
|
|
|
11386
10805
|
serialized.set(key, Encoder.encodeObject(Codec, service.getInfo()));
|
|
11387
10806
|
// preimages
|
|
11388
10807
|
for (const preimage of service.data.preimages.values()) {
|
|
11389
|
-
const { key, Codec } = serialize.servicePreimages(serviceId, preimage.hash);
|
|
10808
|
+
const { key, Codec } = serialize.servicePreimages(blake2b, serviceId, preimage.hash);
|
|
11390
10809
|
serialized.set(key, Encoder.encodeObject(Codec, preimage.blob));
|
|
11391
10810
|
}
|
|
11392
10811
|
// storage
|
|
11393
10812
|
for (const storage of service.data.storage.values()) {
|
|
11394
|
-
const { key, Codec } = serialize.serviceStorage(serviceId, storage.key);
|
|
10813
|
+
const { key, Codec } = serialize.serviceStorage(blake2b, serviceId, storage.key);
|
|
11395
10814
|
serialized.set(key, Encoder.encodeObject(Codec, storage.value));
|
|
11396
10815
|
}
|
|
11397
10816
|
// lookup history
|
|
11398
10817
|
for (const lookupHistoryList of service.data.lookupHistory.values()) {
|
|
11399
10818
|
for (const lookupHistory of lookupHistoryList) {
|
|
11400
|
-
const { key, Codec } = serialize.serviceLookupHistory(serviceId, lookupHistory.hash, lookupHistory.length);
|
|
10819
|
+
const { key, Codec } = serialize.serviceLookupHistory(blake2b, serviceId, lookupHistory.hash, lookupHistory.length);
|
|
11401
10820
|
serialized.set(key, Encoder.encodeObject(Codec, lookupHistory.slots.slice()));
|
|
11402
10821
|
}
|
|
11403
10822
|
}
|
|
@@ -11405,9 +10824,9 @@ function convertInMemoryStateToDictionary(spec, state) {
|
|
|
11405
10824
|
return serialized;
|
|
11406
10825
|
}
|
|
11407
10826
|
|
|
11408
|
-
function loadState(spec, entries) {
|
|
10827
|
+
function loadState(spec, blake2b, entries) {
|
|
11409
10828
|
const stateEntries = StateEntries.fromEntriesUnsafe(entries);
|
|
11410
|
-
return SerializedState.fromStateEntries(spec, stateEntries);
|
|
10829
|
+
return SerializedState.fromStateEntries(spec, blake2b, stateEntries);
|
|
11411
10830
|
}
|
|
11412
10831
|
|
|
11413
10832
|
/**
|
|
@@ -11515,7 +10934,8 @@ class LeafDb {
|
|
|
11515
10934
|
}
|
|
11516
10935
|
assertNever(val);
|
|
11517
10936
|
}
|
|
11518
|
-
getStateRoot() {
|
|
10937
|
+
getStateRoot(blake2b) {
|
|
10938
|
+
const blake2bTrieHasher = getBlake2bTrieHasher(blake2b);
|
|
11519
10939
|
return InMemoryTrie.computeStateRoot(blake2bTrieHasher, this.leaves).asOpaque();
|
|
11520
10940
|
}
|
|
11521
10941
|
intoStateEntries() {
|
|
@@ -11705,7 +11125,8 @@ class InMemoryStates {
|
|
|
11705
11125
|
}
|
|
11706
11126
|
}
|
|
11707
11127
|
async getStateRoot(state) {
|
|
11708
|
-
|
|
11128
|
+
const blake2b = await Blake2b.createHasher();
|
|
11129
|
+
return StateEntries.serializeInMemory(this.spec, blake2b, state).getRootHash(blake2b);
|
|
11709
11130
|
}
|
|
11710
11131
|
/** Insert a full state into the database. */
|
|
11711
11132
|
async insertState(headerHash, state) {
|
|
@@ -11783,7 +11204,7 @@ function padAndEncodeData(input) {
|
|
|
11783
11204
|
const paddedLength = Math.ceil(input.length / PIECE_SIZE) * PIECE_SIZE;
|
|
11784
11205
|
let padded = input;
|
|
11785
11206
|
if (input.length !== paddedLength) {
|
|
11786
|
-
padded = BytesBlob.blobFrom(
|
|
11207
|
+
padded = BytesBlob.blobFrom(safeAllocUint8Array(paddedLength));
|
|
11787
11208
|
padded.raw.set(input.raw, 0);
|
|
11788
11209
|
}
|
|
11789
11210
|
return chunkingFunction(padded);
|
|
@@ -11829,7 +11250,7 @@ function decodeData(input) {
|
|
|
11829
11250
|
*/
|
|
11830
11251
|
function encodePoints(input) {
|
|
11831
11252
|
const result = [];
|
|
11832
|
-
const data =
|
|
11253
|
+
const data = safeAllocUint8Array(POINT_ALIGNMENT * N_CHUNKS_REQUIRED);
|
|
11833
11254
|
// add original shards to the result
|
|
11834
11255
|
for (let i = 0; i < N_CHUNKS_REQUIRED; i++) {
|
|
11835
11256
|
const pointStart = POINT_LENGTH * i;
|
|
@@ -11845,7 +11266,7 @@ function encodePoints(input) {
|
|
|
11845
11266
|
const encodedData = encodedResult.take_data();
|
|
11846
11267
|
for (let i = 0; i < N_CHUNKS_REDUNDANCY; i++) {
|
|
11847
11268
|
const pointIndex = i * POINT_ALIGNMENT;
|
|
11848
|
-
const redundancyPoint =
|
|
11269
|
+
const redundancyPoint = safeAllocUint8Array(POINT_LENGTH);
|
|
11849
11270
|
for (let j = 0; j < POINT_LENGTH; j++) {
|
|
11850
11271
|
redundancyPoint[j] = encodedData[pointIndex + j * HALF_POINT_SIZE];
|
|
11851
11272
|
}
|
|
@@ -11860,7 +11281,7 @@ function encodePoints(input) {
|
|
|
11860
11281
|
*/
|
|
11861
11282
|
function decodePiece(input) {
|
|
11862
11283
|
const result = Bytes.zero(PIECE_SIZE);
|
|
11863
|
-
const data =
|
|
11284
|
+
const data = safeAllocUint8Array(N_CHUNKS_REQUIRED * POINT_ALIGNMENT);
|
|
11864
11285
|
const indices = new Uint16Array(input.length);
|
|
11865
11286
|
for (let i = 0; i < N_CHUNKS_REQUIRED; i++) {
|
|
11866
11287
|
const [index, points] = input[i];
|
|
@@ -11976,7 +11397,7 @@ function lace(input) {
|
|
|
11976
11397
|
return BytesBlob.empty();
|
|
11977
11398
|
}
|
|
11978
11399
|
const n = input[0].length;
|
|
11979
|
-
const result = BytesBlob.blobFrom(
|
|
11400
|
+
const result = BytesBlob.blobFrom(safeAllocUint8Array(k * n));
|
|
11980
11401
|
for (let i = 0; i < k; i++) {
|
|
11981
11402
|
const entry = input[i].raw;
|
|
11982
11403
|
for (let j = 0; j < n; j++) {
|
|
@@ -13255,7 +12676,7 @@ class Registers {
|
|
|
13255
12676
|
bytes;
|
|
13256
12677
|
asSigned;
|
|
13257
12678
|
asUnsigned;
|
|
13258
|
-
constructor(bytes =
|
|
12679
|
+
constructor(bytes = safeAllocUint8Array(NO_OF_REGISTERS$1 << REGISTER_SIZE_SHIFT)) {
|
|
13259
12680
|
this.bytes = bytes;
|
|
13260
12681
|
check `${bytes.length === NO_OF_REGISTERS$1 << REGISTER_SIZE_SHIFT} Invalid size of registers array.`;
|
|
13261
12682
|
this.asSigned = new BigInt64Array(bytes.buffer, bytes.byteOffset);
|
|
@@ -13327,10 +12748,16 @@ function signExtend32To64(value) {
|
|
|
13327
12748
|
|
|
13328
12749
|
/** Attempt to convert a number into `HostCallIndex`. */
|
|
13329
12750
|
const tryAsHostCallIndex = (v) => asOpaqueType(tryAsU32(v));
|
|
12751
|
+
/**
|
|
12752
|
+
* Host-call exit reason.
|
|
12753
|
+
*
|
|
12754
|
+
* https://graypaper.fluffylabs.dev/#/ab2cdbd/24a30124a501?v=0.7.2
|
|
12755
|
+
*/
|
|
13330
12756
|
var PvmExecution;
|
|
13331
12757
|
(function (PvmExecution) {
|
|
13332
12758
|
PvmExecution[PvmExecution["Halt"] = 0] = "Halt";
|
|
13333
12759
|
PvmExecution[PvmExecution["Panic"] = 1] = "Panic";
|
|
12760
|
+
PvmExecution[PvmExecution["OOG"] = 2] = "OOG";
|
|
13334
12761
|
})(PvmExecution || (PvmExecution = {}));
|
|
13335
12762
|
/** A utility function to easily trace a bunch of registers. */
|
|
13336
12763
|
function traceRegisters(...regs) {
|
|
@@ -13402,7 +12829,7 @@ class Mask {
|
|
|
13402
12829
|
return Math.min(this.lookupTableForward[index] ?? 0, MAX_INSTRUCTION_DISTANCE);
|
|
13403
12830
|
}
|
|
13404
12831
|
buildLookupTableForward(mask) {
|
|
13405
|
-
const table =
|
|
12832
|
+
const table = safeAllocUint8Array(mask.bitLength);
|
|
13406
12833
|
let lastInstructionOffset = 0;
|
|
13407
12834
|
for (let i = mask.bitLength - 1; i >= 0; i--) {
|
|
13408
12835
|
if (mask.isSet(i)) {
|
|
@@ -16937,7 +16364,7 @@ class HostCalls {
|
|
|
16937
16364
|
const regs = pvmInstance.getRegisters();
|
|
16938
16365
|
const maybeAddress = regs.getLowerU32(7);
|
|
16939
16366
|
const maybeLength = regs.getLowerU32(8);
|
|
16940
|
-
const result =
|
|
16367
|
+
const result = safeAllocUint8Array(maybeLength);
|
|
16941
16368
|
const startAddress = tryAsMemoryIndex(maybeAddress);
|
|
16942
16369
|
const loadResult = memory.loadInto(result, startAddress);
|
|
16943
16370
|
if (loadResult.isError) {
|
|
@@ -16965,8 +16392,9 @@ class HostCalls {
|
|
|
16965
16392
|
const index = tryAsHostCallIndex(hostCallIndex);
|
|
16966
16393
|
const hostCall = this.hostCalls.get(index);
|
|
16967
16394
|
const gasBefore = gas.get();
|
|
16968
|
-
|
|
16969
|
-
const
|
|
16395
|
+
// NOTE: `basicGasCost(regs)` function is for compatibility reasons: pre GP 0.7.2
|
|
16396
|
+
const basicGasCost = typeof hostCall.basicGasCost === "number" ? hostCall.basicGasCost : hostCall.basicGasCost(regs);
|
|
16397
|
+
const underflow = gas.sub(basicGasCost);
|
|
16970
16398
|
const pcLog = `[PC: ${pvmInstance.getPC()}]`;
|
|
16971
16399
|
if (underflow) {
|
|
16972
16400
|
this.hostCalls.traceHostCall(`${pcLog} OOG`, index, hostCall, regs, gas.get());
|
|
@@ -16983,6 +16411,10 @@ class HostCalls {
|
|
|
16983
16411
|
status = Status.PANIC;
|
|
16984
16412
|
return this.getReturnValue(status, pvmInstance);
|
|
16985
16413
|
}
|
|
16414
|
+
if (result === PvmExecution.OOG) {
|
|
16415
|
+
status = Status.OOG;
|
|
16416
|
+
return this.getReturnValue(status, pvmInstance);
|
|
16417
|
+
}
|
|
16986
16418
|
if (result === undefined) {
|
|
16987
16419
|
pvmInstance.runProgram();
|
|
16988
16420
|
status = pvmInstance.getStatus();
|
|
@@ -17281,14 +16713,14 @@ class DebuggerAdapter {
|
|
|
17281
16713
|
const page = this.pvm.getMemoryPage(pageNumber);
|
|
17282
16714
|
if (page === null) {
|
|
17283
16715
|
// page wasn't allocated so we return an empty page
|
|
17284
|
-
return
|
|
16716
|
+
return safeAllocUint8Array(PAGE_SIZE$1);
|
|
17285
16717
|
}
|
|
17286
16718
|
if (page.length === PAGE_SIZE$1) {
|
|
17287
16719
|
// page was allocated and has a proper size so we can simply return it
|
|
17288
16720
|
return page;
|
|
17289
16721
|
}
|
|
17290
16722
|
// page was allocated but it is shorter than PAGE_SIZE so we have to extend it
|
|
17291
|
-
const fullPage =
|
|
16723
|
+
const fullPage = safeAllocUint8Array(PAGE_SIZE$1);
|
|
17292
16724
|
fullPage.set(page);
|
|
17293
16725
|
return fullPage;
|
|
17294
16726
|
}
|
|
@@ -17392,7 +16824,7 @@ var index$3 = /*#__PURE__*/Object.freeze({
|
|
|
17392
16824
|
extractCodeAndMetadata: extractCodeAndMetadata,
|
|
17393
16825
|
getServiceId: getServiceId,
|
|
17394
16826
|
getServiceIdOrCurrent: getServiceIdOrCurrent,
|
|
17395
|
-
hash: index$
|
|
16827
|
+
hash: index$o,
|
|
17396
16828
|
inspect: inspect,
|
|
17397
16829
|
instructionArgumentTypeMap: instructionArgumentTypeMap,
|
|
17398
16830
|
interpreter: index$7,
|
|
@@ -17414,10 +16846,10 @@ const ENTROPY_BYTES = 32;
|
|
|
17414
16846
|
*
|
|
17415
16847
|
* https://graypaper.fluffylabs.dev/#/579bd12/3b9a013b9a01
|
|
17416
16848
|
*/
|
|
17417
|
-
function fisherYatesShuffle(arr, entropy) {
|
|
16849
|
+
function fisherYatesShuffle(blake2b, arr, entropy) {
|
|
17418
16850
|
check `${entropy.length === ENTROPY_BYTES} Expected entropy of length ${ENTROPY_BYTES}, got ${entropy.length}`;
|
|
17419
16851
|
const n = arr.length;
|
|
17420
|
-
const randomNumbers = hashToNumberSequence(entropy, arr.length);
|
|
16852
|
+
const randomNumbers = hashToNumberSequence(blake2b, entropy, arr.length);
|
|
17421
16853
|
const result = new Array(n);
|
|
17422
16854
|
let itemsLeft = n;
|
|
17423
16855
|
for (let i = 0; i < n; i++) {
|
|
@@ -17430,13 +16862,13 @@ function fisherYatesShuffle(arr, entropy) {
|
|
|
17430
16862
|
}
|
|
17431
16863
|
return result;
|
|
17432
16864
|
}
|
|
17433
|
-
function hashToNumberSequence(entropy, length) {
|
|
16865
|
+
function hashToNumberSequence(blake2b, entropy, length) {
|
|
17434
16866
|
const result = new Array(length);
|
|
17435
|
-
const randomBytes =
|
|
16867
|
+
const randomBytes = safeAllocUint8Array(ENTROPY_BYTES + 4);
|
|
17436
16868
|
randomBytes.set(entropy.raw);
|
|
17437
16869
|
for (let i = 0; i < length; i++) {
|
|
17438
16870
|
randomBytes.set(u32AsLeBytes(tryAsU32(Math.floor(i / 8))), ENTROPY_BYTES);
|
|
17439
|
-
const newHash = hashBytes(randomBytes);
|
|
16871
|
+
const newHash = blake2b.hashBytes(randomBytes);
|
|
17440
16872
|
const numberStartIndex = (4 * i) % 32;
|
|
17441
16873
|
const numberEndIndex = numberStartIndex + 4;
|
|
17442
16874
|
const number = leBytesAsU32(newHash.raw.subarray(numberStartIndex, numberEndIndex)) >>> 0;
|
|
@@ -17550,8 +16982,7 @@ const availabilityAssignmentFromJson = json.object({
|
|
|
17550
16982
|
report: workReportFromJson,
|
|
17551
16983
|
timeout: "number",
|
|
17552
16984
|
}, ({ report, timeout }) => {
|
|
17553
|
-
|
|
17554
|
-
return AvailabilityAssignment.create({ workReport: new WithHash(workReportHash, report), timeout });
|
|
16985
|
+
return AvailabilityAssignment.create({ workReport: report, timeout });
|
|
17555
16986
|
});
|
|
17556
16987
|
|
|
17557
16988
|
const disputesRecordsFromJson = json.object({
|
|
@@ -17857,11 +17288,11 @@ var index$1 = /*#__PURE__*/Object.freeze({
|
|
|
17857
17288
|
class TransitionHasher {
|
|
17858
17289
|
context;
|
|
17859
17290
|
keccakHasher;
|
|
17860
|
-
|
|
17861
|
-
constructor(context, keccakHasher,
|
|
17291
|
+
blake2b;
|
|
17292
|
+
constructor(context, keccakHasher, blake2b) {
|
|
17862
17293
|
this.context = context;
|
|
17863
17294
|
this.keccakHasher = keccakHasher;
|
|
17864
|
-
this.
|
|
17295
|
+
this.blake2b = blake2b;
|
|
17865
17296
|
}
|
|
17866
17297
|
/** Concatenates two hashes and hash this concatenation */
|
|
17867
17298
|
hashConcat(a, b) {
|
|
@@ -17872,7 +17303,7 @@ class TransitionHasher {
|
|
|
17872
17303
|
}
|
|
17873
17304
|
/** Creates hash from the block header view */
|
|
17874
17305
|
header(header) {
|
|
17875
|
-
return new WithHash(hashBytes(header.encoded()
|
|
17306
|
+
return new WithHash(this.blake2b.hashBytes(header.encoded()).asOpaque(), header);
|
|
17876
17307
|
}
|
|
17877
17308
|
/**
|
|
17878
17309
|
* Merkle commitment of the extrinsic data
|
|
@@ -17885,7 +17316,7 @@ class TransitionHasher {
|
|
|
17885
17316
|
.view()
|
|
17886
17317
|
.map((g) => g.view())
|
|
17887
17318
|
.map((guarantee) => {
|
|
17888
|
-
const reportHash = hashBytes(guarantee.report.encoded()
|
|
17319
|
+
const reportHash = this.blake2b.hashBytes(guarantee.report.encoded()).asOpaque();
|
|
17889
17320
|
return BytesBlob.blobFromParts([
|
|
17890
17321
|
reportHash.raw,
|
|
17891
17322
|
guarantee.slot.encoded().raw,
|
|
@@ -17893,13 +17324,13 @@ class TransitionHasher {
|
|
|
17893
17324
|
]);
|
|
17894
17325
|
});
|
|
17895
17326
|
const guaranteeBlob = Encoder.encodeObject(codec$1.sequenceVarLen(dumpCodec), guarantees, this.context);
|
|
17896
|
-
const et = hashBytes(extrinsicView.tickets.encoded()
|
|
17897
|
-
const ep = hashBytes(extrinsicView.preimages.encoded()
|
|
17898
|
-
const eg = hashBytes(guaranteeBlob
|
|
17899
|
-
const ea = hashBytes(extrinsicView.assurances.encoded()
|
|
17900
|
-
const ed = hashBytes(extrinsicView.disputes.encoded()
|
|
17327
|
+
const et = this.blake2b.hashBytes(extrinsicView.tickets.encoded()).asOpaque();
|
|
17328
|
+
const ep = this.blake2b.hashBytes(extrinsicView.preimages.encoded()).asOpaque();
|
|
17329
|
+
const eg = this.blake2b.hashBytes(guaranteeBlob).asOpaque();
|
|
17330
|
+
const ea = this.blake2b.hashBytes(extrinsicView.assurances.encoded()).asOpaque();
|
|
17331
|
+
const ed = this.blake2b.hashBytes(extrinsicView.disputes.encoded()).asOpaque();
|
|
17901
17332
|
const encoded = BytesBlob.blobFromParts([et.raw, ep.raw, eg.raw, ea.raw, ed.raw]);
|
|
17902
|
-
return new WithHashAndBytes(hashBytes(encoded
|
|
17333
|
+
return new WithHashAndBytes(this.blake2b.hashBytes(encoded).asOpaque(), extrinsicView, encoded);
|
|
17903
17334
|
}
|
|
17904
17335
|
/** Creates hash for given WorkPackage */
|
|
17905
17336
|
workPackage(workPackage) {
|
|
@@ -17908,7 +17339,7 @@ class TransitionHasher {
|
|
|
17908
17339
|
encode(codec, data) {
|
|
17909
17340
|
// TODO [ToDr] Use already allocated encoding destination and hash bytes from some arena.
|
|
17910
17341
|
const encoded = Encoder.encodeObject(codec, data, this.context);
|
|
17911
|
-
return new WithHashAndBytes(hashBytes(encoded
|
|
17342
|
+
return new WithHashAndBytes(this.blake2b.hashBytes(encoded).asOpaque(), data, encoded);
|
|
17912
17343
|
}
|
|
17913
17344
|
}
|
|
17914
17345
|
|
|
@@ -17921,8 +17352,10 @@ var PreimagesErrorCode;
|
|
|
17921
17352
|
// TODO [SeKo] consider whether this module is the right place to remove expired preimages
|
|
17922
17353
|
class Preimages {
|
|
17923
17354
|
state;
|
|
17924
|
-
|
|
17355
|
+
blake2b;
|
|
17356
|
+
constructor(state, blake2b) {
|
|
17925
17357
|
this.state = state;
|
|
17358
|
+
this.blake2b = blake2b;
|
|
17926
17359
|
}
|
|
17927
17360
|
integrate(input) {
|
|
17928
17361
|
// make sure lookup extrinsics are sorted and unique
|
|
@@ -17945,7 +17378,7 @@ class Preimages {
|
|
|
17945
17378
|
// select preimages for integration
|
|
17946
17379
|
for (const preimage of preimages) {
|
|
17947
17380
|
const { requester, blob } = preimage;
|
|
17948
|
-
const hash = hashBytes(blob).asOpaque();
|
|
17381
|
+
const hash = this.blake2b.hashBytes(blob).asOpaque();
|
|
17949
17382
|
const service = this.state.getService(requester);
|
|
17950
17383
|
if (service === null) {
|
|
17951
17384
|
return Result$1.error(PreimagesErrorCode.AccountNotFound);
|
|
@@ -17970,146 +17403,11 @@ class Preimages {
|
|
|
17970
17403
|
}
|
|
17971
17404
|
}
|
|
17972
17405
|
|
|
17973
|
-
class Missing {
|
|
17974
|
-
index = tryAsHostCallIndex(2 ** 32 - 1);
|
|
17975
|
-
gasCost = tryAsSmallGas(10);
|
|
17976
|
-
currentServiceId = CURRENT_SERVICE_ID;
|
|
17977
|
-
tracedRegisters = traceRegisters(7);
|
|
17978
|
-
execute(_gas, regs, _memory) {
|
|
17979
|
-
regs.set(7, HostCallResult.WHAT);
|
|
17980
|
-
return Promise.resolve(undefined);
|
|
17981
|
-
}
|
|
17982
|
-
}
|
|
17983
|
-
|
|
17984
|
-
var ServiceExecutorError;
|
|
17985
|
-
(function (ServiceExecutorError) {
|
|
17986
|
-
ServiceExecutorError[ServiceExecutorError["NoLookup"] = 0] = "NoLookup";
|
|
17987
|
-
ServiceExecutorError[ServiceExecutorError["NoState"] = 1] = "NoState";
|
|
17988
|
-
ServiceExecutorError[ServiceExecutorError["NoServiceCode"] = 2] = "NoServiceCode";
|
|
17989
|
-
ServiceExecutorError[ServiceExecutorError["ServiceCodeMismatch"] = 3] = "ServiceCodeMismatch";
|
|
17990
|
-
})(ServiceExecutorError || (ServiceExecutorError = {}));
|
|
17991
|
-
class WorkPackageExecutor {
|
|
17992
|
-
blocks;
|
|
17993
|
-
state;
|
|
17994
|
-
hasher;
|
|
17995
|
-
constructor(blocks, state, hasher) {
|
|
17996
|
-
this.blocks = blocks;
|
|
17997
|
-
this.state = state;
|
|
17998
|
-
this.hasher = hasher;
|
|
17999
|
-
}
|
|
18000
|
-
// TODO [ToDr] this while thing should be triple-checked with the GP.
|
|
18001
|
-
// I'm currently implementing some dirty version for the demo.
|
|
18002
|
-
async executeWorkPackage(pack) {
|
|
18003
|
-
const headerHash = pack.context.lookupAnchor;
|
|
18004
|
-
// execute authorisation first or is it already executed and we just need to check it?
|
|
18005
|
-
const authExec = this.getServiceExecutor(
|
|
18006
|
-
// TODO [ToDr] should this be anchor or lookupAnchor?
|
|
18007
|
-
headerHash, pack.authCodeHost, pack.authCodeHash);
|
|
18008
|
-
if (authExec.isError) {
|
|
18009
|
-
// TODO [ToDr] most likely shouldn't be throw.
|
|
18010
|
-
throw new Error(`Could not get authorization executor: ${authExec.error}`);
|
|
18011
|
-
}
|
|
18012
|
-
const pvm = authExec.ok;
|
|
18013
|
-
const authGas = tryAsGas(15000n);
|
|
18014
|
-
const result = await pvm.run(pack.parametrization, authGas);
|
|
18015
|
-
if (!result.isEqualTo(pack.authorization)) {
|
|
18016
|
-
throw new Error("Authorization is invalid.");
|
|
18017
|
-
}
|
|
18018
|
-
const results = [];
|
|
18019
|
-
for (const item of pack.items) {
|
|
18020
|
-
const exec = this.getServiceExecutor(headerHash, item.service, item.codeHash);
|
|
18021
|
-
if (exec.isError) {
|
|
18022
|
-
throw new Error(`Could not get item executor: ${exec.error}`);
|
|
18023
|
-
}
|
|
18024
|
-
const pvm = exec.ok;
|
|
18025
|
-
const gasRatio = tryAsServiceGas(3000n);
|
|
18026
|
-
const ret = await pvm.run(item.payload, tryAsGas(item.refineGasLimit)); // or accumulateGasLimit?
|
|
18027
|
-
results.push(WorkResult.create({
|
|
18028
|
-
serviceId: item.service,
|
|
18029
|
-
codeHash: item.codeHash,
|
|
18030
|
-
payloadHash: hashBytes(item.payload),
|
|
18031
|
-
gas: gasRatio,
|
|
18032
|
-
result: new WorkExecResult(WorkExecResultKind.ok, ret),
|
|
18033
|
-
load: WorkRefineLoad.create({
|
|
18034
|
-
gasUsed: tryAsServiceGas(5),
|
|
18035
|
-
importedSegments: tryAsU32(0),
|
|
18036
|
-
exportedSegments: tryAsU32(0),
|
|
18037
|
-
extrinsicSize: tryAsU32(0),
|
|
18038
|
-
extrinsicCount: tryAsU32(0),
|
|
18039
|
-
}),
|
|
18040
|
-
}));
|
|
18041
|
-
}
|
|
18042
|
-
const workPackage = this.hasher.workPackage(pack);
|
|
18043
|
-
const workPackageSpec = WorkPackageSpec.create({
|
|
18044
|
-
hash: workPackage.hash,
|
|
18045
|
-
length: tryAsU32(workPackage.encoded.length),
|
|
18046
|
-
erasureRoot: Bytes.zero(HASH_SIZE),
|
|
18047
|
-
exportsRoot: Bytes.zero(HASH_SIZE).asOpaque(),
|
|
18048
|
-
exportsCount: tryAsU16(0),
|
|
18049
|
-
});
|
|
18050
|
-
const coreIndex = tryAsCoreIndex(0);
|
|
18051
|
-
const authorizerHash = Bytes.fill(HASH_SIZE, 5).asOpaque();
|
|
18052
|
-
const workResults = FixedSizeArray.new(results, tryAsWorkItemsCount(results.length));
|
|
18053
|
-
return Promise.resolve(WorkReport.create({
|
|
18054
|
-
workPackageSpec,
|
|
18055
|
-
context: pack.context,
|
|
18056
|
-
coreIndex,
|
|
18057
|
-
authorizerHash,
|
|
18058
|
-
authorizationOutput: pack.authorization,
|
|
18059
|
-
segmentRootLookup: [],
|
|
18060
|
-
results: workResults,
|
|
18061
|
-
authorizationGasUsed: tryAsServiceGas(0),
|
|
18062
|
-
}));
|
|
18063
|
-
}
|
|
18064
|
-
getServiceExecutor(lookupAnchor, serviceId, expectedCodeHash) {
|
|
18065
|
-
const header = this.blocks.getHeader(lookupAnchor);
|
|
18066
|
-
if (header === null) {
|
|
18067
|
-
return Result$1.error(ServiceExecutorError.NoLookup);
|
|
18068
|
-
}
|
|
18069
|
-
const state = this.state.getState(lookupAnchor);
|
|
18070
|
-
if (state === null) {
|
|
18071
|
-
return Result$1.error(ServiceExecutorError.NoState);
|
|
18072
|
-
}
|
|
18073
|
-
const service = state.getService(serviceId);
|
|
18074
|
-
const serviceCodeHash = service?.getInfo().codeHash ?? null;
|
|
18075
|
-
if (serviceCodeHash === null) {
|
|
18076
|
-
return Result$1.error(ServiceExecutorError.NoServiceCode);
|
|
18077
|
-
}
|
|
18078
|
-
if (!serviceCodeHash.isEqualTo(expectedCodeHash)) {
|
|
18079
|
-
return Result$1.error(ServiceExecutorError.ServiceCodeMismatch);
|
|
18080
|
-
}
|
|
18081
|
-
const serviceCode = service?.getPreimage(serviceCodeHash.asOpaque()) ?? null;
|
|
18082
|
-
if (serviceCode === null) {
|
|
18083
|
-
return Result$1.error(ServiceExecutorError.NoServiceCode);
|
|
18084
|
-
}
|
|
18085
|
-
return Result$1.ok(new PvmExecutor(serviceCode));
|
|
18086
|
-
}
|
|
18087
|
-
}
|
|
18088
|
-
class PvmExecutor {
|
|
18089
|
-
serviceCode;
|
|
18090
|
-
pvm;
|
|
18091
|
-
hostCalls = new HostCallsManager({ missing: new Missing() });
|
|
18092
|
-
pvmInstanceManager = new InterpreterInstanceManager(4);
|
|
18093
|
-
constructor(serviceCode) {
|
|
18094
|
-
this.serviceCode = serviceCode;
|
|
18095
|
-
this.pvm = new HostCalls(this.pvmInstanceManager, this.hostCalls);
|
|
18096
|
-
}
|
|
18097
|
-
async run(args, gas) {
|
|
18098
|
-
const program = Program.fromSpi(this.serviceCode.raw, args.raw, true);
|
|
18099
|
-
const result = await this.pvm.runProgram(program.code, 5, gas, program.registers, program.memory);
|
|
18100
|
-
if (result.hasMemorySlice()) {
|
|
18101
|
-
return BytesBlob.blobFrom(result.memorySlice);
|
|
18102
|
-
}
|
|
18103
|
-
return BytesBlob.empty();
|
|
18104
|
-
}
|
|
18105
|
-
}
|
|
18106
|
-
|
|
18107
17406
|
var index = /*#__PURE__*/Object.freeze({
|
|
18108
17407
|
__proto__: null,
|
|
18109
17408
|
Preimages: Preimages,
|
|
18110
17409
|
get PreimagesErrorCode () { return PreimagesErrorCode; },
|
|
18111
|
-
TransitionHasher: TransitionHasher
|
|
18112
|
-
WorkPackageExecutor: WorkPackageExecutor
|
|
17410
|
+
TransitionHasher: TransitionHasher
|
|
18113
17411
|
});
|
|
18114
17412
|
|
|
18115
17413
|
exports.block = index$l;
|
|
@@ -18119,11 +17417,11 @@ exports.codec = index$q;
|
|
|
18119
17417
|
exports.collections = index$n;
|
|
18120
17418
|
exports.config = index$m;
|
|
18121
17419
|
exports.config_node = index$h;
|
|
18122
|
-
exports.crypto = index$
|
|
17420
|
+
exports.crypto = index$p;
|
|
18123
17421
|
exports.database = index$d;
|
|
18124
17422
|
exports.erasure_coding = index$c;
|
|
18125
17423
|
exports.fuzz_proto = index$a;
|
|
18126
|
-
exports.hash = index$
|
|
17424
|
+
exports.hash = index$o;
|
|
18127
17425
|
exports.jam_host_calls = index$9;
|
|
18128
17426
|
exports.json_parser = index$k;
|
|
18129
17427
|
exports.logger = index$i;
|