o1js-pack 0.4.1 → 0.4.3

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 (28) hide show
  1. package/.husky/pre-commit +0 -0
  2. package/README.md +8 -2
  3. package/build/src/index.d.ts +5 -5
  4. package/build/src/index.js +5 -5
  5. package/build/src/index.js.map +1 -1
  6. package/build/src/lib/PackingPlant.d.ts +132 -132
  7. package/build/src/lib/PackingPlant.js +190 -190
  8. package/build/src/lib/packed-types/PackedBool.d.ts +85 -85
  9. package/build/src/lib/packed-types/PackedBool.js +49 -49
  10. package/build/src/lib/packed-types/PackedBool.test.d.ts +1 -1
  11. package/build/src/lib/packed-types/PackedBool.test.js +75 -75
  12. package/build/src/lib/packed-types/PackedString.d.ts +181 -181
  13. package/build/src/lib/packed-types/PackedString.js +127 -127
  14. package/build/src/lib/packed-types/PackedString.test.d.ts +1 -1
  15. package/build/src/lib/packed-types/PackedString.test.js +100 -100
  16. package/build/src/lib/packed-types/PackedUInt32.d.ts +85 -85
  17. package/build/src/lib/packed-types/PackedUInt32.js +49 -49
  18. package/build/src/lib/packed-types/PackedUInt32.test.d.ts +1 -1
  19. package/build/src/lib/packed-types/PackedUInt32.test.js +83 -83
  20. package/examples/smart_contract/election/README.md +3 -0
  21. package/examples/smart_contract/election/contract.ts +79 -0
  22. package/examples/smart_contract/election/run.ts +98 -0
  23. package/examples/zk_program/age_gate/README.md +7 -0
  24. package/examples/zk_program/age_gate/circuit.ts +75 -0
  25. package/examples/zk_program/age_gate/non-packed-circuit.ts +68 -0
  26. package/examples/zk_program/age_gate/non-packed-run.ts +36 -0
  27. package/examples/zk_program/age_gate/run.ts +35 -0
  28. package/package.json +2 -4
