@waterx/predict-sdk 0.1.0

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 (105) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +67 -0
  3. package/dist/src/account.d.ts +64 -0
  4. package/dist/src/account.js +134 -0
  5. package/dist/src/admin.d.ts +47 -0
  6. package/dist/src/admin.js +104 -0
  7. package/dist/src/bcs.d.ts +20 -0
  8. package/dist/src/bcs.js +209 -0
  9. package/dist/src/client.d.ts +60 -0
  10. package/dist/src/client.js +59 -0
  11. package/dist/src/constants.d.ts +61 -0
  12. package/dist/src/constants.js +62 -0
  13. package/dist/src/fetch.d.ts +53 -0
  14. package/dist/src/fetch.js +187 -0
  15. package/dist/src/generated/bucket_v2_framework/account.d.ts +100 -0
  16. package/dist/src/generated/bucket_v2_framework/account.js +129 -0
  17. package/dist/src/generated/bucket_v2_framework/deps/std/type_name.d.ts +6 -0
  18. package/dist/src/generated/bucket_v2_framework/deps/std/type_name.js +19 -0
  19. package/dist/src/generated/bucket_v2_framework/deps/sui/balance.d.ts +10 -0
  20. package/dist/src/generated/bucket_v2_framework/deps/sui/balance.js +14 -0
  21. package/dist/src/generated/bucket_v2_framework/deps/sui/vec_map.d.ts +36 -0
  22. package/dist/src/generated/bucket_v2_framework/deps/sui/vec_map.js +27 -0
  23. package/dist/src/generated/bucket_v2_framework/deps/sui/vec_set.d.ts +16 -0
  24. package/dist/src/generated/bucket_v2_framework/deps/sui/vec_set.js +19 -0
  25. package/dist/src/generated/bucket_v2_framework/double.d.ts +382 -0
  26. package/dist/src/generated/bucket_v2_framework/double.js +466 -0
  27. package/dist/src/generated/bucket_v2_framework/float.d.ts +362 -0
  28. package/dist/src/generated/bucket_v2_framework/float.js +440 -0
  29. package/dist/src/generated/bucket_v2_framework/liability.d.ts +193 -0
  30. package/dist/src/generated/bucket_v2_framework/liability.js +205 -0
  31. package/dist/src/generated/bucket_v2_framework/linked_table.d.ts +384 -0
  32. package/dist/src/generated/bucket_v2_framework/linked_table.js +382 -0
  33. package/dist/src/generated/bucket_v2_framework/sheet.d.ts +344 -0
  34. package/dist/src/generated/bucket_v2_framework/sheet.js +344 -0
  35. package/dist/src/generated/utils/index.d.ts +30 -0
  36. package/dist/src/generated/utils/index.js +157 -0
  37. package/dist/src/generated/waterx_account/account.d.ts +1326 -0
  38. package/dist/src/generated/waterx_account/account.js +1487 -0
  39. package/dist/src/generated/waterx_account/deps/std/type_name.d.ts +6 -0
  40. package/dist/src/generated/waterx_account/deps/std/type_name.js +19 -0
  41. package/dist/src/generated/waterx_account/deps/sui/balance.d.ts +10 -0
  42. package/dist/src/generated/waterx_account/deps/sui/balance.js +14 -0
  43. package/dist/src/generated/waterx_account/deps/sui/table.d.ts +24 -0
  44. package/dist/src/generated/waterx_account/deps/sui/table.js +31 -0
  45. package/dist/src/generated/waterx_account/deps/sui/vec_map.d.ts +36 -0
  46. package/dist/src/generated/waterx_account/deps/sui/vec_map.js +27 -0
  47. package/dist/src/generated/waterx_account/deps/sui/vec_set.d.ts +16 -0
  48. package/dist/src/generated/waterx_account/deps/sui/vec_set.js +19 -0
  49. package/dist/src/generated/waterx_account/direct_rule.d.ts +72 -0
  50. package/dist/src/generated/waterx_account/direct_rule.js +75 -0
  51. package/dist/src/generated/waterx_account/events.d.ts +30 -0
  52. package/dist/src/generated/waterx_account/events.js +145 -0
  53. package/dist/src/generated/waterx_account/version.d.ts +10 -0
  54. package/dist/src/generated/waterx_account/version.js +8 -0
  55. package/dist/src/generated/waterx_prediction/account_data.d.ts +321 -0
  56. package/dist/src/generated/waterx_prediction/account_data.js +399 -0
  57. package/dist/src/generated/waterx_prediction/admin.d.ts +5 -0
  58. package/dist/src/generated/waterx_prediction/admin.js +9 -0
  59. package/dist/src/generated/waterx_prediction/deps/bucket_v2_framework/linked_table.d.ts +8 -0
  60. package/dist/src/generated/waterx_prediction/deps/bucket_v2_framework/linked_table.js +18 -0
  61. package/dist/src/generated/waterx_prediction/deps/sui/balance.d.ts +10 -0
  62. package/dist/src/generated/waterx_prediction/deps/sui/balance.js +14 -0
  63. package/dist/src/generated/waterx_prediction/deps/sui/table.d.ts +24 -0
  64. package/dist/src/generated/waterx_prediction/deps/sui/table.js +31 -0
  65. package/dist/src/generated/waterx_prediction/deps/sui/vec_set.d.ts +16 -0
  66. package/dist/src/generated/waterx_prediction/deps/sui/vec_set.js +19 -0
  67. package/dist/src/generated/waterx_prediction/events.d.ts +19 -0
  68. package/dist/src/generated/waterx_prediction/events.js +99 -0
  69. package/dist/src/generated/waterx_prediction/global_config.d.ts +68 -0
  70. package/dist/src/generated/waterx_prediction/global_config.js +83 -0
  71. package/dist/src/generated/waterx_prediction/order.d.ts +170 -0
  72. package/dist/src/generated/waterx_prediction/order.js +237 -0
  73. package/dist/src/generated/waterx_prediction/outcome.d.ts +58 -0
  74. package/dist/src/generated/waterx_prediction/outcome.js +73 -0
  75. package/dist/src/generated/waterx_prediction/position.d.ts +150 -0
  76. package/dist/src/generated/waterx_prediction/position.js +200 -0
  77. package/dist/src/generated/waterx_prediction/view.d.ts +353 -0
  78. package/dist/src/generated/waterx_prediction/view.js +426 -0
  79. package/dist/src/generated/waterx_prediction/waterx_prediction.d.ts +1520 -0
  80. package/dist/src/generated/waterx_prediction/waterx_prediction.js +1550 -0
  81. package/dist/src/index.d.ts +22 -0
  82. package/dist/src/index.js +17 -0
  83. package/dist/src/prediction.d.ts +81 -0
  84. package/dist/src/prediction.js +220 -0
  85. package/dist/src/types.d.ts +81 -0
  86. package/dist/src/types.js +1 -0
  87. package/dist/src/user/account.d.ts +2 -0
  88. package/dist/src/user/account.js +1 -0
  89. package/dist/src/user/admin.d.ts +4 -0
  90. package/dist/src/user/admin.js +2 -0
  91. package/dist/src/user/index.d.ts +4 -0
  92. package/dist/src/user/index.js +2 -0
  93. package/dist/src/user/keeper.d.ts +2 -0
  94. package/dist/src/user/keeper.js +1 -0
  95. package/dist/src/user/order.d.ts +2 -0
  96. package/dist/src/user/order.js +1 -0
  97. package/dist/src/user/position.d.ts +2 -0
  98. package/dist/src/user/position.js +1 -0
  99. package/dist/src/utils/bcs.d.ts +1 -0
  100. package/dist/src/utils/bcs.js +1 -0
  101. package/dist/src/utils/index.d.ts +1 -0
  102. package/dist/src/utils/index.js +1 -0
  103. package/dist/src/utils.d.ts +29 -0
  104. package/dist/src/utils.js +170 -0
  105. package/package.json +62 -0
