@xyo-network/payload-model 3.6.0-rc.4 → 3.6.0-rc.5

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.
Files changed (51) hide show
  1. package/dist/browser/Schema.d.ts +2 -2
  2. package/dist/browser/StorageMeta/Sequence.d.ts +59 -0
  3. package/dist/browser/StorageMeta/Sequence.d.ts.map +1 -0
  4. package/dist/browser/StorageMeta/SequenceParser.d.ts +23 -0
  5. package/dist/browser/StorageMeta/SequenceParser.d.ts.map +1 -0
  6. package/dist/browser/{StorageMeta.d.ts → StorageMeta/StorageMeta.d.ts} +4 -15
  7. package/dist/browser/StorageMeta/StorageMeta.d.ts.map +1 -0
  8. package/dist/browser/StorageMeta/index.d.ts +4 -0
  9. package/dist/browser/StorageMeta/index.d.ts.map +1 -0
  10. package/dist/browser/index.d.ts +1 -1
  11. package/dist/browser/index.d.ts.map +1 -1
  12. package/dist/browser/index.mjs +149 -17
  13. package/dist/browser/index.mjs.map +1 -1
  14. package/dist/browser/isPayload.d.ts +4 -4
  15. package/dist/neutral/Schema.d.ts +2 -2
  16. package/dist/neutral/StorageMeta/Sequence.d.ts +59 -0
  17. package/dist/neutral/StorageMeta/Sequence.d.ts.map +1 -0
  18. package/dist/neutral/StorageMeta/SequenceParser.d.ts +23 -0
  19. package/dist/neutral/StorageMeta/SequenceParser.d.ts.map +1 -0
  20. package/dist/{node → neutral/StorageMeta}/StorageMeta.d.ts +4 -15
  21. package/dist/neutral/StorageMeta/StorageMeta.d.ts.map +1 -0
  22. package/dist/neutral/StorageMeta/index.d.ts +4 -0
  23. package/dist/neutral/StorageMeta/index.d.ts.map +1 -0
  24. package/dist/neutral/index.d.ts +1 -1
  25. package/dist/neutral/index.d.ts.map +1 -1
  26. package/dist/neutral/index.mjs +149 -17
  27. package/dist/neutral/index.mjs.map +1 -1
  28. package/dist/neutral/isPayload.d.ts +4 -4
  29. package/dist/node/Schema.d.ts +2 -2
  30. package/dist/node/StorageMeta/Sequence.d.ts +59 -0
  31. package/dist/node/StorageMeta/Sequence.d.ts.map +1 -0
  32. package/dist/node/StorageMeta/SequenceParser.d.ts +23 -0
  33. package/dist/node/StorageMeta/SequenceParser.d.ts.map +1 -0
  34. package/dist/{neutral → node/StorageMeta}/StorageMeta.d.ts +4 -15
  35. package/dist/node/StorageMeta/StorageMeta.d.ts.map +1 -0
  36. package/dist/node/StorageMeta/index.d.ts +4 -0
  37. package/dist/node/StorageMeta/index.d.ts.map +1 -0
  38. package/dist/node/index.d.ts +1 -1
  39. package/dist/node/index.d.ts.map +1 -1
  40. package/dist/node/index.mjs +149 -17
  41. package/dist/node/index.mjs.map +1 -1
  42. package/dist/node/isPayload.d.ts +4 -4
  43. package/package.json +6 -4
  44. package/src/StorageMeta/Sequence.ts +72 -0
  45. package/src/StorageMeta/SequenceParser.ts +124 -0
  46. package/src/{StorageMeta.ts → StorageMeta/StorageMeta.ts} +4 -26
  47. package/src/StorageMeta/index.ts +3 -0
  48. package/src/index.ts +1 -1
  49. package/dist/browser/StorageMeta.d.ts.map +0 -1
  50. package/dist/neutral/StorageMeta.d.ts.map +0 -1
  51. package/dist/node/StorageMeta.d.ts.map +0 -1
@@ -41,28 +41,150 @@ var isSchema = (value) => {
41
41
  };
42
42
  var asSchema = AsTypeFactory.create(isSchema);
43
43
 