package/.husky/pre-commit CHANGED
File without changes
package/README.md CHANGED
@@ -8,12 +8,18 @@ o1js Pack is a library for [o1js](https://github.com/o1-labs/o1js/) that allows
8
8
 
9
9
  ### Usage in a zkApp
10
10
 
11
- TODO
12
-
13
11
  ### Smart Contract
14
12
 
13
+ The primary benefit of using this library in a smart contract is that it allows you to use more of your allotted 8 Fields of storage.
14
+
15
+ Check out example usage in a smart contract in [Smart Contract Examples](/examples/smart_contract/).
16
+
15
17
  ### ZK Program
16
18
 
19
+ The benefit to using this library in a zk program is less obvious. In some cases, the number of gates required in a circuit is less using this library than with provable arrays. Especially in applications where the array is hashed many times, packing and unpacking ends up being more effecient than doing a lot of Poseidon hashes. In other cases, you may just prefer the API of o1js Pack compared to using provable arrays.
20
+
21
+ Check out example usage in a zk program in [Zk Program Examples](/examples/zk_program/).
22
+
17
23
  ## How to build
18
24
 
19
25
  ```sh
@@ -1,5 +1,5 @@
1
- import { PackedBoolFactory } from './lib/packed-types/PackedBool.js';
2
- import { PackedUInt32Factory } from './lib/packed-types/PackedUInt32.js';
3
- import { PackingPlant, MultiPackingPlant } from './lib/PackingPlant.js';
4
- import { PackedStringFactory } from './lib/packed-types/PackedString.js';
5
- export { PackedBoolFactory, PackedStringFactory, PackedUInt32Factory, PackingPlant, MultiPackingPlant, };
1
+ import { PackedBoolFactory } from './lib/packed-types/PackedBool.js';
2
+ import { PackedUInt32Factory } from './lib/packed-types/PackedUInt32.js';
3
+ import { PackingPlant, MultiPackingPlant } from './lib/PackingPlant.js';
4
+ import { PackedStringFactory, MultiPackedStringFactory } from './lib/packed-types/PackedString.js';
5
+ export { PackedBoolFactory, PackedStringFactory, MultiPackedStringFactory, PackedUInt32Factory, PackingPlant, MultiPackingPlant, };
@@ -1,6 +1,6 @@
1
- import { PackedBoolFactory } from './lib/packed-types/PackedBool.js';
2
- import { PackedUInt32Factory } from './lib/packed-types/PackedUInt32.js';
3
- import { PackingPlant, MultiPackingPlant } from './lib/PackingPlant.js';
4
- import { PackedStringFactory } from './lib/packed-types/PackedString.js';
5
- export { PackedBoolFactory, PackedStringFactory, PackedUInt32Factory, PackingPlant, MultiPackingPlant, };
1
+ import { PackedBoolFactory } from './lib/packed-types/PackedBool.js';
2
+ import { PackedUInt32Factory } from './lib/packed-types/PackedUInt32.js';
3
+ import { PackingPlant, MultiPackingPlant } from './lib/PackingPlant.js';
4
+ import { PackedStringFactory, MultiPackedStringFactory, } from './lib/packed-types/PackedString.js';
5
+ export { PackedBoolFactory, PackedStringFactory, MultiPackedStringFactory, PackedUInt32Factory, PackingPlant, MultiPackingPlant, };
6
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AAEzE,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,mBAAmB,EACnB,YAAY,EACZ,iBAAiB,GAClB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AACxE,OAAO,EACL,mBAAmB,EACnB,wBAAwB,GACzB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,wBAAwB,EACxB,mBAAmB,EACnB,YAAY,EACZ,iBAAiB,GAClB,CAAC"}
@@ -1,132 +1,132 @@
1
- import { Field, InferProvable } from 'o1js';
2
- export declare function PackingPlant<A, T extends InferProvable<A> = InferProvable<A>>(elementType: A, l: number, bitSize: bigint): (abstract new (packed: Field) => {
3
- assertEquals(other: any): void;
4
- packed: import("o1js/dist/node/lib/field").Field;
5
- }) & {
6
- type: import("o1js/dist/node/bindings/lib/provable-snarky").ProvableExtended<{
7
- packed: import("o1js/dist/node/lib/field").Field;
8
- }, {
9
- packed: string;
10
- }>;
11
- l: number;
12
- bitSize: bigint;
13
- extractField(input: T): Field;
14
- sizeInBits(): bigint;
15
- unpack(f: Field): Array<T>;
16
- /**
17
- *
18
- * @param unpacked Array of the implemented packed type
19
- * @throws if the length of the array is longer than the length of the implementing factory config
20
- */
21
- checkPack(unpacked: Array<T>): void;
22
- /**
23
- *
24
- * @param unpacked Array of the implemented packed type, must be shorter than the max allowed, which varies by type, will throw if the input is too long
25
- * @returns Field, packed with the information from the unpacked input
26
- */
27
- pack(unpacked: Array<T>): Field;
28
- /**
29
- *
30
- * @param f Field, packed with the information, as returned by #pack
31
- * @returns Array of bigints, which can be decoded by the implementing class into the final type
32
- */
33
- unpackToBigints(f: Field): Array<bigint>;
34
- _isStruct: true;
35
- toFields: (value: {
36
- packed: import("o1js/dist/node/lib/field").Field;
37
- }) => import("o1js/dist/node/lib/field").Field[];
38
- toAuxiliary: (value?: {
39
- packed: import("o1js/dist/node/lib/field").Field;
40
- } | undefined) => any[];
41
- fromFields: (fields: import("o1js/dist/node/lib/field").Field[]) => {
42
- packed: import("o1js/dist/node/lib/field").Field;
43
- };
44
- sizeInFields(): number;
45
- check: (value: {
46
- packed: import("o1js/dist/node/lib/field").Field;
47
- }) => void;
48
- toInput: (x: {
49
- packed: import("o1js/dist/node/lib/field").Field;
50
- }) => {
51
- fields?: import("o1js/dist/node/lib/field").Field[] | undefined;
52
- packed?: [import("o1js/dist/node/lib/field").Field, number][] | undefined;
53
- };
54
- toJSON: (x: {
55
- packed: import("o1js/dist/node/lib/field").Field;
56
- }) => {
57
- packed: string;
58
- };
59
- fromJSON: (x: {
60
- packed: string;
61
- }) => {
62
- packed: import("o1js/dist/node/lib/field").Field;
63
- };
64
- };
65
- export declare function MultiPackingPlant<A, T extends InferProvable<A> = InferProvable<A>>(elementType: A, l: number, bitSize: bigint): (abstract new (packed: Array<Field>) => {
66
- assertEquals(other: any): void;
67
- packed: import("o1js/dist/node/lib/field").Field[];
68
- }) & {
69
- type: import("o1js/dist/node/bindings/lib/provable-snarky").ProvableExtended<{
70
- packed: import("o1js/dist/node/lib/field").Field[];
71
- }, {
72
- packed: string[];
73
- }>;
74
- l: number;
75
- n: number;
76
- bitSize: bigint;
77
- extractField(input: T | undefined): Field;
78
- sizeInBits(): bigint;
79
- elementsPerField(): number;
80
- unpack(fields: Array<Field>): Array<T>;
81
- /**
82
- *
83
- * @param unpacked Array of the implemented packed type
84
- * @throws if the length of the array is longer than the length of the implementing factory config
85
- */
86
- checkPack(unpacked: Array<T>): void;
87
- /**
88
- *
89
- * @param unpacked Array of the implemented packed type, must be shorter than the max allowed, which varies by type, will throw if the input is too long
90
- * @returns Array of Fields, packed such that each Field has as much information as possible
91
- *
92
- * e.g. 15 Characters pack into 1 Field. 15 or fewer Characters will return an array of 1 Field
93
- * 30 of fewer Characters will return an aray of 2 Fields
94
- */
95
- pack(unpacked: Array<T>): Array<Field>;
96
- /**
97
- *
98
- * @param fields Array of Fields, packed such that each Field has as much information as possible, as returned in #pack
99
- * @returns Array of bigints, which can be decoded by the implementing class into the final type
100
- */
101
- unpackToBigints(fields: Array<Field>): Array<bigint>;
102
- _isStruct: true;
103
- toFields: (value: {
104
- packed: import("o1js/dist/node/lib/field").Field[];
105
- }) => import("o1js/dist/node/lib/field").Field[];
106
- toAuxiliary: (value?: {
107
- packed: import("o1js/dist/node/lib/field").Field[];
108
- } | undefined) => any[];
109
- fromFields: (fields: import("o1js/dist/node/lib/field").Field[]) => {
110
- packed: import("o1js/dist/node/lib/field").Field[];
111
- };
112
- sizeInFields(): number;
113
- check: (value: {
114
- packed: import("o1js/dist/node/lib/field").Field[];
115
- }) => void;
116
- toInput: (x: {
117
- packed: import("o1js/dist/node/lib/field").Field[];
118
- }) => {
119
- fields?: import("o1js/dist/node/lib/field").Field[] | undefined;
120
- packed?: [import("o1js/dist/node/lib/field").Field, number][] | undefined;
121
- };
122
- toJSON: (x: {
123
- packed: import("o1js/dist/node/lib/field").Field[];
124
- }) => {
125
- packed: string[];
126
- };
127
- fromJSON: (x: {
128
- packed: string[];
129
- }) => {
130
- packed: import("o1js/dist/node/lib/field").Field[];
131
- };
132
- };
1
+ import { Field, InferProvable } from 'o1js';
2
+ export declare function PackingPlant<A, T extends InferProvable<A> = InferProvable<A>>(elementType: A, l: number, bitSize: bigint): (abstract new (packed: Field) => {
3
+ assertEquals(other: any): void;
4
+ packed: import("o1js/dist/node/lib/field").Field;
5
+ }) & {
6
+ type: import("o1js/dist/node/bindings/lib/provable-snarky").ProvableExtended<{
7
+ packed: import("o1js/dist/node/lib/field").Field;
8
+ }, {
9
+ packed: string;
10
+ }>;
11
+ l: number;
12
+ bitSize: bigint;
13
+ extractField(input: T): Field;
14
+ sizeInBits(): bigint;
15
+ unpack(f: Field): Array<T>;
16
+ /**
17
+ *
18
+ * @param unpacked Array of the implemented packed type
19
+ * @throws if the length of the array is longer than the length of the implementing factory config
20
+ */
21
+ checkPack(unpacked: Array<T>): void;
22
+ /**
23
+ *
24
+ * @param unpacked Array of the implemented packed type, must be shorter than the max allowed, which varies by type, will throw if the input is too long
25
+ * @returns Field, packed with the information from the unpacked input
26
+ */
27
+ pack(unpacked: Array<T>): Field;
28
+ /**
29
+ *
30
+ * @param f Field, packed with the information, as returned by #pack
31
+ * @returns Array of bigints, which can be decoded by the implementing class into the final type
32
+ */
33
+ unpackToBigints(f: Field): Array<bigint>;
34
+ _isStruct: true;
35
+ toFields: (value: {
36
+ packed: import("o1js/dist/node/lib/field").Field;
37
+ }) => import("o1js/dist/node/lib/field").Field[];
38
+ toAuxiliary: (value?: {
39
+ packed: import("o1js/dist/node/lib/field").Field;
40
+ } | undefined) => any[];
41
+ fromFields: (fields: import("o1js/dist/node/lib/field").Field[]) => {
42
+ packed: import("o1js/dist/node/lib/field").Field;
43
+ };
44
+ sizeInFields(): number;
45
+ check: (value: {
46
+ packed: import("o1js/dist/node/lib/field").Field;
47
+ }) => void;
48
+ toInput: (x: {
49
+ packed: import("o1js/dist/node/lib/field").Field;
50
+ }) => {
51
+ fields?: import("o1js/dist/node/lib/field").Field[] | undefined;
52
+ packed?: [import("o1js/dist/node/lib/field").Field, number][] | undefined;
53
+ };
54
+ toJSON: (x: {
55
+ packed: import("o1js/dist/node/lib/field").Field;
56
+ }) => {
57
+ packed: string;
58
+ };
59
+ fromJSON: (x: {
60
+ packed: string;
61
+ }) => {
62
+ packed: import("o1js/dist/node/lib/field").Field;
63
+ };
64
+ };
65
+ export declare function MultiPackingPlant<A, T extends InferProvable<A> = InferProvable<A>>(elementType: A, l: number, bitSize: bigint): (abstract new (packed: Array<Field>) => {
66
+ assertEquals(other: any): void;
67
+ packed: import("o1js/dist/node/lib/field").Field[];
68
+ }) & {
69
+ type: import("o1js/dist/node/bindings/lib/provable-snarky").ProvableExtended<{
70
+ packed: import("o1js/dist/node/lib/field").Field[];
71
+ }, {
72
+ packed: string[];
73
+ }>;
74
+ l: number;
75
+ n: number;
76
+ bitSize: bigint;
77
+ extractField(input: T | undefined): Field;
78
+ sizeInBits(): bigint;
79
+ elementsPerField(): number;
80
+ unpack(fields: Array<Field>): Array<T>;
81
+ /**
82
+ *
83
+ * @param unpacked Array of the implemented packed type
84
+ * @throws if the length of the array is longer than the length of the implementing factory config
85
+ */
86
+ checkPack(unpacked: Array<T>): void;
87
+ /**
88
+ *
89
+ * @param unpacked Array of the implemented packed type, must be shorter than the max allowed, which varies by type, will throw if the input is too long
90
+ * @returns Array of Fields, packed such that each Field has as much information as possible
91
+ *
92
+ * e.g. 15 Characters pack into 1 Field. 15 or fewer Characters will return an array of 1 Field
93
+ * 30 of fewer Characters will return an aray of 2 Fields
94
+ */
95
+ pack(unpacked: Array<T>): Array<Field>;
96
+ /**
97
+ *
98
+ * @param fields Array of Fields, packed such that each Field has as much information as possible, as returned in #pack
99
+ * @returns Array of bigints, which can be decoded by the implementing class into the final type
100
+ */
101
+ unpackToBigints(fields: Array<Field>): Array<bigint>;
102
+ _isStruct: true;
103
+ toFields: (value: {
104
+ packed: import("o1js/dist/node/lib/field").Field[];
105
+ }) => import("o1js/dist/node/lib/field").Field[];
106
+ toAuxiliary: (value?: {
107
+ packed: import("o1js/dist/node/lib/field").Field[];
108
+ } | undefined) => any[];
109
+ fromFields: (fields: import("o1js/dist/node/lib/field").Field[]) => {
110
+ packed: import("o1js/dist/node/lib/field").Field[];
111
+ };
112
+ sizeInFields(): number;
113
+ check: (value: {
114
+ packed: import("o1js/dist/node/lib/field").Field[];
115
+ }) => void;
116
+ toInput: (x: {
117
+ packed: import("o1js/dist/node/lib/field").Field[];
118
+ }) => {
119
+ fields?: import("o1js/dist/node/lib/field").Field[] | undefined;
120
+ packed?: [import("o1js/dist/node/lib/field").Field, number][] | undefined;
121
+ };
122
+ toJSON: (x: {
123
+ packed: import("o1js/dist/node/lib/field").Field[];
124
+ }) => {
125
+ packed: string[];
126
+ };
127
+ fromJSON: (x: {
128
+ packed: string[];
129
+ }) => {
130
+ packed: import("o1js/dist/node/lib/field").Field[];
131
+ };
132
+ };