@@ -0,0 +1,30 @@
1
+ import { type BcsType, type TypeTag, BcsStruct, BcsEnum, BcsTuple } from '@mysten/sui/bcs';
2
+ import { type TransactionArgument } from '@mysten/sui/transactions';
3
+ import { type ClientWithCoreApi, type SuiClientTypes } from '@mysten/sui/client';
4
+ export type RawTransactionArgument<T> = T | TransactionArgument;
5
+ export interface GetOptions<Include extends Omit<SuiClientTypes.ObjectInclude, 'content'> = {}> extends SuiClientTypes.GetObjectOptions<Include> {
6
+ client: ClientWithCoreApi;
7
+ }
8
+ export interface GetManyOptions<Include extends Omit<SuiClientTypes.ObjectInclude, 'content'> = {}> extends SuiClientTypes.GetObjectsOptions<Include> {
9
+ client: ClientWithCoreApi;
10
+ }
11
+ export declare function getPureBcsSchema(typeTag: string | TypeTag): BcsType<any> | null;
12
+ export declare function normalizeMoveArguments(args: unknown[] | object, argTypes: readonly (string | null)[], parameterNames?: string[]): TransactionArgument[];
13
+ export declare class MoveStruct<T extends Record<string, BcsType<any>>, const Name extends string = string> extends BcsStruct<T, Name> {
14
+ get<Include extends Omit<SuiClientTypes.ObjectInclude, 'content' | 'json'> = {}>({ objectId, ...options }: GetOptions<Include>): Promise<SuiClientTypes.Object<Include & {
15
+ content: true;
16
+ json: true;
17
+ }> & {
18
+ json: BcsStruct<T>['$inferType'];
19
+ }>;
20
+ getMany<Include extends Omit<SuiClientTypes.ObjectInclude, 'content' | 'json'> = {}>({ client, ...options }: GetManyOptions<Include>): Promise<Array<SuiClientTypes.Object<Include & {
21
+ content: true;
22
+ json: true;
23
+ }> & {
24
+ json: BcsStruct<T>['$inferType'];
25
+ }>>;
26
+ }
27
+ export declare class MoveEnum<T extends Record<string, BcsType<any> | null>, const Name extends string> extends BcsEnum<T, Name> {
28
+ }
29
+ export declare class MoveTuple<const T extends readonly BcsType<any>[], const Name extends string> extends BcsTuple<T, Name> {
30
+ }
@@ -0,0 +1,157 @@
1
+ import { bcs, TypeTagSerializer, BcsStruct, BcsEnum, BcsTuple, } from '@mysten/sui/bcs';
2
+ import { normalizeSuiAddress } from '@mysten/sui/utils';
3
+ import { isArgument } from '@mysten/sui/transactions';
4
+ const MOVE_STDLIB_ADDRESS = normalizeSuiAddress('0x1');
5
+ const SUI_FRAMEWORK_ADDRESS = normalizeSuiAddress('0x2');
6
+ export function getPureBcsSchema(typeTag) {
7
+ const parsedTag = typeof typeTag === 'string' ? TypeTagSerializer.parseFromStr(typeTag) : typeTag;
8
+ if ('u8' in parsedTag) {
9
+ return bcs.U8;
10
+ }
11
+ else if ('u16' in parsedTag) {
12
+ return bcs.U16;
13
+ }
14
+ else if ('u32' in parsedTag) {
15
+ return bcs.U32;
16
+ }
17
+ else if ('u64' in parsedTag) {
18
+ return bcs.U64;
19
+ }
20
+ else if ('u128' in parsedTag) {
21
+ return bcs.U128;
22
+ }
23
+ else if ('u256' in parsedTag) {
24
+ return bcs.U256;
25
+ }
26
+ else if ('address' in parsedTag) {
27
+ return bcs.Address;
28
+ }
29
+ else if ('bool' in parsedTag) {
30
+ return bcs.Bool;
31
+ }
32
+ else if ('vector' in parsedTag) {
33
+ const type = getPureBcsSchema(parsedTag.vector);
34
+ return type ? bcs.vector(type) : null;
35
+ }
36
+ else if ('struct' in parsedTag) {
37
+ const structTag = parsedTag.struct;
38
+ const pkg = normalizeSuiAddress(structTag.address);
39
+ if (pkg === MOVE_STDLIB_ADDRESS) {
40
+ if ((structTag.module === 'ascii' || structTag.module === 'string') &&
41
+ structTag.name === 'String') {
42
+ return bcs.String;
43
+ }
44
+ if (structTag.module === 'option' && structTag.name === 'Option') {
45
+ const type = getPureBcsSchema(structTag.typeParams[0]);
46
+ return type ? bcs.option(type) : null;
47
+ }
48
+ }
49
+ if (pkg === SUI_FRAMEWORK_ADDRESS &&
50
+ structTag.module === 'object' &&
51
+ (structTag.name === 'ID' || structTag.name === 'UID')) {
52
+ return bcs.Address;
53
+ }
54
+ }
55
+ return null;
56
+ }
57
+ export function normalizeMoveArguments(args, argTypes, parameterNames) {
58
+ const argLen = Array.isArray(args) ? args.length : Object.keys(args).length;
59
+ if (parameterNames && argLen !== parameterNames.length) {
60
+ throw new Error(`Invalid number of arguments, expected ${parameterNames.length}, got ${argLen}`);
61
+ }
62
+ const normalizedArgs = [];
63
+ let index = 0;
64
+ for (const [i, argType] of argTypes.entries()) {
65
+ if (argType === '0x2::clock::Clock') {
66
+ normalizedArgs.push((tx) => tx.object.clock());
67
+ continue;
68
+ }
69
+ if (argType === '0x2::random::Random') {
70
+ normalizedArgs.push((tx) => tx.object.random());
71
+ continue;
72
+ }
73
+ if (argType === '0x2::deny_list::DenyList') {
74
+ normalizedArgs.push((tx) => tx.object.denyList());
75
+ continue;
76
+ }
77
+ if (argType === '0x3::sui_system::SuiSystemState') {
78
+ normalizedArgs.push((tx) => tx.object.system());
79
+ continue;
80
+ }
81
+ let arg;
82
+ if (Array.isArray(args)) {
83
+ if (index >= args.length) {
84
+ throw new Error(`Invalid number of arguments, expected at least ${index + 1}, got ${args.length}`);
85
+ }
86
+ arg = args[index];
87
+ }
88
+ else {
89
+ if (!parameterNames) {
90
+ throw new Error(`Expected arguments to be passed as an array`);
91
+ }
92
+ const name = parameterNames[index];
93
+ arg = args[name];
94
+ if (arg === undefined) {
95
+ throw new Error(`Parameter ${name} is required`);
96
+ }
97
+ }
98
+ index += 1;
99
+ if (typeof arg === 'function' || isArgument(arg)) {
100
+ normalizedArgs.push(arg);
101
+ continue;
102
+ }
103
+ const type = argTypes[i];
104
+ const bcsType = type === null ? null : getPureBcsSchema(type);
105
+ if (bcsType) {
106
+ const bytes = bcsType.serialize(arg);
107
+ normalizedArgs.push((tx) => tx.pure(bytes));
108
+ continue;
109
+ }
110
+ else if (typeof arg === 'string') {
111
+ normalizedArgs.push((tx) => tx.object(arg));
112
+ continue;
113
+ }
114
+ throw new Error(`Invalid argument ${stringify(arg)} for type ${type}`);
115
+ }
116
+ return normalizedArgs;
117
+ }
118
+ export class MoveStruct extends BcsStruct {
119
+ async get({ objectId, ...options }) {
120
+ const [res] = await this.getMany({
121
+ ...options,
122
+ objectIds: [objectId],
123
+ });
124
+ return res;
125
+ }
126
+ async getMany({ client, ...options }) {
127
+ const response = (await client.core.getObjects({
128
+ ...options,
129
+ include: {
130
+ ...options.include,
131
+ content: true,
132
+ },
133
+ }));
134
+ return response.objects.map((obj) => {
135
+ if (obj instanceof Error) {
136
+ throw obj;
137
+ }
138
+ return {
139
+ ...obj,
140
+ json: this.parse(obj.content),
141
+ };
142
+ });
143
+ }
144
+ }
145
+ export class MoveEnum extends BcsEnum {
146
+ }
147
+ export class MoveTuple extends BcsTuple {
148
+ }
149
+ function stringify(val) {
150
+ if (typeof val === 'object') {
151
+ return JSON.stringify(val, (val) => val);
152
+ }
153
+ if (typeof val === 'bigint') {
154
+ return val.toString();
155
+ }
156
+ return val;
157
+ }