44
- // src/StorageMeta.ts
45
- import {
46
- isHash
47
- } from "@xylabs/hex";
48
- var StorageMetaComponentConstants = {
44
+ // src/StorageMeta/Sequence.ts
45
+ import { isHex } from "@xylabs/hex";
46
+ var isEpoch = (value) => {
47
+ return isHex(value) && value.length === SequenceConstants.epochBytes * 2;
48
+ };
49
+ var isNonce = (value) => {
50
+ return isHex(value) && value.length === SequenceConstants.nonceBytes * 2;
51
+ };
52
+ var isLocalSequence = (value) => {
53
+ return isHex(value) && value.length === SequenceConstants.localSequenceBytes * 2;
54
+ };
55
+ var isQualifiedSequence = (value) => {
56
+ return isHex(value) && value.length === SequenceConstants.qualifiedSequenceBytes * 2;
57
+ };
58
+ var isSequence = (value) => {
59
+ return isLocalSequence(value) || isQualifiedSequence(value);
60
+ };
61
+ var SequenceComponentLengths = {
49
62
  epochBytes: 8,
50
63
  nonceBytes: 8,
51
64
  addressBytes: 20
52
65
  };
53
- var StorageMetaLocalConstants = {
54
- maxEpoch: Math.pow(256, StorageMetaComponentConstants.epochBytes) - 1,
55
- localSequenceBytes: StorageMetaComponentConstants.epochBytes + StorageMetaComponentConstants.nonceBytes,
56
- minLocalSequence: "00000000000000000000000000000000",
57
- maxLocalSequence: "ffffffffffffffffffffffffffffffff",
58
- ...StorageMetaComponentConstants
66
+ var SequenceComponentMinMax = {
67
+ minEpoch: "0".repeat(SequenceComponentLengths.epochBytes),
68
+ maxEpoch: "f".repeat(SequenceComponentLengths.epochBytes),
69
+ minNonce: "0".repeat(SequenceComponentLengths.nonceBytes),
70
+ maxNonce: "f".repeat(SequenceComponentLengths.nonceBytes),
71
+ minAddress: "0".repeat(SequenceComponentLengths.addressBytes),
72
+ maxAddress: "f".repeat(SequenceComponentLengths.addressBytes)
73
+ };
74
+ var LocalSequenceConstants = {
75
+ ...SequenceComponentLengths,
76
+ ...SequenceComponentMinMax,
77
+ localSequenceBytes: SequenceComponentLengths.epochBytes + SequenceComponentLengths.nonceBytes,
78
+ minLocalSequence: SequenceComponentMinMax.minEpoch + SequenceComponentMinMax.minNonce,
79
+ maxLocalSequence: SequenceComponentMinMax.maxEpoch + SequenceComponentMinMax.maxNonce
80
+ };
81
+ var QualifiedSequenceConstants = {
82
+ qualifiedSequenceBytes: LocalSequenceConstants.localSequenceBytes + SequenceComponentLengths.addressBytes,
83
+ minLocalSequence: LocalSequenceConstants.minLocalSequence + SequenceComponentMinMax.minAddress,
84
+ maxLocalSequence: LocalSequenceConstants.maxLocalSequence + SequenceComponentMinMax.maxAddress
59
85
  };
60
- var StorageMetaConstants = {
61
- qualifiedSequenceBytes: StorageMetaLocalConstants.localSequenceBytes + StorageMetaComponentConstants.addressBytes,
62
- minSequence: `${StorageMetaLocalConstants}0000000000000000000000000000000000000000`,
63
- maxSequence: `${StorageMetaLocalConstants}ffffffffffffffffffffffffffffffffffffffff`,
64
- ...StorageMetaLocalConstants
86
+ var SequenceConstants = {
87
+ ...LocalSequenceConstants,
88
+ ...QualifiedSequenceConstants
89
+ };
90
+
91
+ // src/StorageMeta/SequenceParser.ts
92
+ import { toUint8Array } from "@xylabs/arraybuffer";
93
+ import { assertEx } from "@xylabs/assert";
94
+ import {
95
+ isAddress,
96
+ toHex
97
+ } from "@xylabs/hex";
98
+ var SequenceParser = class _SequenceParser {
99
+ static privateConstructorKey = Date.now().toString();
100
+ data;
101
+ constructor(privateConstructorKey, hex) {
102
+ assertEx(_SequenceParser.privateConstructorKey === privateConstructorKey, () => "Use create function instead of constructor");
103
+ const paddedHex = toHex(hex, {
104
+ prefix: false,
105
+ bitLength: hex.length <= SequenceConstants.localSequenceBytes * 2 ? SequenceConstants.localSequenceBytes * 8 : SequenceConstants.qualifiedSequenceBytes * 8
106
+ });
107
+ this.data = toUint8Array(paddedHex);
108
+ }
109
+ get address() {
110
+ const start = SequenceConstants.localSequenceBytes;
111
+ const end = SequenceConstants.qualifiedSequenceBytes;
112
+ return toHex(this.data.slice(start, end).buffer, { prefix: false });
113
+ }
114
+ get epoch() {
115
+ const start = 0;
116
+ const end = SequenceConstants.epochBytes;
117
+ return toHex(this.data.slice(start, end).buffer, { prefix: false });
118
+ }
119
+ get localSequence() {
120
+ const start = 0;
121
+ const end = SequenceConstants.localSequenceBytes;
122
+ return toHex(this.data.slice(start, end).buffer, { prefix: false });
123
+ }
124
+ get nonce() {
125
+ const start = SequenceConstants.epochBytes;
126
+ const end = SequenceConstants.localSequenceBytes;
127
+ return toHex(this.data.slice(start, end).buffer, { prefix: false });
128
+ }
129
+ get qualifiedSequence() {
130
+ const start = 0;
131
+ const end = SequenceConstants.qualifiedSequenceBytes;
132
+ return toHex(this.data.slice(start, end).buffer, { prefix: false });
133
+ }
134
+ static from(timestampOrSequence, nonceOrAddress, address) {
135
+ if (isSequence(timestampOrSequence)) {
136
+ if (nonceOrAddress) {
137
+ assertEx(!isQualifiedSequence(timestampOrSequence), () => "Providing both a qualified sequence and a address is not allowed");
138
+ assertEx(isAddress(nonceOrAddress), () => "Invalid address provided");
139
+ return new this(_SequenceParser.privateConstructorKey, timestampOrSequence + address);
140
+ }
141
+ return new this(_SequenceParser.privateConstructorKey, timestampOrSequence);
142
+ }
143
+ const epoch = _SequenceParser.toEpoch(timestampOrSequence);
144
+ const nonce = _SequenceParser.toNonce(nonceOrAddress);
145
+ const addressHex = address ? toHex(address, { bitLength: SequenceConstants.addressBytes * 8 }) : "";
146
+ const hexString = epoch + nonce + addressHex;
147
+ assertEx(isSequence(hexString), () => `Invalid sequence [${hexString}] [${epoch}, ${nonce}, ${addressHex}]`);
148
+ return new this(_SequenceParser.privateConstructorKey, hexString);
149
+ }
150
+ static parse(value) {
151
+ const hex = toHex(value);
152
+ if (isSequence(hex)) {
153
+ return new this(_SequenceParser.privateConstructorKey, hex);
154
+ }
155
+ throw new Error(`Invalid sequence [${value}]`);
156
+ }
157
+ // can convert a short number/hex to an epoch (treats it as the whole value) or extract an epoch from a sequence
158
+ static toEpoch(value) {
159
+ assertEx(
160
+ typeof value !== "number" || Number.isInteger(value),
161
+ () => "Value must be in integer"
162
+ );
163
+ const hex = toHex(value, { prefix: false });
164
+ if (hex.length <= SequenceConstants.epochBytes * 2) {
165
+ return toHex(value, { prefix: false, bitLength: SequenceConstants.epochBytes * 8 });
166
+ }
167
+ if (isSequence(hex)) {
168
+ return hex.slice(0, SequenceConstants.epochBytes * 2);
169
+ }
170
+ throw new Error(`Value could not be converted to epoch [${hex}]`);
171
+ }
172
+ // can convert a short number/hex to a nonce (treats it as the whole value) or extract an nonce from a sequence
173
+ static toNonce(value) {
174
+ assertEx(
175
+ typeof value !== "number" || Number.isInteger(value),
176
+ () => "Value must be in integer"
177
+ );
178
+ const hex = toHex(value, { prefix: false });
179
+ if (isSequence(hex)) {
180
+ return hex.slice(SequenceConstants.epochBytes * 2, SequenceConstants.localSequenceBytes * 2);
181
+ }
182
+ return toHex(hex.slice(-SequenceConstants.nonceBytes), { prefix: false, bitLength: SequenceConstants.nonceBytes * 8 });
183
+ }
65
184
  };
185
+
186
+ // src/StorageMeta/StorageMeta.ts
187
+ import { isHash } from "@xylabs/hex";
66
188
  var isSequenceMeta = (value) => {
67
189
  return value?._sequence !== void 0;
68
190
  };
@@ -73,20 +195,30 @@ var isStorageMeta = (value) => {
73
195
  return isSequenceMeta(value) && isHashMeta(value);
74
196
  };
75
197
  export {
198
+ LocalSequenceConstants,
76
199
  ModuleErrorSchema,
77
200
  PayloadSchema,
78
201
  PayloadSetSchema,
79
- StorageMetaConstants,
202
+ QualifiedSequenceConstants,
203
+ SequenceComponentLengths,
204
+ SequenceComponentMinMax,
205
+ SequenceConstants,
206
+ SequenceParser,
80
207
  asAnyPayload,
81
208
  asPayload,
82
209
  asSchema,
83
210
  isAnyPayload,
211
+ isEpoch,
84
212
  isHashMeta,
213
+ isLocalSequence,
85
214
  isModuleError,
215
+ isNonce,
86
216
  isPayload,
87
217
  isPayloadOfSchemaType,
88
218
  isPayloadOfSchemaTypeWithSources,
219
+ isQualifiedSequence,
89
220
  isSchema,
221
+ isSequence,
90
222
  isSequenceMeta,
91
223
  isStorageMeta,
92
224
  notPayloadOfSchemaType
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/isPayload.ts","../../src/isPayloadOfSchemaType.ts","../../src/Error.ts","../../src/PayloadSet/PayloadSetSchema.ts","../../src/Schema.ts","../../src/StorageMeta.ts"],"sourcesContent":["import { AsObjectFactory, isObject } from '@xylabs/object'\n\nimport type { Payload } from './Payload.ts'\n\nexport const isAnyPayload = (value: unknown): value is Payload => {\n if (isObject(value)) {\n return typeof value.schema === 'string'\n }\n return false\n}\n\nexport const asAnyPayload = AsObjectFactory.create(isAnyPayload)\n\nexport const isPayload\n = <T extends Payload>(schema: string[]) =>\n (value: unknown): value is T => {\n if (isAnyPayload(value)) {\n return schema.includes(value.schema)\n }\n return false\n }\n\nexport const asPayload = <T extends Payload>(schema: string[]) => AsObjectFactory.create((value: unknown): value is T => isPayload(schema)(value))\n","import { isAnyPayload } from './isPayload.ts'\nimport type { Payload, WithSources } from './Payload.ts'\n\nexport const isPayloadOfSchemaType = <T extends Payload>(schema: string) => {\n return (x?: unknown | null): x is T => isAnyPayload(x) && x?.schema === schema\n}\n\nexport const isPayloadOfSchemaTypeWithSources = <T extends Payload>(schema: string) => {\n return (x?: unknown | null): x is WithSources<T> =>\n isPayloadOfSchemaType<WithSources<T>>(schema)(x) && x.sources !== undefined && Array.isArray(x.sources)\n}\n\nexport const notPayloadOfSchemaType = <T extends Payload>(schema: string) => {\n return (x?: unknown | null): x is T => !isAnyPayload(x) || x?.schema !== schema\n}\n\n// test types -- keep for future validation, but comment out\n\n/*\ntype TestSchema = 'network.xyo.test'\nconst TestSchema: TestSchema = 'network.xyo.test'\n\ntype Test = Payload<{ field: string }, TestSchema>\n\nconst testPayload: Test = { field: 'test', schema: TestSchema }\n\nconst testPayloads: Payload[] = [testPayload]\n\nconst isTest: Test[] = testPayloads.filter(isPayloadOfSchemaType(TestSchema))\n\nconst isTestFromMetaTyped = testMetaPayloads.filter(isPayloadOfSchemaType<Test>(TestSchema))\n*/\n","import type { Hash } from '@xylabs/hex'\nimport type { JsonValue } from '@xylabs/object'\n\nimport { isPayloadOfSchemaType } from './isPayloadOfSchemaType.ts'\nimport type { Payload } from './Payload.ts'\n\nexport type ModuleErrorSchema = 'network.xyo.error.module'\nexport const ModuleErrorSchema: ModuleErrorSchema = 'network.xyo.error.module'\n\nexport type ModuleError = Payload<{\n details?: JsonValue\n message?: string\n name?: string\n query?: Hash\n schema: ModuleErrorSchema\n sources?: Hash[]\n}>\n\nexport const isModuleError = isPayloadOfSchemaType<ModuleError>(ModuleErrorSchema)\n","export type PayloadSetSchema = 'network.xyo.payload.set'\nexport const PayloadSetSchema: PayloadSetSchema = 'network.xyo.payload.set'\n","import type { EmptyObject } from '@xylabs/object'\nimport { AsTypeFactory } from '@xylabs/object'\n\n/** Schema type in Javascript is a string */\nexport type Schema = string\n\nexport const PayloadSchema = 'network.xyo.payload' as const\nexport type PayloadSchema = typeof PayloadSchema\n\nexport const isSchema = (value: unknown): value is Schema => {\n return typeof value === 'string'\n}\n\nexport const asSchema = AsTypeFactory.create<Schema>(isSchema)\n\n/** Schema fields for a Payload */\nexport interface SchemaFields extends EmptyObject {\n /** Schema of the object */\n schema: Schema\n}\n\n/** Add the Schema Fields to an object */\nexport type WithSchema<T extends EmptyObject | void = void> = T extends EmptyObject ? SchemaFields & T : SchemaFields\n","import {\n type Hash, type Hex, isHash,\n} from '@xylabs/hex'\n\nimport type { Payload } from './Payload.ts'\n\nexport interface SequenceMeta {\n _sequence: Hex\n}\n\nexport type WithPartialSequenceMeta<T extends Payload = Payload> = Partial<WithSequenceMeta<T>>\n\nexport type WithSequenceMeta<T extends Payload = Payload> = T & SequenceMeta\n\nexport interface HashMeta {\n _dataHash: Hash\n _hash: Hash\n}\n\nexport type WithPartialHashMeta<T extends Payload = Payload> = Partial<WithHashMeta<T>>\n\nexport type WithHashMeta<T extends Payload = Payload> = T & HashMeta\n\nexport interface StorageMeta extends SequenceMeta, HashMeta {}\n\nexport type WithPartialStorageMeta<T extends Payload = Payload> = Partial<WithStorageMeta<T>>\n\nexport type WithStorageMeta<T extends Payload = Payload> = T & StorageMeta\n\nconst StorageMetaComponentConstants = {\n epochBytes: 8,\n nonceBytes: 8,\n addressBytes: 20,\n}\n\nconst StorageMetaLocalConstants = {\n maxEpoch: Math.pow(256, StorageMetaComponentConstants.epochBytes) - 1,\n localSequenceBytes: StorageMetaComponentConstants.epochBytes + StorageMetaComponentConstants.nonceBytes,\n minLocalSequence: '00000000000000000000000000000000' as Hex,\n maxLocalSequence: 'ffffffffffffffffffffffffffffffff' as Hex,\n ...StorageMetaComponentConstants,\n}\n\nexport const StorageMetaConstants = {\n qualifiedSequenceBytes: StorageMetaLocalConstants.localSequenceBytes + StorageMetaComponentConstants.addressBytes,\n minSequence: `${StorageMetaLocalConstants}0000000000000000000000000000000000000000` as Hex,\n maxSequence: `${StorageMetaLocalConstants}ffffffffffffffffffffffffffffffffffffffff` as Hex,\n ...StorageMetaLocalConstants,\n}\n\nexport const isSequenceMeta = (value: unknown): value is SequenceMeta => {\n return (value as WithSequenceMeta)?._sequence !== undefined\n}\n\nexport const isHashMeta = (value: unknown): value is HashMeta => {\n return isHash((value as WithHashMeta)?._hash) && isHash((value as WithHashMeta)?._dataHash)\n}\n\nexport const isStorageMeta = (value: unknown): value is StorageMeta => {\n return isSequenceMeta(value) && isHashMeta(value)\n}\n\n// \"00005a7f354762f3ac1bc5ddc6cfd08d14\" is and example of a local sequence string\n\n// \"00005a7f354762f3ac1bc5ddc6cfd08d14a123456789abcdef0123\" is and example of a local sequence string\n// epoch = \"00005a7f354762f3ac\"\n// nonce = \"1bc5ddc6cfd08d14\"\n// address = \"a123456789abcdef0123\"\n"],"mappings":";AAAA,SAAS,iBAAiB,gBAAgB;AAInC,IAAM,eAAe,CAAC,UAAqC;AAChE,MAAI,SAAS,KAAK,GAAG;AACnB,WAAO,OAAO,MAAM,WAAW;AAAA,EACjC;AACA,SAAO;AACT;AAEO,IAAM,eAAe,gBAAgB,OAAO,YAAY;AAExD,IAAM,YACT,CAAoB,WACpB,CAAC,UAA+B;AAC9B,MAAI,aAAa,KAAK,GAAG;AACvB,WAAO,OAAO,SAAS,MAAM,MAAM;AAAA,EACrC;AACA,SAAO;AACT;AAEG,IAAM,YAAY,CAAoB,WAAqB,gBAAgB,OAAO,CAAC,UAA+B,UAAU,MAAM,EAAE,KAAK,CAAC;;;ACnB1I,IAAM,wBAAwB,CAAoB,WAAmB;AAC1E,SAAO,CAAC,MAA+B,aAAa,CAAC,KAAK,GAAG,WAAW;AAC1E;AAEO,IAAM,mCAAmC,CAAoB,WAAmB;AACrF,SAAO,CAAC,MACN,sBAAsC,MAAM,EAAE,CAAC,KAAK,EAAE,YAAY,UAAa,MAAM,QAAQ,EAAE,OAAO;AAC1G;AAEO,IAAM,yBAAyB,CAAoB,WAAmB;AAC3E,SAAO,CAAC,MAA+B,CAAC,aAAa,CAAC,KAAK,GAAG,WAAW;AAC3E;;;ACPO,IAAM,oBAAuC;AAW7C,IAAM,gBAAgB,sBAAmC,iBAAiB;;;ACjB1E,IAAM,mBAAqC;;;ACAlD,SAAS,qBAAqB;AAKvB,IAAM,gBAAgB;AAGtB,IAAM,WAAW,CAAC,UAAoC;AAC3D,SAAO,OAAO,UAAU;AAC1B;AAEO,IAAM,WAAW,cAAc,OAAe,QAAQ;;;ACb7D;AAAA,EACuB;AAAA,OAChB;AA2BP,IAAM,gCAAgC;AAAA,EACpC,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,cAAc;AAChB;AAEA,IAAM,4BAA4B;AAAA,EAChC,UAAU,KAAK,IAAI,KAAK,8BAA8B,UAAU,IAAI;AAAA,EACpE,oBAAoB,8BAA8B,aAAa,8BAA8B;AAAA,EAC7F,kBAAkB;AAAA,EAClB,kBAAkB;AAAA,EAClB,GAAG;AACL;AAEO,IAAM,uBAAuB;AAAA,EAClC,wBAAwB,0BAA0B,qBAAqB,8BAA8B;AAAA,EACrG,aAAa,GAAG,yBAAyB;AAAA,EACzC,aAAa,GAAG,yBAAyB;AAAA,EACzC,GAAG;AACL;AAEO,IAAM,iBAAiB,CAAC,UAA0C;AACvE,SAAQ,OAA4B,cAAc;AACpD;AAEO,IAAM,aAAa,CAAC,UAAsC;AAC/D,SAAO,OAAQ,OAAwB,KAAK,KAAK,OAAQ,OAAwB,SAAS;AAC5F;AAEO,IAAM,gBAAgB,CAAC,UAAyC;AACrE,SAAO,eAAe,KAAK,KAAK,WAAW,KAAK;AAClD;","names":[]}
1
+ {"version":3,"sources":["../../src/isPayload.ts","../../src/isPayloadOfSchemaType.ts","../../src/Error.ts","../../src/PayloadSet/PayloadSetSchema.ts","../../src/Schema.ts","../../src/StorageMeta/Sequence.ts","../../src/StorageMeta/SequenceParser.ts","../../src/StorageMeta/StorageMeta.ts"],"sourcesContent":["import { AsObjectFactory, isObject } from '@xylabs/object'\n\nimport type { Payload } from './Payload.ts'\n\nexport const isAnyPayload = (value: unknown): value is Payload => {\n if (isObject(value)) {\n return typeof value.schema === 'string'\n }\n return false\n}\n\nexport const asAnyPayload = AsObjectFactory.create(isAnyPayload)\n\nexport const isPayload\n = <T extends Payload>(schema: string[]) =>\n (value: unknown): value is T => {\n if (isAnyPayload(value)) {\n return schema.includes(value.schema)\n }\n return false\n }\n\nexport const asPayload = <T extends Payload>(schema: string[]) => AsObjectFactory.create((value: unknown): value is T => isPayload(schema)(value))\n","import { isAnyPayload } from './isPayload.ts'\nimport type { Payload, WithSources } from './Payload.ts'\n\nexport const isPayloadOfSchemaType = <T extends Payload>(schema: string) => {\n return (x?: unknown | null): x is T => isAnyPayload(x) && x?.schema === schema\n}\n\nexport const isPayloadOfSchemaTypeWithSources = <T extends Payload>(schema: string) => {\n return (x?: unknown | null): x is WithSources<T> =>\n isPayloadOfSchemaType<WithSources<T>>(schema)(x) && x.sources !== undefined && Array.isArray(x.sources)\n}\n\nexport const notPayloadOfSchemaType = <T extends Payload>(schema: string) => {\n return (x?: unknown | null): x is T => !isAnyPayload(x) || x?.schema !== schema\n}\n\n// test types -- keep for future validation, but comment out\n\n/*\ntype TestSchema = 'network.xyo.test'\nconst TestSchema: TestSchema = 'network.xyo.test'\n\ntype Test = Payload<{ field: string }, TestSchema>\n\nconst testPayload: Test = { field: 'test', schema: TestSchema }\n\nconst testPayloads: Payload[] = [testPayload]\n\nconst isTest: Test[] = testPayloads.filter(isPayloadOfSchemaType(TestSchema))\n\nconst isTestFromMetaTyped = testMetaPayloads.filter(isPayloadOfSchemaType<Test>(TestSchema))\n*/\n","import type { Hash } from '@xylabs/hex'\nimport type { JsonValue } from '@xylabs/object'\n\nimport { isPayloadOfSchemaType } from './isPayloadOfSchemaType.ts'\nimport type { Payload } from './Payload.ts'\n\nexport type ModuleErrorSchema = 'network.xyo.error.module'\nexport const ModuleErrorSchema: ModuleErrorSchema = 'network.xyo.error.module'\n\nexport type ModuleError = Payload<{\n details?: JsonValue\n message?: string\n name?: string\n query?: Hash\n schema: ModuleErrorSchema\n sources?: Hash[]\n}>\n\nexport const isModuleError = isPayloadOfSchemaType<ModuleError>(ModuleErrorSchema)\n","export type PayloadSetSchema = 'network.xyo.payload.set'\nexport const PayloadSetSchema: PayloadSetSchema = 'network.xyo.payload.set'\n","import type { EmptyObject } from '@xylabs/object'\nimport { AsTypeFactory } from '@xylabs/object'\n\n/** Schema type in Javascript is a string */\nexport type Schema = string\n\nexport const PayloadSchema = 'network.xyo.payload' as const\nexport type PayloadSchema = typeof PayloadSchema\n\nexport const isSchema = (value: unknown): value is Schema => {\n return typeof value === 'string'\n}\n\nexport const asSchema = AsTypeFactory.create<Schema>(isSchema)\n\n/** Schema fields for a Payload */\nexport interface SchemaFields extends EmptyObject {\n /** Schema of the object */\n schema: Schema\n}\n\n/** Add the Schema Fields to an object */\nexport type WithSchema<T extends EmptyObject | void = void> = T extends EmptyObject ? SchemaFields & T : SchemaFields\n","import type { Address, Hex } from '@xylabs/hex'\nimport { isHex } from '@xylabs/hex'\n\n// we use Exclude to intentionally make the type not equal to string\nexport type LocalSequence = Hex & Exclude<string, 'reserved-local-sequence-value'>\nexport type QualifiedSequence = Hex & Exclude<string, 'reserved-qualified-sequence-value'>\nexport type Sequence = LocalSequence | QualifiedSequence\n\nexport type Epoch = Hex & Exclude<string, 'reserved-epoch-sequence-value'>\n\nexport const isEpoch = (value: unknown): value is Epoch => {\n return isHex(value) && (value as string).length === SequenceConstants.epochBytes * 2\n}\n\nexport type Nonce = Hex & Exclude<string, 'reserved-nonce-sequence-value'>\n\nexport const isNonce = (value: unknown): value is Epoch => {\n return isHex(value) && (value as string).length === SequenceConstants.nonceBytes * 2\n}\n\nexport const isLocalSequence = (value: unknown): value is Sequence => {\n return isHex(value) && (value as string).length === (SequenceConstants.localSequenceBytes) * 2\n}\n\nexport const isQualifiedSequence = (value: unknown): value is Sequence => {\n return isHex(value) && (value as string).length === (SequenceConstants.qualifiedSequenceBytes) * 2\n}\n\nexport const isSequence = (value: unknown): value is Sequence => {\n return isLocalSequence(value) || isQualifiedSequence(value)\n}\n\nexport const SequenceComponentLengths = {\n epochBytes: 8,\n nonceBytes: 8,\n addressBytes: 20,\n}\n\nexport const SequenceComponentMinMax = {\n minEpoch: '0'.repeat(SequenceComponentLengths.epochBytes) as Epoch,\n maxEpoch: 'f'.repeat(SequenceComponentLengths.epochBytes) as Epoch,\n minNonce: '0'.repeat(SequenceComponentLengths.nonceBytes) as Nonce,\n maxNonce: 'f'.repeat(SequenceComponentLengths.nonceBytes) as Nonce,\n minAddress: '0'.repeat(SequenceComponentLengths.addressBytes) as Address,\n maxAddress: 'f'.repeat(SequenceComponentLengths.addressBytes) as Address,\n}\n\nexport const LocalSequenceConstants = {\n ...SequenceComponentLengths,\n ...SequenceComponentMinMax,\n localSequenceBytes: SequenceComponentLengths.epochBytes + SequenceComponentLengths.nonceBytes,\n minLocalSequence: SequenceComponentMinMax.minEpoch + SequenceComponentMinMax.minNonce as LocalSequence,\n maxLocalSequence: SequenceComponentMinMax.maxEpoch + SequenceComponentMinMax.maxNonce as LocalSequence,\n}\n\nexport const QualifiedSequenceConstants = {\n qualifiedSequenceBytes: LocalSequenceConstants.localSequenceBytes + SequenceComponentLengths.addressBytes,\n minLocalSequence: LocalSequenceConstants.minLocalSequence + SequenceComponentMinMax.minAddress as QualifiedSequence,\n maxLocalSequence: LocalSequenceConstants.maxLocalSequence + SequenceComponentMinMax.maxAddress as QualifiedSequence,\n}\n\nexport const SequenceConstants = {\n ...LocalSequenceConstants,\n ...QualifiedSequenceConstants,\n}\n\n// \"11111111111111112222222222222222\" is and example of a local sequence string\n\n// \"111111111111111122222222222222223333333333333333333333333333333333333333\" is and example of a local sequence string\n// epoch = \"1111111111111111\"\n// nonce = \"2222222222222222\"\n// address = \"3333333333333333333333333333333333333333\"\n","import { toUint8Array } from '@xylabs/arraybuffer'\nimport { assertEx } from '@xylabs/assert'\nimport {\n type Address,\n type Hash, type Hex,\n isAddress,\n toHex,\n} from '@xylabs/hex'\n\nimport type {\n Epoch, LocalSequence, Nonce, QualifiedSequence,\n Sequence,\n} from './Sequence.ts'\nimport {\n isQualifiedSequence, isSequence, SequenceConstants,\n} from './Sequence.ts'\n\nexport class SequenceParser {\n protected static privateConstructorKey = Date.now().toString()\n\n private readonly data: Readonly<Uint8Array>\n\n protected constructor(privateConstructorKey: string, hex: Hex) {\n assertEx(SequenceParser.privateConstructorKey === privateConstructorKey, () => 'Use create function instead of constructor')\n const paddedHex = toHex(hex, {\n prefix: false,\n bitLength: (hex.length <= SequenceConstants.localSequenceBytes * 2)\n ? SequenceConstants.localSequenceBytes * 8\n : SequenceConstants.qualifiedSequenceBytes * 8,\n })\n this.data = toUint8Array(paddedHex)\n }\n\n get address(): Address {\n const start = SequenceConstants.localSequenceBytes\n const end = SequenceConstants.qualifiedSequenceBytes\n return toHex(this.data.slice(start, end).buffer, { prefix: false })\n }\n\n get epoch(): Epoch {\n const start = 0\n const end = SequenceConstants.epochBytes\n return toHex(this.data.slice(start, end).buffer, { prefix: false })\n }\n\n get localSequence(): LocalSequence {\n const start = 0\n const end = SequenceConstants.localSequenceBytes\n return toHex(this.data.slice(start, end).buffer, { prefix: false })\n }\n\n get nonce(): Nonce {\n const start = SequenceConstants.epochBytes\n const end = SequenceConstants.localSequenceBytes\n return toHex(this.data.slice(start, end).buffer, { prefix: false })\n }\n\n get qualifiedSequence(): QualifiedSequence {\n const start = 0\n const end = SequenceConstants.qualifiedSequenceBytes\n return toHex(this.data.slice(start, end).buffer, { prefix: false })\n }\n\n static from(sequence: Sequence, address?: Address): SequenceParser\n static from(timestamp: Hex, hash: Hash, address?: Address): SequenceParser\n static from(timestamp: Hex, hash: Hex, address?: Address): SequenceParser\n static from(timestamp: Hex, nonce: Nonce, address?: Address): SequenceParser\n static from(timestamp: number, hash: Hash, address?: Address): SequenceParser\n static from(timestamp: number, hash: Hex, address?: Address): SequenceParser\n static from(timestamp: number, nonce: Nonce, address?: Address): SequenceParser\n static from(timestampOrSequence: Sequence | Hex | number, nonceOrAddress: Hash | Nonce, address?: Address): SequenceParser {\n if (isSequence(timestampOrSequence)) {\n if (nonceOrAddress) {\n assertEx(!isQualifiedSequence(timestampOrSequence), () => 'Providing both a qualified sequence and a address is not allowed')\n assertEx(isAddress(nonceOrAddress), () => 'Invalid address provided')\n return new this(SequenceParser.privateConstructorKey, (timestampOrSequence + address) as Hex)\n }\n return new this(SequenceParser.privateConstructorKey, timestampOrSequence)\n }\n const epoch = SequenceParser.toEpoch(timestampOrSequence)\n const nonce = SequenceParser.toNonce(nonceOrAddress)\n const addressHex: Hex = address ? toHex(address, { bitLength: SequenceConstants.addressBytes * 8 }) : '' as Hex\n const hexString = (epoch + nonce + addressHex) as Hex\n assertEx(isSequence(hexString), () => `Invalid sequence [${hexString}] [${epoch}, ${nonce}, ${addressHex}]`)\n return new this(SequenceParser.privateConstructorKey, hexString)\n }\n\n static parse(value: Hex | string | ArrayBufferLike): SequenceParser {\n const hex = toHex(value)\n if (isSequence(hex)) {\n return new this(SequenceParser.privateConstructorKey, hex)\n }\n throw new Error(`Invalid sequence [${value}]`)\n }\n\n // can convert a short number/hex to an epoch (treats it as the whole value) or extract an epoch from a sequence\n static toEpoch(value: number | Hex | Epoch): Epoch {\n assertEx(\n typeof value !== 'number' || Number.isInteger(value),\n () => 'Value must be in integer',\n )\n const hex = toHex(value, { prefix: false })\n if (hex.length <= SequenceConstants.epochBytes * 2) {\n return toHex(value, { prefix: false, bitLength: SequenceConstants.epochBytes * 8 }) as Epoch\n }\n if (isSequence(hex)) {\n return hex.slice(0, SequenceConstants.epochBytes * 2) as Epoch\n }\n throw new Error(`Value could not be converted to epoch [${hex}]`)\n }\n\n // can convert a short number/hex to a nonce (treats it as the whole value) or extract an nonce from a sequence\n static toNonce(value: Hash | Hex): Nonce {\n assertEx(\n typeof value !== 'number' || Number.isInteger(value),\n () => 'Value must be in integer',\n )\n const hex = toHex(value, { prefix: false })\n if (isSequence(hex)) {\n return hex.slice(SequenceConstants.epochBytes * 2, SequenceConstants.localSequenceBytes * 2) as Nonce\n }\n return toHex((hex as string).slice(-SequenceConstants.nonceBytes), { prefix: false, bitLength: SequenceConstants.nonceBytes * 8 }) as Nonce\n }\n}\n","import { type Hash, isHash } from '@xylabs/hex'\n\nimport type { Payload } from '../Payload.ts'\nimport type { Sequence } from './Sequence.ts'\n\nexport interface SequenceMeta {\n _sequence: Sequence\n}\n\nexport type WithPartialSequenceMeta<T extends Payload = Payload> = Partial<WithSequenceMeta<T>>\n\nexport type WithSequenceMeta<T extends Payload = Payload> = T & SequenceMeta\n\nexport interface HashMeta {\n _dataHash: Hash\n _hash: Hash\n}\n\nexport type WithPartialHashMeta<T extends Payload = Payload> = Partial<WithHashMeta<T>>\n\nexport type WithHashMeta<T extends Payload = Payload> = T & HashMeta\n\nexport interface StorageMeta extends SequenceMeta, HashMeta {}\n\nexport type WithPartialStorageMeta<T extends Payload = Payload> = Partial<WithStorageMeta<T>>\n\nexport type WithStorageMeta<T extends Payload = Payload> = T & StorageMeta\n\nexport const isSequenceMeta = (value: unknown): value is SequenceMeta => {\n return (value as WithSequenceMeta)?._sequence !== undefined\n}\n\nexport const isHashMeta = (value: unknown): value is HashMeta => {\n return isHash((value as WithHashMeta)?._hash) && isHash((value as WithHashMeta)?._dataHash)\n}\n\nexport const isStorageMeta = (value: unknown): value is StorageMeta => {\n return isSequenceMeta(value) && isHashMeta(value)\n}\n\n// \"00005a7f354762f3ac1bc5ddc6cfd08d14\" is and example of a local sequence string\n\n// \"00005a7f354762f3ac1bc5ddc6cfd08d14a123456789abcdef0123\" is and example of a local sequence string\n// epoch = \"00005a7f354762f3ac\"\n// nonce = \"1bc5ddc6cfd08d14\"\n// address = \"a123456789abcdef0123\"\n"],"mappings":"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","names":[]}
@@ -3,16 +3,16 @@ export declare const isAnyPayload: (value: unknown) => value is Payload;
3
3
  export declare const asAnyPayload: {
4
4
  <TType extends {
5
5
  schema: string;
6
- } & import("./Payload.ts").PayloadFields>(value: import(".store/@xylabs-promise-npm-4.4.13-f119ea3c1f/package").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig): TType | undefined;
6
+ } & import("./Payload.ts").PayloadFields>(value: import(".store/@xylabs-promise-npm-4.4.14-a00a2a7e8e/package").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig): TType | undefined;
7
7
  <TType extends {
8
8
  schema: string;
9
- } & import("./Payload.ts").PayloadFields>(value: import(".store/@xylabs-promise-npm-4.4.13-f119ea3c1f/package").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<{
9
+ } & import("./Payload.ts").PayloadFields>(value: import(".store/@xylabs-promise-npm-4.4.14-a00a2a7e8e/package").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<{
10
10
  schema: string;
11
11
  } & import("./Payload.ts").PayloadFields>, config?: import("@xylabs/object").TypeCheckConfig): TType;
12
12
  };
13
13
  export declare const isPayload: <T extends Payload>(schema: string[]) => (value: unknown) => value is T;
14
14
  export declare const asPayload: <T extends Payload>(schema: string[]) => {
15
- <TType extends T>(value: import(".store/@xylabs-promise-npm-4.4.13-f119ea3c1f/package").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig): TType | undefined;
16
- <TType extends T>(value: import(".store/@xylabs-promise-npm-4.4.13-f119ea3c1f/package").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<T>, config?: import("@xylabs/object").TypeCheckConfig): TType;
15
+ <TType extends T>(value: import(".store/@xylabs-promise-npm-4.4.14-a00a2a7e8e/package").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig): TType | undefined;
16
+ <TType extends T>(value: import(".store/@xylabs-promise-npm-4.4.14-a00a2a7e8e/package").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<T>, config?: import("@xylabs/object").TypeCheckConfig): TType;
17
17
  };
18
18
  //# sourceMappingURL=isPayload.d.ts.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/payload-model",
3
- "version": "3.6.0-rc.4",
3
+ "version": "3.6.0-rc.5",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -37,13 +37,15 @@
37
37
  "module": "dist/neutral/index.mjs",
38
38
  "types": "dist/neutral/index.d.ts",
39
39
  "dependencies": {
40
- "@xylabs/hex": "^4.4.13",
41
- "@xylabs/object": "^4.4.13"
40
+ "@xylabs/arraybuffer": "^4.4.14",
41
+ "@xylabs/assert": "^4.4.14",
42
+ "@xylabs/hex": "^4.4.14",
43
+ "@xylabs/object": "^4.4.14"
42
44
  },
43
45
  "devDependencies": {
44
46
  "@xylabs/ts-scripts-yarn3": "^4.2.4",
45
47
  "@xylabs/tsconfig": "^4.2.4",
46
- "@xylabs/vitest-extended": "^4.4.13",
48
+ "@xylabs/vitest-extended": "^4.4.14",
47
49
  "typescript": "^5.7.2",
48
50
  "vitest": "^2.1.8"
49
51
  },
@@ -0,0 +1,72 @@
1
+ import type { Address, Hex } from '@xylabs/hex'
2
+ import { isHex } from '@xylabs/hex'
3
+
4
+ // we use Exclude to intentionally make the type not equal to string
5
+ export type LocalSequence = Hex & Exclude<string, 'reserved-local-sequence-value'>
6
+ export type QualifiedSequence = Hex & Exclude<string, 'reserved-qualified-sequence-value'>
7
+ export type Sequence = LocalSequence | QualifiedSequence
8
+
9
+ export type Epoch = Hex & Exclude<string, 'reserved-epoch-sequence-value'>
10
+
11
+ export const isEpoch = (value: unknown): value is Epoch => {
12
+ return isHex(value) && (value as string).length === SequenceConstants.epochBytes * 2
13
+ }
14
+
15
+ export type Nonce = Hex & Exclude<string, 'reserved-nonce-sequence-value'>
16
+
17
+ export const isNonce = (value: unknown): value is Epoch => {
18
+ return isHex(value) && (value as string).length === SequenceConstants.nonceBytes * 2
19
+ }
20
+
21
+ export const isLocalSequence = (value: unknown): value is Sequence => {
22
+ return isHex(value) && (value as string).length === (SequenceConstants.localSequenceBytes) * 2
23
+ }
24
+
25
+ export const isQualifiedSequence = (value: unknown): value is Sequence => {
26
+ return isHex(value) && (value as string).length === (SequenceConstants.qualifiedSequenceBytes) * 2
27
+ }
28
+
29
+ export const isSequence = (value: unknown): value is Sequence => {
30
+ return isLocalSequence(value) || isQualifiedSequence(value)
31
+ }
32
+
33
+ export const SequenceComponentLengths = {
34
+ epochBytes: 8,
35
+ nonceBytes: 8,
36
+ addressBytes: 20,
37
+ }
38
+
39
+ export const SequenceComponentMinMax = {
40
+ minEpoch: '0'.repeat(SequenceComponentLengths.epochBytes) as Epoch,
41
+ maxEpoch: 'f'.repeat(SequenceComponentLengths.epochBytes) as Epoch,
42
+ minNonce: '0'.repeat(SequenceComponentLengths.nonceBytes) as Nonce,
43
+ maxNonce: 'f'.repeat(SequenceComponentLengths.nonceBytes) as Nonce,
44
+ minAddress: '0'.repeat(SequenceComponentLengths.addressBytes) as Address,
45
+ maxAddress: 'f'.repeat(SequenceComponentLengths.addressBytes) as Address,
46
+ }
47
+
48
+ export const LocalSequenceConstants = {
49
+ ...SequenceComponentLengths,
50
+ ...SequenceComponentMinMax,
51
+ localSequenceBytes: SequenceComponentLengths.epochBytes + SequenceComponentLengths.nonceBytes,
52
+ minLocalSequence: SequenceComponentMinMax.minEpoch + SequenceComponentMinMax.minNonce as LocalSequence,
53
+ maxLocalSequence: SequenceComponentMinMax.maxEpoch + SequenceComponentMinMax.maxNonce as LocalSequence,
54
+ }
55
+
56
+ export const QualifiedSequenceConstants = {
57
+ qualifiedSequenceBytes: LocalSequenceConstants.localSequenceBytes + SequenceComponentLengths.addressBytes,
58
+ minLocalSequence: LocalSequenceConstants.minLocalSequence + SequenceComponentMinMax.minAddress as QualifiedSequence,
59
+ maxLocalSequence: LocalSequenceConstants.maxLocalSequence + SequenceComponentMinMax.maxAddress as QualifiedSequence,
60
+ }
61
+
62
+ export const SequenceConstants = {
63
+ ...LocalSequenceConstants,
64
+ ...QualifiedSequenceConstants,
65
+ }
66
+
67
+ // "11111111111111112222222222222222" is and example of a local sequence string
68
+
69
+ // "111111111111111122222222222222223333333333333333333333333333333333333333" is and example of a local sequence string
70
+ // epoch = "1111111111111111"
71
+ // nonce = "2222222222222222"
72
+ // address = "3333333333333333333333333333333333333333"
@@ -0,0 +1,124 @@
1
+ import { toUint8Array } from '@xylabs/arraybuffer'
2
+ import { assertEx } from '@xylabs/assert'
3
+ import {
4
+ type Address,
5
+ type Hash, type Hex,
6
+ isAddress,
7
+ toHex,
8
+ } from '@xylabs/hex'
9
+
10
+ import type {
11
+ Epoch, LocalSequence, Nonce, QualifiedSequence,
12
+ Sequence,
13
+ } from './Sequence.ts'
14
+ import {
15
+ isQualifiedSequence, isSequence, SequenceConstants,
16
+ } from './Sequence.ts'
17
+
18
+ export class SequenceParser {
19
+ protected static privateConstructorKey = Date.now().toString()
20
+
21
+ private readonly data: Readonly<Uint8Array>
22
+
23
+ protected constructor(privateConstructorKey: string, hex: Hex) {
24
+ assertEx(SequenceParser.privateConstructorKey === privateConstructorKey, () => 'Use create function instead of constructor')
25
+ const paddedHex = toHex(hex, {
26
+ prefix: false,
27
+ bitLength: (hex.length <= SequenceConstants.localSequenceBytes * 2)
28
+ ? SequenceConstants.localSequenceBytes * 8
29
+ : SequenceConstants.qualifiedSequenceBytes * 8,
30
+ })
31
+ this.data = toUint8Array(paddedHex)
32
+ }
33
+
34
+ get address(): Address {
35
+ const start = SequenceConstants.localSequenceBytes
36
+ const end = SequenceConstants.qualifiedSequenceBytes
37
+ return toHex(this.data.slice(start, end).buffer, { prefix: false })
38
+ }
39
+
40
+ get epoch(): Epoch {
41
+ const start = 0
42
+ const end = SequenceConstants.epochBytes
43
+ return toHex(this.data.slice(start, end).buffer, { prefix: false })
44
+ }
45
+
46
+ get localSequence(): LocalSequence {
47
+ const start = 0
48
+ const end = SequenceConstants.localSequenceBytes
49
+ return toHex(this.data.slice(start, end).buffer, { prefix: false })
50
+ }
51
+
52
+ get nonce(): Nonce {
53
+ const start = SequenceConstants.epochBytes
54
+ const end = SequenceConstants.localSequenceBytes
55
+ return toHex(this.data.slice(start, end).buffer, { prefix: false })
56
+ }
57
+
58
+ get qualifiedSequence(): QualifiedSequence {
59
+ const start = 0
60
+ const end = SequenceConstants.qualifiedSequenceBytes
61
+ return toHex(this.data.slice(start, end).buffer, { prefix: false })
62
+ }
63
+
64
+ static from(sequence: Sequence, address?: Address): SequenceParser
65
+ static from(timestamp: Hex, hash: Hash, address?: Address): SequenceParser
66
+ static from(timestamp: Hex, hash: Hex, address?: Address): SequenceParser
67
+ static from(timestamp: Hex, nonce: Nonce, address?: Address): SequenceParser
68
+ static from(timestamp: number, hash: Hash, address?: Address): SequenceParser
69
+ static from(timestamp: number, hash: Hex, address?: Address): SequenceParser
70
+ static from(timestamp: number, nonce: Nonce, address?: Address): SequenceParser
71
+ static from(timestampOrSequence: Sequence | Hex | number, nonceOrAddress: Hash | Nonce, address?: Address): SequenceParser {
72
+ if (isSequence(timestampOrSequence)) {
73
+ if (nonceOrAddress) {
74
+ assertEx(!isQualifiedSequence(timestampOrSequence), () => 'Providing both a qualified sequence and a address is not allowed')
75
+ assertEx(isAddress(nonceOrAddress), () => 'Invalid address provided')
76
+ return new this(SequenceParser.privateConstructorKey, (timestampOrSequence + address) as Hex)
77
+ }
78
+ return new this(SequenceParser.privateConstructorKey, timestampOrSequence)
79
+ }
80
+ const epoch = SequenceParser.toEpoch(timestampOrSequence)
81
+ const nonce = SequenceParser.toNonce(nonceOrAddress)
82
+ const addressHex: Hex = address ? toHex(address, { bitLength: SequenceConstants.addressBytes * 8 }) : '' as Hex
83
+ const hexString = (epoch + nonce + addressHex) as Hex
84
+ assertEx(isSequence(hexString), () => `Invalid sequence [${hexString}] [${epoch}, ${nonce}, ${addressHex}]`)
85
+ return new this(SequenceParser.privateConstructorKey, hexString)
86
+ }
87
+
88
+ static parse(value: Hex | string | ArrayBufferLike): SequenceParser {
89
+ const hex = toHex(value)
90
+ if (isSequence(hex)) {
91
+ return new this(SequenceParser.privateConstructorKey, hex)
92
+ }
93
+ throw new Error(`Invalid sequence [${value}]`)
94
+ }
95
+
96
+ // can convert a short number/hex to an epoch (treats it as the whole value) or extract an epoch from a sequence
97
+ static toEpoch(value: number | Hex | Epoch): Epoch {
98
+ assertEx(
99
+ typeof value !== 'number' || Number.isInteger(value),
100
+ () => 'Value must be in integer',
101
+ )
102
+ const hex = toHex(value, { prefix: false })
103
+ if (hex.length <= SequenceConstants.epochBytes * 2) {
104
+ return toHex(value, { prefix: false, bitLength: SequenceConstants.epochBytes * 8 }) as Epoch
105
+ }
106
+ if (isSequence(hex)) {
107
+ return hex.slice(0, SequenceConstants.epochBytes * 2) as Epoch
108
+ }
109
+ throw new Error(`Value could not be converted to epoch [${hex}]`)
110
+ }
111
+
112
+ // can convert a short number/hex to a nonce (treats it as the whole value) or extract an nonce from a sequence
113
+ static toNonce(value: Hash | Hex): Nonce {
114
+ assertEx(
115
+ typeof value !== 'number' || Number.isInteger(value),
116
+ () => 'Value must be in integer',
117
+ )
118
+ const hex = toHex(value, { prefix: false })
119
+ if (isSequence(hex)) {
120
+ return hex.slice(SequenceConstants.epochBytes * 2, SequenceConstants.localSequenceBytes * 2) as Nonce
121
+ }
122
+ return toHex((hex as string).slice(-SequenceConstants.nonceBytes), { prefix: false, bitLength: SequenceConstants.nonceBytes * 8 }) as Nonce
123
+ }
124
+ }
@@ -1,11 +1,10 @@
1
- import {
2
- type Hash, type Hex, isHash,
3
- } from '@xylabs/hex'
1
+ import { type Hash, isHash } from '@xylabs/hex'
4
2
 
5
- import type { Payload } from './Payload.ts'
3
+ import type { Payload } from '../Payload.ts'
4
+ import type { Sequence } from './Sequence.ts'
6
5
 
7
6
  export interface SequenceMeta {
8
- _sequence: Hex
7
+ _sequence: Sequence
9
8
  }
10
9
 
11
10
  export type WithPartialSequenceMeta<T extends Payload = Payload> = Partial<WithSequenceMeta<T>>
@@ -27,27 +26,6 @@ export type WithPartialStorageMeta<T extends Payload = Payload> = Partial<WithSt
27
26
 
28
27
  export type WithStorageMeta<T extends Payload = Payload> = T & StorageMeta
29
28
 
30
- const StorageMetaComponentConstants = {
31
- epochBytes: 8,
32
- nonceBytes: 8,
33
- addressBytes: 20,
34
- }
35
-
36
- const StorageMetaLocalConstants = {
37
- maxEpoch: Math.pow(256, StorageMetaComponentConstants.epochBytes) - 1,
38
- localSequenceBytes: StorageMetaComponentConstants.epochBytes + StorageMetaComponentConstants.nonceBytes,
39
- minLocalSequence: '00000000000000000000000000000000' as Hex,
40
- maxLocalSequence: 'ffffffffffffffffffffffffffffffff' as Hex,
41
- ...StorageMetaComponentConstants,
42
- }
43
-
44
- export const StorageMetaConstants = {
45
- qualifiedSequenceBytes: StorageMetaLocalConstants.localSequenceBytes + StorageMetaComponentConstants.addressBytes,
46
- minSequence: `${StorageMetaLocalConstants}0000000000000000000000000000000000000000` as Hex,
47
- maxSequence: `${StorageMetaLocalConstants}ffffffffffffffffffffffffffffffffffffffff` as Hex,
48
- ...StorageMetaLocalConstants,
49
- }
50
-
51
29
  export const isSequenceMeta = (value: unknown): value is SequenceMeta => {
52
30
  return (value as WithSequenceMeta)?._sequence !== undefined
53
31
  }
@@ -0,0 +1,3 @@
1
+ export * from './Sequence.ts'
2
+ export * from './SequenceParser.ts'
3
+ export * from './StorageMeta.ts'
package/src/index.ts CHANGED
@@ -8,4 +8,4 @@ export * from './PayloadValidationFunction.ts'
8
8
  export * from './PayloadValueExpression.ts'
9
9
  export * from './Query.ts'
10
10
  export * from './Schema.ts'
11
- export * from './StorageMeta.ts'
11
+ export * from './StorageMeta/index.ts'
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageMeta.d.ts","sourceRoot":"","sources":["../../src/StorageMeta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,IAAI,EAAE,KAAK,GAAG,EACpB,MAAM,aAAa,CAAA;AAEpB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAE3C,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,GAAG,CAAA;CACf;AAED,MAAM,MAAM,uBAAuB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAA;AAE/F,MAAM,MAAM,gBAAgB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,YAAY,CAAA;AAE5E,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,IAAI,CAAA;IACf,KAAK,EAAE,IAAI,CAAA;CACZ;AAED,MAAM,MAAM,mBAAmB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;AAEvF,MAAM,MAAM,YAAY,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,QAAQ,CAAA;AAEpE,MAAM,WAAW,WAAY,SAAQ,YAAY,EAAE,QAAQ;CAAG;AAE9D,MAAM,MAAM,sBAAsB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAA;AAE7F,MAAM,MAAM,eAAe,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,WAAW,CAAA;AAgB1E,eAAO,MAAM,oBAAoB;;;;;;sBALyB,GAAG;sBACH,GAAG;;iBAM4B,GAAG;iBACH,GAAG;CAE3F,CAAA;AAED,eAAO,MAAM,cAAc,UAAW,OAAO,KAAG,KAAK,IAAI,YAExD,CAAA;AAED,eAAO,MAAM,UAAU,UAAW,OAAO,KAAG,KAAK,IAAI,QAEpD,CAAA;AAED,eAAO,MAAM,aAAa,UAAW,OAAO,KAAG,KAAK,IAAI,WAEvD,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageMeta.d.ts","sourceRoot":"","sources":["../../src/StorageMeta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,IAAI,EAAE,KAAK,GAAG,EACpB,MAAM,aAAa,CAAA;AAEpB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAE3C,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,GAAG,CAAA;CACf;AAED,MAAM,MAAM,uBAAuB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAA;AAE/F,MAAM,MAAM,gBAAgB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,YAAY,CAAA;AAE5E,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,IAAI,CAAA;IACf,KAAK,EAAE,IAAI,CAAA;CACZ;AAED,MAAM,MAAM,mBAAmB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;AAEvF,MAAM,MAAM,YAAY,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,QAAQ,CAAA;AAEpE,MAAM,WAAW,WAAY,SAAQ,YAAY,EAAE,QAAQ;CAAG;AAE9D,MAAM,MAAM,sBAAsB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAA;AAE7F,MAAM,MAAM,eAAe,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,WAAW,CAAA;AAgB1E,eAAO,MAAM,oBAAoB;;;;;;sBALyB,GAAG;sBACH,GAAG;;iBAM4B,GAAG;iBACH,GAAG;CAE3F,CAAA;AAED,eAAO,MAAM,cAAc,UAAW,OAAO,KAAG,KAAK,IAAI,YAExD,CAAA;AAED,eAAO,MAAM,UAAU,UAAW,OAAO,KAAG,KAAK,IAAI,QAEpD,CAAA;AAED,eAAO,MAAM,aAAa,UAAW,OAAO,KAAG,KAAK,IAAI,WAEvD,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageMeta.d.ts","sourceRoot":"","sources":["../../src/StorageMeta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,IAAI,EAAE,KAAK,GAAG,EACpB,MAAM,aAAa,CAAA;AAEpB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAE3C,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,GAAG,CAAA;CACf;AAED,MAAM,MAAM,uBAAuB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAA;AAE/F,MAAM,MAAM,gBAAgB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,YAAY,CAAA;AAE5E,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,IAAI,CAAA;IACf,KAAK,EAAE,IAAI,CAAA;CACZ;AAED,MAAM,MAAM,mBAAmB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;AAEvF,MAAM,MAAM,YAAY,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,QAAQ,CAAA;AAEpE,MAAM,WAAW,WAAY,SAAQ,YAAY,EAAE,QAAQ;CAAG;AAE9D,MAAM,MAAM,sBAAsB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAA;AAE7F,MAAM,MAAM,eAAe,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,IAAI,CAAC,GAAG,WAAW,CAAA;AAgB1E,eAAO,MAAM,oBAAoB;;;;;;sBALyB,GAAG;sBACH,GAAG;;iBAM4B,GAAG;iBACH,GAAG;CAE3F,CAAA;AAED,eAAO,MAAM,cAAc,UAAW,OAAO,KAAG,KAAK,IAAI,YAExD,CAAA;AAED,eAAO,MAAM,UAAU,UAAW,OAAO,KAAG,KAAK,IAAI,QAEpD,CAAA;AAED,eAAO,MAAM,aAAa,UAAW,OAAO,KAAG,KAAK,IAAI,WAEvD,CAAA"}