wasm-ast-types 0.26.4 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- package/LICENSE-Apache +201 -0
- package/LICENSE-MIT +21 -0
- package/README.md +1 -1
- package/{types/client → client}/client.d.ts +2 -2
- package/client/client.js +275 -0
- package/client/index.js +17 -0
- package/{types/context → context}/context.d.ts +9 -22
- package/context/context.js +114 -0
- package/{types/context → context}/imports.d.ts +9 -8
- package/context/imports.js +166 -0
- package/context/index.js +18 -0
- package/esm/client/client.js +238 -0
- package/esm/client/index.js +1 -0
- package/esm/context/context.js +104 -0
- package/esm/context/imports.js +136 -0
- package/{module → esm}/context/index.js +1 -1
- package/{src/index.ts → esm/index.js} +0 -1
- package/esm/message-builder/message-builder.js +64 -0
- package/esm/message-composer/message-composer.js +105 -0
- package/esm/provider/provider.js +97 -0
- package/esm/react-query/react-query.js +458 -0
- package/esm/recoil/recoil.js +110 -0
- package/esm/utils/babel.js +231 -0
- package/esm/utils/constants.js +20 -0
- package/esm/utils/ref.js +4 -0
- package/esm/utils/types.js +343 -0
- package/{types/index.d.ts → index.d.ts} +0 -1
- package/index.js +24 -0
- package/message-builder/index.js +17 -0
- package/{types/message-builder → message-builder}/message-builder.d.ts +1 -1
- package/message-builder/message-builder.js +91 -0
- package/message-composer/index.d.ts +1 -0
- package/message-composer/index.js +17 -0
- package/{types/message-composer → message-composer}/message-composer.d.ts +1 -1
- package/message-composer/message-composer.js +133 -0
- package/package.json +19 -68
- package/provider/index.d.ts +1 -0
- package/provider/index.js +17 -0
- package/provider/provider.js +127 -0
- package/react-query/index.d.ts +1 -0
- package/react-query/index.js +17 -0
- package/{types/react-query → react-query}/react-query.d.ts +2 -3
- package/react-query/react-query.js +490 -0
- package/recoil/index.d.ts +1 -0
- package/recoil/index.js +17 -0
- package/{types/recoil → recoil}/recoil.d.ts +1 -1
- package/recoil/recoil.js +140 -0
- package/{types/utils → utils}/babel.d.ts +9 -8
- package/utils/babel.js +285 -0
- package/utils/constants.js +46 -0
- package/utils/index.js +26 -0
- package/{types/utils → utils}/ref.d.ts +1 -1
- package/utils/ref.js +8 -0
- package/{types/utils → utils}/types.d.ts +8 -8
- package/utils/types.js +379 -0
- package/main/client/client.js +0 -196
- package/main/client/index.js +0 -16
- package/main/client/test/ts-client.account-nfts.spec.js +0 -28
- package/main/client/test/ts-client.arrays-ref.spec.js +0 -19
- package/main/client/test/ts-client.arrays.spec.js +0 -26
- package/main/client/test/ts-client.cw-named-groups.test.js +0 -19
- package/main/client/test/ts-client.cw-proposal-single.test.js +0 -23
- package/main/client/test/ts-client.empty-enums.spec.js +0 -13
- package/main/client/test/ts-client.issue-101.spec.js +0 -23
- package/main/client/test/ts-client.issue-103.test.js +0 -44
- package/main/client/test/ts-client.issue-71.test.js +0 -81
- package/main/client/test/ts-client.issue-98.test.js +0 -28
- package/main/client/test/ts-client.issues.test.js +0 -81
- package/main/client/test/ts-client.overrides.spec.js +0 -33
- package/main/client/test/ts-client.sg721.spec.js +0 -19
- package/main/client/test/ts-client.spec.js +0 -87
- package/main/client/test/ts-client.vectis.spec.js +0 -46
- package/main/client/test/ts-client.wager.spec.js +0 -39
- package/main/context/context.js +0 -162
- package/main/context/imports.js +0 -159
- package/main/context/index.js +0 -27
- package/main/index.js +0 -104
- package/main/message-builder/index.js +0 -16
- package/main/message-builder/message-builder.js +0 -62
- package/main/message-builder/message-builder.spec.js +0 -20
- package/main/message-composer/index.js +0 -16
- package/main/message-composer/message-composer.js +0 -86
- package/main/message-composer/message-composer.spec.js +0 -23
- package/main/provider/index.js +0 -16
- package/main/provider/provider.js +0 -71
- package/main/provider/provider.spec.js +0 -60
- package/main/react-query/index.js +0 -16
- package/main/react-query/react-query.js +0 -413
- package/main/react-query/react-query.spec.js +0 -91
- package/main/recoil/index.js +0 -16
- package/main/recoil/recoil.js +0 -61
- package/main/recoil/recoil.spec.js +0 -20
- package/main/types.js +0 -4
- package/main/utils/babel.js +0 -282
- package/main/utils/babel.spec.js +0 -109
- package/main/utils/constants.js +0 -26
- package/main/utils/index.js +0 -65
- package/main/utils/ref.js +0 -12
- package/main/utils/types.js +0 -343
- package/module/client/client.js +0 -166
- package/module/client/index.js +0 -1
- package/module/client/test/ts-client.account-nfts.spec.js +0 -25
- package/module/client/test/ts-client.arrays-ref.spec.js +0 -16
- package/module/client/test/ts-client.arrays.spec.js +0 -23
- package/module/client/test/ts-client.cw-named-groups.test.js +0 -16
- package/module/client/test/ts-client.cw-proposal-single.test.js +0 -20
- package/module/client/test/ts-client.empty-enums.spec.js +0 -10
- package/module/client/test/ts-client.issue-101.spec.js +0 -22
- package/module/client/test/ts-client.issue-103.test.js +0 -41
- package/module/client/test/ts-client.issue-71.test.js +0 -21
- package/module/client/test/ts-client.issue-98.test.js +0 -25
- package/module/client/test/ts-client.issues.test.js +0 -21
- package/module/client/test/ts-client.overrides.spec.js +0 -30
- package/module/client/test/ts-client.sg721.spec.js +0 -16
- package/module/client/test/ts-client.spec.js +0 -84
- package/module/client/test/ts-client.vectis.spec.js +0 -43
- package/module/client/test/ts-client.wager.spec.js +0 -36
- package/module/context/context.js +0 -116
- package/module/context/imports.js +0 -127
- package/module/index.js +0 -9
- package/module/message-builder/index.js +0 -1
- package/module/message-builder/message-builder.js +0 -52
- package/module/message-builder/message-builder.spec.js +0 -17
- package/module/message-composer/index.js +0 -1
- package/module/message-composer/message-composer.js +0 -70
- package/module/message-composer/message-composer.spec.js +0 -20
- package/module/provider/index.js +0 -1
- package/module/provider/provider.js +0 -45
- package/module/provider/provider.spec.js +0 -58
- package/module/react-query/index.js +0 -1
- package/module/react-query/react-query.js +0 -403
- package/module/react-query/react-query.spec.js +0 -85
- package/module/recoil/index.js +0 -1
- package/module/recoil/recoil.js +0 -46
- package/module/recoil/recoil.spec.js +0 -14
- package/module/types.js +0 -3
- package/module/utils/babel.js +0 -203
- package/module/utils/babel.spec.js +0 -70
- package/module/utils/constants.js +0 -12
- package/module/utils/index.js +0 -6
- package/module/utils/ref.js +0 -4
- package/module/utils/types.js +0 -301
- package/src/client/client.ts +0 -584
- package/src/client/index.ts +0 -1
- package/src/client/test/__snapshots__/ts-client.account-nfts.spec.ts.snap +0 -497
- package/src/client/test/__snapshots__/ts-client.arrays-ref.spec.ts.snap +0 -452
- package/src/client/test/__snapshots__/ts-client.arrays.spec.ts.snap +0 -101
- package/src/client/test/__snapshots__/ts-client.cw-named-groups.test.ts.snap +0 -141
- package/src/client/test/__snapshots__/ts-client.cw-proposal-single.test.ts.snap +0 -341
- package/src/client/test/__snapshots__/ts-client.empty-enums.spec.ts.snap +0 -20
- package/src/client/test/__snapshots__/ts-client.issue-101.spec.ts.snap +0 -47
- package/src/client/test/__snapshots__/ts-client.issue-103.test.ts.snap +0 -79
- package/src/client/test/__snapshots__/ts-client.issue-71.test.ts.snap +0 -432
- package/src/client/test/__snapshots__/ts-client.issue-98.test.ts.snap +0 -117
- package/src/client/test/__snapshots__/ts-client.issues.test.ts.snap +0 -984
- package/src/client/test/__snapshots__/ts-client.overrides.spec.ts.snap +0 -709
- package/src/client/test/__snapshots__/ts-client.sg721.spec.ts.snap +0 -350
- package/src/client/test/__snapshots__/ts-client.spec.ts.snap +0 -723
- package/src/client/test/__snapshots__/ts-client.vectis.spec.ts.snap +0 -337
- package/src/client/test/__snapshots__/ts-client.wager.spec.ts.snap +0 -132
- package/src/client/test/ts-client.account-nfts.spec.ts +0 -55
- package/src/client/test/ts-client.arrays-ref.spec.ts +0 -48
- package/src/client/test/ts-client.arrays.spec.ts +0 -58
- package/src/client/test/ts-client.cw-named-groups.test.ts +0 -48
- package/src/client/test/ts-client.cw-proposal-single.test.ts +0 -50
- package/src/client/test/ts-client.empty-enums.spec.ts +0 -28
- package/src/client/test/ts-client.issue-101.spec.ts +0 -37
- package/src/client/test/ts-client.issue-103.test.ts +0 -106
- package/src/client/test/ts-client.issue-71.test.ts +0 -51
- package/src/client/test/ts-client.issue-98.test.ts +0 -55
- package/src/client/test/ts-client.issues.test.ts +0 -52
- package/src/client/test/ts-client.overrides.spec.ts +0 -74
- package/src/client/test/ts-client.sg721.spec.ts +0 -46
- package/src/client/test/ts-client.spec.ts +0 -166
- package/src/client/test/ts-client.vectis.spec.ts +0 -97
- package/src/client/test/ts-client.wager.spec.ts +0 -63
- package/src/context/context.ts +0 -229
- package/src/context/imports.ts +0 -195
- package/src/context/index.ts +0 -2
- package/src/message-builder/__snapshots__/message-builder.spec.ts.snap +0 -270
- package/src/message-builder/message-builder.spec.ts +0 -24
- package/src/message-builder/message-builder.ts +0 -119
- package/src/message-composer/__snapshots__/message-composer.spec.ts.snap +0 -331
- package/src/message-composer/index.ts +0 -1
- package/src/message-composer/message-composer.spec.ts +0 -46
- package/src/message-composer/message-composer.ts +0 -262
- package/src/provider/__snapshots__/provider.spec.ts.snap +0 -49
- package/src/provider/index.ts +0 -1
- package/src/provider/provider.spec.ts +0 -81
- package/src/provider/provider.ts +0 -237
- package/src/react-query/__snapshots__/react-query.spec.ts.snap +0 -1359
- package/src/react-query/index.ts +0 -1
- package/src/react-query/react-query.spec.ts +0 -116
- package/src/react-query/react-query.ts +0 -1072
- package/src/recoil/__snapshots__/recoil.spec.ts.snap +0 -203
- package/src/recoil/index.ts +0 -1
- package/src/recoil/recoil.spec.ts +0 -38
- package/src/recoil/recoil.ts +0 -307
- package/src/types.ts +0 -44
- package/src/utils/__snapshots__/babel.spec.ts.snap +0 -75
- package/src/utils/babel.spec.ts +0 -511
- package/src/utils/babel.ts +0 -352
- package/src/utils/constants.ts +0 -37
- package/src/utils/ref.ts +0 -6
- package/src/utils/types.ts +0 -478
- package/types/types.d.ts +0 -41
- /package/{types/client → client}/index.d.ts +0 -0
- /package/{types/context → context}/index.d.ts +0 -0
- /package/{src/message-builder/index.ts → esm/message-builder/index.js} +0 -0
- /package/{types/message-composer/index.d.ts → esm/message-composer/index.js} +0 -0
- /package/{types/provider/index.d.ts → esm/provider/index.js} +0 -0
- /package/{types/react-query/index.d.ts → esm/react-query/index.js} +0 -0
- /package/{types/recoil/index.d.ts → esm/recoil/index.js} +0 -0
- /package/{src/utils/index.ts → esm/utils/index.js} +0 -0
- /package/{types/message-builder → message-builder}/index.d.ts +0 -0
- /package/{types/provider → provider}/provider.d.ts +0 -0
- /package/{types/utils → utils}/constants.d.ts +0 -0
- /package/{types/utils → utils}/index.d.ts +0 -0
package/utils/types.js
ADDED
@@ -0,0 +1,379 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
26
|
+
exports.createTypedObjectParams = exports.getParamsTypeAnnotation = exports.getPropertySignatureFromProp = exports.getPropertyType = exports.getType = exports.getTypeInfo = exports.detectType = exports.getTypeOrRef = exports.getTypeFromRef = exports.getResponseType = void 0;
|
27
|
+
const t = __importStar(require("@babel/types"));
|
28
|
+
const case_1 = require("case");
|
29
|
+
const babel_1 = require("./babel");
|
30
|
+
function getResponseType(context, underscoreName) {
|
31
|
+
const methodName = (0, case_1.camel)(underscoreName);
|
32
|
+
return (0, case_1.pascal)(context.contract?.responses?.[underscoreName]?.title
|
33
|
+
??
|
34
|
+
// after v1.1 is adopted, we can deprecate this and require the above response
|
35
|
+
`${methodName}Response`);
|
36
|
+
}
|
37
|
+
exports.getResponseType = getResponseType;
|
38
|
+
;
|
39
|
+
const getTypeStrFromRef = ($ref) => {
|
40
|
+
if ($ref?.startsWith('#/definitions/')) {
|
41
|
+
return $ref.replace('#/definitions/', '');
|
42
|
+
}
|
43
|
+
throw new Error('what is $ref: ' + $ref);
|
44
|
+
};
|
45
|
+
const getTypeFromRef = ($ref) => {
|
46
|
+
return t.tsTypeReference(t.identifier(getTypeStrFromRef($ref)));
|
47
|
+
};
|
48
|
+
exports.getTypeFromRef = getTypeFromRef;
|
49
|
+
const getArrayTypeFromRef = ($ref) => {
|
50
|
+
return t.tsArrayType((0, exports.getTypeFromRef)($ref));
|
51
|
+
};
|
52
|
+
const getTypeOrRef = (obj) => {
|
53
|
+
if (obj.$ref) {
|
54
|
+
return (0, exports.getTypeFromRef)(obj.$ref);
|
55
|
+
}
|
56
|
+
else if (typeof obj.type === 'string') {
|
57
|
+
return (0, exports.getType)(obj.type);
|
58
|
+
}
|
59
|
+
else if (Array.isArray(obj.type)) {
|
60
|
+
// Handle array of types by creating a union type
|
61
|
+
const types = obj.type.map(t => (0, exports.getType)(t));
|
62
|
+
return t.tsUnionType(types);
|
63
|
+
}
|
64
|
+
else {
|
65
|
+
throw new Error('Type definition not supported or missing: ' + JSON.stringify(obj));
|
66
|
+
}
|
67
|
+
};
|
68
|
+
exports.getTypeOrRef = getTypeOrRef;
|
69
|
+
const getArrayTypeFromItems = (context, items) => {
|
70
|
+
if (Array.isArray(items)) {
|
71
|
+
// if (context.options.types.itemsUseTuples === true) {
|
72
|
+
// Using the modified method with tsTupleType
|
73
|
+
// return t.tsArrayType(
|
74
|
+
// t.tsTupleType(items.map(item => getTypeOrRef(item)))
|
75
|
+
// );
|
76
|
+
// } else {
|
77
|
+
// Using the original method with nested arrays
|
78
|
+
if (items.length > 0 && items[0].type === 'array') {
|
79
|
+
return getArrayTypeFromItems(context, items[0]);
|
80
|
+
}
|
81
|
+
return items.length > 0 ? t.tsArrayType(t.tsArrayType((0, exports.getTypeOrRef)(items[0]))) : t.tsArrayType(t.tsArrayType(t.tsAnyKeyword()));
|
82
|
+
// }
|
83
|
+
}
|
84
|
+
else {
|
85
|
+
const detect = (0, exports.detectType)(items.type);
|
86
|
+
if (detect.type === 'array') {
|
87
|
+
if (Array.isArray(items.items)) {
|
88
|
+
return t.tsArrayType(t.tsArrayType((0, exports.getTypeOrRef)(items.items[0])));
|
89
|
+
}
|
90
|
+
else if (items.items) {
|
91
|
+
return t.tsArrayType(getArrayTypeFromItems(context, items.items));
|
92
|
+
}
|
93
|
+
else {
|
94
|
+
// Handle the case where items.items is undefined for array types
|
95
|
+
return t.tsArrayType(t.tsAnyKeyword());
|
96
|
+
}
|
97
|
+
}
|
98
|
+
return t.tsArrayType((0, exports.getType)(detect.type));
|
99
|
+
}
|
100
|
+
};
|
101
|
+
const detectType = (type) => {
|
102
|
+
let optional = false;
|
103
|
+
let theType = '';
|
104
|
+
if (Array.isArray(type)) {
|
105
|
+
if (type.length !== 2) {
|
106
|
+
throw new Error('[getType(array length)] case not handled by transpiler. contact maintainers.');
|
107
|
+
}
|
108
|
+
const [nullableType, nullType] = type;
|
109
|
+
if (nullType !== 'null') {
|
110
|
+
throw new Error('[getType(null)] case not handled by transpiler. contact maintainers.');
|
111
|
+
}
|
112
|
+
theType = nullableType;
|
113
|
+
optional = true;
|
114
|
+
}
|
115
|
+
else {
|
116
|
+
theType = type;
|
117
|
+
}
|
118
|
+
return {
|
119
|
+
type: theType,
|
120
|
+
optional
|
121
|
+
};
|
122
|
+
};
|
123
|
+
exports.detectType = detectType;
|
124
|
+
const getTypeInfo = (context, info) => {
|
125
|
+
let type = undefined;
|
126
|
+
let optional = undefined;
|
127
|
+
// Handle nullable types using 'anyOf' schema
|
128
|
+
if (Array.isArray(info.anyOf)) {
|
129
|
+
if (info.anyOf.length !== 2) {
|
130
|
+
throw new Error('case not handled by transpiler. contact maintainers.');
|
131
|
+
}
|
132
|
+
const [nullableType, nullType] = info.anyOf;
|
133
|
+
if (nullType?.type !== 'null') {
|
134
|
+
throw new Error('[nullableType.type]: case not handled by transpiler. contact maintainers.');
|
135
|
+
}
|
136
|
+
if (!nullableType?.$ref) {
|
137
|
+
if (nullableType.title) {
|
138
|
+
type = t.tsTypeReference(t.identifier(nullableType.title));
|
139
|
+
}
|
140
|
+
else {
|
141
|
+
throw new Error('[nullableType.title] case not handled by transpiler. contact maintainers.');
|
142
|
+
}
|
143
|
+
}
|
144
|
+
else {
|
145
|
+
type = (0, exports.getTypeFromRef)(nullableType.$ref);
|
146
|
+
}
|
147
|
+
optional = true;
|
148
|
+
}
|
149
|
+
else if (typeof info.type === 'string') {
|
150
|
+
// Process type when it's explicitly defined
|
151
|
+
if (info.type === 'array') {
|
152
|
+
if (typeof info.items === 'object' && !Array.isArray(info.items)) {
|
153
|
+
if (info.items.$ref) {
|
154
|
+
type = getArrayTypeFromRef(info.items.$ref);
|
155
|
+
}
|
156
|
+
else if (info.items.title) {
|
157
|
+
type = t.tsArrayType(t.tsTypeReference(t.identifier(info.items.title)));
|
158
|
+
}
|
159
|
+
else if (info.items.type) {
|
160
|
+
type = getArrayTypeFromItems(context, info.items);
|
161
|
+
}
|
162
|
+
else {
|
163
|
+
throw new Error('[info.items] case not handled by transpiler. contact maintainers.');
|
164
|
+
}
|
165
|
+
// type = getArrayTypeFromItems(context, info.items);
|
166
|
+
}
|
167
|
+
else {
|
168
|
+
if (Array.isArray(info.items)) {
|
169
|
+
type = getArrayTypeFromItems(context, info.items);
|
170
|
+
}
|
171
|
+
else {
|
172
|
+
throw new Error('[info.items] case not handled by transpiler. contact maintainers.');
|
173
|
+
}
|
174
|
+
}
|
175
|
+
}
|
176
|
+
else {
|
177
|
+
const detect = (0, exports.detectType)(info.type);
|
178
|
+
type = (0, exports.getType)(detect.type);
|
179
|
+
optional = detect.optional;
|
180
|
+
}
|
181
|
+
}
|
182
|
+
else if (Array.isArray(info.type)) {
|
183
|
+
// Handle multiple types, typically nullable types
|
184
|
+
if (info.type.length !== 2) {
|
185
|
+
throw new Error('please report this to maintainers (field type): ' + JSON.stringify(info, null, 2));
|
186
|
+
}
|
187
|
+
const [nullableType, nullType] = info.type;
|
188
|
+
if (nullType !== 'null') {
|
189
|
+
throw new Error('please report this to maintainers (field type): ' + JSON.stringify(info, null, 2));
|
190
|
+
}
|
191
|
+
if (nullableType === 'array' && typeof info.items === 'object' && !Array.isArray(info.items)) {
|
192
|
+
if (info.items.type) {
|
193
|
+
const detect = (0, exports.detectType)(info.items.type);
|
194
|
+
if (detect.type === 'array') {
|
195
|
+
type = t.tsArrayType(getArrayTypeFromItems(context, info.items));
|
196
|
+
}
|
197
|
+
else {
|
198
|
+
type = t.tsArrayType((0, exports.getType)(detect.type));
|
199
|
+
}
|
200
|
+
optional = detect.optional;
|
201
|
+
}
|
202
|
+
else if (info.items.$ref) {
|
203
|
+
type = getArrayTypeFromRef(info.items.$ref);
|
204
|
+
}
|
205
|
+
else if (info.items.type) {
|
206
|
+
type = getArrayTypeFromItems(context, info.items);
|
207
|
+
}
|
208
|
+
else {
|
209
|
+
throw new Error('[info.items] case not handled by transpiler. contact maintainers.');
|
210
|
+
}
|
211
|
+
}
|
212
|
+
else {
|
213
|
+
const detect = (0, exports.detectType)(nullableType);
|
214
|
+
optional = detect.optional;
|
215
|
+
if (detect.type === 'array') {
|
216
|
+
type = getArrayTypeFromItems(context, info.items);
|
217
|
+
}
|
218
|
+
else {
|
219
|
+
type = (0, exports.getType)(detect.type);
|
220
|
+
}
|
221
|
+
}
|
222
|
+
optional = true; // Ensure optional is set for nullable types
|
223
|
+
}
|
224
|
+
return {
|
225
|
+
type,
|
226
|
+
optional
|
227
|
+
};
|
228
|
+
};
|
229
|
+
exports.getTypeInfo = getTypeInfo;
|
230
|
+
const getType = (type) => {
|
231
|
+
switch (type) {
|
232
|
+
case 'string':
|
233
|
+
return t.tsStringKeyword();
|
234
|
+
case 'boolean':
|
235
|
+
return t.tSBooleanKeyword();
|
236
|
+
case 'integer':
|
237
|
+
return t.tsNumberKeyword();
|
238
|
+
case 'null':
|
239
|
+
return t.tsNullKeyword();
|
240
|
+
case 'number':
|
241
|
+
return t.tsNumberKeyword();
|
242
|
+
default:
|
243
|
+
throw new Error('contact maintainers [unknown type]: ' + type);
|
244
|
+
}
|
245
|
+
};
|
246
|
+
exports.getType = getType;
|
247
|
+
const getPropertyType = (context, schema, prop) => {
|
248
|
+
const props = schema.properties ?? {};
|
249
|
+
let info = props[prop];
|
250
|
+
let type = null;
|
251
|
+
let optional = !schema.required?.includes(prop);
|
252
|
+
if (info.allOf && info.allOf.length === 1) {
|
253
|
+
info = info.allOf[0];
|
254
|
+
}
|
255
|
+
if (typeof info.$ref === 'string') {
|
256
|
+
type = (0, exports.getTypeFromRef)(info.$ref);
|
257
|
+
}
|
258
|
+
const typeInfo = (0, exports.getTypeInfo)(context, info);
|
259
|
+
if (typeof typeInfo.optional !== 'undefined') {
|
260
|
+
optional = typeInfo.optional;
|
261
|
+
}
|
262
|
+
if (typeof typeInfo.type !== 'undefined') {
|
263
|
+
type = typeInfo.type;
|
264
|
+
}
|
265
|
+
if (!type) {
|
266
|
+
throw new Error('cannot find type for ' + JSON.stringify(info));
|
267
|
+
}
|
268
|
+
if (schema.required?.includes(prop)) {
|
269
|
+
optional = false;
|
270
|
+
}
|
271
|
+
return { type, optional };
|
272
|
+
};
|
273
|
+
exports.getPropertyType = getPropertyType;
|
274
|
+
function getPropertySignatureFromProp(context, jsonschema, prop, camelize) {
|
275
|
+
if (jsonschema.properties[prop].type === 'object') {
|
276
|
+
if (jsonschema.properties[prop].title) {
|
277
|
+
return (0, babel_1.propertySignature)(camelize ? (0, case_1.camel)(prop) : prop, t.tsTypeAnnotation(t.tsTypeReference(t.identifier(jsonschema.properties[prop].title))));
|
278
|
+
}
|
279
|
+
else {
|
280
|
+
throw new Error('getPropertySignatureFromProp() contact maintainer');
|
281
|
+
}
|
282
|
+
}
|
283
|
+
if (Array.isArray(jsonschema.properties[prop].allOf)) {
|
284
|
+
const isOptional = !jsonschema.required?.includes(prop);
|
285
|
+
const unionTypes = jsonschema.properties[prop].allOf.map(el => {
|
286
|
+
if (el.title)
|
287
|
+
return el.title;
|
288
|
+
if (el.$ref)
|
289
|
+
return getTypeStrFromRef(el.$ref);
|
290
|
+
return el.type;
|
291
|
+
}).filter(a => typeof a === 'string');
|
292
|
+
// ONLY SUPPORT string types for now!
|
293
|
+
// e.g. NOT supporting nullable types or type: string[] yet
|
294
|
+
// @ts-ignore:next-line
|
295
|
+
const uniqUnionTypes = [...new Set(unionTypes)];
|
296
|
+
if (uniqUnionTypes.length === 1) {
|
297
|
+
return (0, babel_1.propertySignature)(camelize ? (0, case_1.camel)(prop) : prop, t.tsTypeAnnotation(t.tsTypeReference(t.identifier(uniqUnionTypes[0]))), isOptional);
|
298
|
+
}
|
299
|
+
else {
|
300
|
+
return (0, babel_1.propertySignature)(camelize ? (0, case_1.camel)(prop) : prop, t.tsTypeAnnotation(t.tsUnionType(uniqUnionTypes.map(typ => t.tsTypeReference(t.identifier(typ))))), isOptional);
|
301
|
+
}
|
302
|
+
}
|
303
|
+
else if (Array.isArray(jsonschema.properties[prop].oneOf)) {
|
304
|
+
const isOptional = !jsonschema.required?.includes(prop);
|
305
|
+
const unionTypes = jsonschema.properties[prop].oneOf.map(el => {
|
306
|
+
if (el.title)
|
307
|
+
return el.title;
|
308
|
+
if (el.$ref)
|
309
|
+
return getTypeStrFromRef(el.$ref);
|
310
|
+
return el.type;
|
311
|
+
}).filter(a => typeof a === 'string');
|
312
|
+
// ONLY SUPPORT string types for now!
|
313
|
+
// e.g. NOT supporting nullable types or type: string[] yet
|
314
|
+
const uniqUnionTypes = [...new Set(unionTypes)];
|
315
|
+
if (uniqUnionTypes.length === 1) {
|
316
|
+
return (0, babel_1.propertySignature)(camelize ? (0, case_1.camel)(prop) : prop, t.tsTypeAnnotation(t.tsTypeReference(t.identifier(uniqUnionTypes[0]))), isOptional);
|
317
|
+
}
|
318
|
+
else {
|
319
|
+
return (0, babel_1.propertySignature)(camelize ? (0, case_1.camel)(prop) : prop, t.tsTypeAnnotation(t.tsUnionType(uniqUnionTypes.map(typ => t.tsTypeReference(t.identifier(typ))))), isOptional);
|
320
|
+
}
|
321
|
+
}
|
322
|
+
try {
|
323
|
+
(0, exports.getPropertyType)(context, jsonschema, prop);
|
324
|
+
}
|
325
|
+
catch (e) {
|
326
|
+
console.log(e);
|
327
|
+
console.log(JSON.stringify(jsonschema, null, 2), prop);
|
328
|
+
}
|
329
|
+
const { type, optional } = (0, exports.getPropertyType)(context, jsonschema, prop);
|
330
|
+
return (0, babel_1.propertySignature)(camelize ? (0, case_1.camel)(prop) : prop, t.tsTypeAnnotation(type), optional);
|
331
|
+
}
|
332
|
+
exports.getPropertySignatureFromProp = getPropertySignatureFromProp;
|
333
|
+
const getParamsTypeAnnotation = (context, jsonschema, camelize = true) => {
|
334
|
+
const keys = Object.keys(jsonschema.properties ?? {});
|
335
|
+
if (!keys.length && jsonschema.$ref) {
|
336
|
+
return t.tsTypeAnnotation((0, exports.getTypeFromRef)(jsonschema.$ref));
|
337
|
+
}
|
338
|
+
if (!keys.length)
|
339
|
+
return undefined;
|
340
|
+
const typedParams = keys.map(prop => getPropertySignatureFromProp(context, jsonschema, prop, camelize));
|
341
|
+
return t.tsTypeAnnotation(t.tsTypeLiteral(
|
342
|
+
// @ts-ignore:next-line
|
343
|
+
[
|
344
|
+
...typedParams
|
345
|
+
]));
|
346
|
+
};
|
347
|
+
exports.getParamsTypeAnnotation = getParamsTypeAnnotation;
|
348
|
+
const createTypedObjectParams = (context, jsonschema, camelize = true) => {
|
349
|
+
const keys = Object.keys(jsonschema.properties ?? {});
|
350
|
+
if (!keys.length) {
|
351
|
+
// is there a ref?
|
352
|
+
if (jsonschema.$ref) {
|
353
|
+
const obj = context.refLookup(jsonschema.$ref);
|
354
|
+
// If there is a oneOf, then we need to create a type for it
|
355
|
+
if (obj?.oneOf) {
|
356
|
+
// the actual type of the ref
|
357
|
+
const refType = jsonschema.$ref.split('/').pop();
|
358
|
+
const refName = (0, case_1.camel)(refType);
|
359
|
+
const id = t.identifier(refName);
|
360
|
+
id.typeAnnotation = t.tsTypeAnnotation(t.tsTypeReference(t.identifier(refType)));
|
361
|
+
return id;
|
362
|
+
}
|
363
|
+
else if (obj) {
|
364
|
+
return (0, exports.createTypedObjectParams)(context, obj, camelize);
|
365
|
+
}
|
366
|
+
}
|
367
|
+
// no results...
|
368
|
+
return;
|
369
|
+
}
|
370
|
+
const params = keys.map(prop => {
|
371
|
+
return t.objectProperty(camelize ? t.identifier((0, case_1.camel)(prop)) : t.identifier(prop), camelize ? t.identifier((0, case_1.camel)(prop)) : t.identifier(prop), false, true);
|
372
|
+
});
|
373
|
+
const obj = t.objectPattern([
|
374
|
+
...params
|
375
|
+
]);
|
376
|
+
obj.typeAnnotation = (0, exports.getParamsTypeAnnotation)(context, jsonschema, camelize);
|
377
|
+
return obj;
|
378
|
+
};
|
379
|
+
exports.createTypedObjectParams = createTypedObjectParams;
|
package/main/client/client.js
DELETED
@@ -1,196 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
6
|
-
value: true
|
7
|
-
});
|
8
|
-
exports.getWasmMethodArgs = exports.createWasmQueryMethod = exports.createWasmExecMethod = exports.createTypeOrInterface = exports.createTypeInterface = exports.createQueryInterface = exports.createQueryClass = exports.createPropertyFunctionWithObjectParamsForExec = exports.createPropertyFunctionWithObjectParams = exports.createExecuteInterface = exports.createExecuteClass = exports.CONSTANT_EXEC_PARAMS = void 0;
|
9
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
10
|
-
var t = _interopRequireWildcard(require("@babel/types"));
|
11
|
-
var _case = require("case");
|
12
|
-
var _utils = require("../utils");
|
13
|
-
var _types2 = require("../utils/types");
|
14
|
-
var _babel = require("../utils/babel");
|
15
|
-
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
16
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
17
|
-
var CONSTANT_EXEC_PARAMS = [t.assignmentPattern((0, _babel.identifier)('fee', t.tsTypeAnnotation(t.tsUnionType([t.tSNumberKeyword(), t.tsTypeReference(t.identifier('StdFee')), t.tsLiteralType(t.stringLiteral('auto'))])), false), t.stringLiteral('auto')), (0, _babel.identifier)('memo', t.tsTypeAnnotation(t.tsStringKeyword()), true), _utils.OPTIONAL_FUNDS_PARAM];
|
18
|
-
exports.CONSTANT_EXEC_PARAMS = CONSTANT_EXEC_PARAMS;
|
19
|
-
var createWasmQueryMethod = function createWasmQueryMethod(context, jsonschema) {
|
20
|
-
var underscoreName = Object.keys(jsonschema.properties)[0];
|
21
|
-
var methodName = (0, _case.camel)(underscoreName);
|
22
|
-
var responseType = (0, _types2.getResponseType)(context, underscoreName);
|
23
|
-
var param = (0, _types2.createTypedObjectParams)(context, jsonschema.properties[underscoreName]);
|
24
|
-
var args = getWasmMethodArgs(context, jsonschema.properties[underscoreName]);
|
25
|
-
var msgAction = t.identifier(underscoreName);
|
26
|
-
// If the param is an identifier, we can just use it as is
|
27
|
-
var msgActionValue = (param === null || param === void 0 ? void 0 : param.type) === 'Identifier' ? t.identifier(param.name) : t.objectExpression(args);
|
28
|
-
return t.classProperty(t.identifier(methodName), (0, _utils.arrowFunctionExpression)(param ? [param] : [], t.blockStatement([t.returnStatement(t.callExpression(t.memberExpression(t.memberExpression(t.thisExpression(), t.identifier('client')), t.identifier('queryContractSmart')), [t.memberExpression(t.thisExpression(), t.identifier('contractAddress')), t.objectExpression([t.objectProperty(msgAction, msgActionValue)])]))]), t.tsTypeAnnotation(t.tsTypeReference(t.identifier('Promise'), t.tsTypeParameterInstantiation([t.tSTypeReference(t.identifier(responseType))]))), true));
|
29
|
-
};
|
30
|
-
exports.createWasmQueryMethod = createWasmQueryMethod;
|
31
|
-
var createQueryClass = function createQueryClass(context, className, implementsClassName, queryMsg) {
|
32
|
-
context.addUtil('CosmWasmClient');
|
33
|
-
var propertyNames = (0, _utils.getMessageProperties)(queryMsg).map(function (method) {
|
34
|
-
var _Object$keys;
|
35
|
-
return (_Object$keys = Object.keys(method.properties)) === null || _Object$keys === void 0 ? void 0 : _Object$keys[0];
|
36
|
-
}).filter(Boolean);
|
37
|
-
var bindings = propertyNames.map(_case.camel).map(_utils.bindMethod);
|
38
|
-
var methods = (0, _utils.getMessageProperties)(queryMsg).map(function (schema) {
|
39
|
-
return createWasmQueryMethod(context, schema);
|
40
|
-
});
|
41
|
-
return t.exportNamedDeclaration((0, _utils.classDeclaration)(className, [
|
42
|
-
// client
|
43
|
-
(0, _utils.classProperty)('client', t.tsTypeAnnotation(t.tsTypeReference(t.identifier('CosmWasmClient')))),
|
44
|
-
// contractAddress
|
45
|
-
(0, _utils.classProperty)('contractAddress', t.tsTypeAnnotation(t.tsStringKeyword())),
|
46
|
-
// constructor
|
47
|
-
t.classMethod('constructor', t.identifier('constructor'), [(0, _utils.typedIdentifier)('client', t.tsTypeAnnotation(t.tsTypeReference(t.identifier('CosmWasmClient')))), (0, _utils.typedIdentifier)('contractAddress', t.tsTypeAnnotation(t.tsStringKeyword()))], t.blockStatement([
|
48
|
-
// client/contract set
|
49
|
-
t.expressionStatement(t.assignmentExpression('=', t.memberExpression(t.thisExpression(), t.identifier('client')), t.identifier('client'))), t.expressionStatement(t.assignmentExpression('=', t.memberExpression(t.thisExpression(), t.identifier('contractAddress')), t.identifier('contractAddress')))].concat((0, _toConsumableArray2["default"])(bindings))))].concat((0, _toConsumableArray2["default"])(methods)), [t.tSExpressionWithTypeArguments(t.identifier(implementsClassName))]));
|
50
|
-
};
|
51
|
-
exports.createQueryClass = createQueryClass;
|
52
|
-
var getWasmMethodArgs = function getWasmMethodArgs(context, jsonschema) {
|
53
|
-
var _jsonschema$propertie;
|
54
|
-
var keys = Object.keys((_jsonschema$propertie = jsonschema.properties) !== null && _jsonschema$propertie !== void 0 ? _jsonschema$propertie : {});
|
55
|
-
|
56
|
-
// only 1 degree $ref-lookup
|
57
|
-
if (!keys.length && jsonschema.$ref) {
|
58
|
-
var obj = context.refLookup(jsonschema.$ref);
|
59
|
-
// properties
|
60
|
-
if (obj) {
|
61
|
-
var _obj$properties;
|
62
|
-
keys = Object.keys((_obj$properties = obj.properties) !== null && _obj$properties !== void 0 ? _obj$properties : {});
|
63
|
-
}
|
64
|
-
|
65
|
-
// tuple struct or otherwise, use the name of the reference
|
66
|
-
if (!keys.length && obj !== null && obj !== void 0 && obj.oneOf) {
|
67
|
-
// TODO????? ADAIR
|
68
|
-
}
|
69
|
-
}
|
70
|
-
var args = keys.map(function (prop) {
|
71
|
-
return t.objectProperty(t.identifier(prop), t.identifier((0, _case.camel)(prop)), false, prop === (0, _case.camel)(prop));
|
72
|
-
});
|
73
|
-
return args;
|
74
|
-
};
|
75
|
-
exports.getWasmMethodArgs = getWasmMethodArgs;
|
76
|
-
var createWasmExecMethod = function createWasmExecMethod(context, jsonschema) {
|
77
|
-
context.addUtil('ExecuteResult');
|
78
|
-
context.addUtil('StdFee');
|
79
|
-
context.addUtil('Coin');
|
80
|
-
var underscoreName = Object.keys(jsonschema.properties)[0];
|
81
|
-
var methodName = (0, _case.camel)(underscoreName);
|
82
|
-
var param = (0, _types2.createTypedObjectParams)(context, jsonschema.properties[underscoreName]);
|
83
|
-
var args = getWasmMethodArgs(context, jsonschema.properties[underscoreName]);
|
84
|
-
var msgAction = t.identifier(underscoreName);
|
85
|
-
// If the param is an identifier, we can just use it as is
|
86
|
-
var msgActionValue = (param === null || param === void 0 ? void 0 : param.type) === 'Identifier' ? t.identifier(param.name) : t.objectExpression(args);
|
87
|
-
return t.classProperty(t.identifier(methodName), (0, _utils.arrowFunctionExpression)(param ? [
|
88
|
-
// props
|
89
|
-
param].concat(CONSTANT_EXEC_PARAMS) : CONSTANT_EXEC_PARAMS, t.blockStatement([t.returnStatement(t.awaitExpression(t.callExpression(t.memberExpression(t.memberExpression(t.thisExpression(), t.identifier('client')), t.identifier('execute')), [t.memberExpression(t.thisExpression(), t.identifier('sender')), t.memberExpression(t.thisExpression(), t.identifier('contractAddress')), t.objectExpression([t.objectProperty(msgAction, msgActionValue)]), t.identifier('fee'), t.identifier('memo'), t.identifier('_funds')])))]),
|
90
|
-
// return type
|
91
|
-
t.tsTypeAnnotation(t.tsTypeReference(t.identifier('Promise'), t.tsTypeParameterInstantiation([t.tSTypeReference(t.identifier('ExecuteResult'))]))), true));
|
92
|
-
};
|
93
|
-
exports.createWasmExecMethod = createWasmExecMethod;
|
94
|
-
var createExecuteClass = function createExecuteClass(context, className, implementsClassName, extendsClassName, execMsg) {
|
95
|
-
context.addUtil('SigningCosmWasmClient');
|
96
|
-
var propertyNames = (0, _utils.getMessageProperties)(execMsg).map(function (method) {
|
97
|
-
var _Object$keys2;
|
98
|
-
return (_Object$keys2 = Object.keys(method.properties)) === null || _Object$keys2 === void 0 ? void 0 : _Object$keys2[0];
|
99
|
-
}).filter(Boolean);
|
100
|
-
var bindings = propertyNames.map(_case.camel).map(_utils.bindMethod);
|
101
|
-
var methods = (0, _utils.getMessageProperties)(execMsg).map(function (schema) {
|
102
|
-
return createWasmExecMethod(context, schema);
|
103
|
-
});
|
104
|
-
var blockStmt = [];
|
105
|
-
if (extendsClassName) {
|
106
|
-
blockStmt.push(
|
107
|
-
// super()
|
108
|
-
t.expressionStatement(t.callExpression(t["super"](), [t.identifier('client'), t.identifier('contractAddress')])));
|
109
|
-
}
|
110
|
-
[].push.apply(blockStmt, [
|
111
|
-
// client/contract set
|
112
|
-
t.expressionStatement(t.assignmentExpression('=', t.memberExpression(t.thisExpression(), t.identifier('client')), t.identifier('client'))), t.expressionStatement(t.assignmentExpression('=', t.memberExpression(t.thisExpression(), t.identifier('sender')), t.identifier('sender'))), t.expressionStatement(t.assignmentExpression('=', t.memberExpression(t.thisExpression(), t.identifier('contractAddress')), t.identifier('contractAddress')))].concat((0, _toConsumableArray2["default"])(bindings)));
|
113
|
-
var noImplicitOverride = context.options.client.noImplicitOverride && extendsClassName && context.options.client.execExtendsQuery;
|
114
|
-
return t.exportNamedDeclaration((0, _utils.classDeclaration)(className, [
|
115
|
-
// client
|
116
|
-
(0, _utils.classProperty)('client', t.tsTypeAnnotation(t.tsTypeReference(t.identifier('SigningCosmWasmClient'))), false, false, noImplicitOverride),
|
117
|
-
// sender
|
118
|
-
(0, _utils.classProperty)('sender', t.tsTypeAnnotation(t.tsStringKeyword())),
|
119
|
-
// contractAddress
|
120
|
-
(0, _utils.classProperty)('contractAddress', t.tsTypeAnnotation(t.tsStringKeyword()), false, false, noImplicitOverride),
|
121
|
-
// constructor
|
122
|
-
t.classMethod('constructor', t.identifier('constructor'), [(0, _utils.typedIdentifier)('client', t.tsTypeAnnotation(t.tsTypeReference(t.identifier('SigningCosmWasmClient')))), (0, _utils.typedIdentifier)('sender', t.tsTypeAnnotation(t.tsStringKeyword())), (0, _utils.typedIdentifier)('contractAddress', t.tsTypeAnnotation(t.tsStringKeyword()))], t.blockStatement(blockStmt))].concat((0, _toConsumableArray2["default"])(methods)), [t.tSExpressionWithTypeArguments(t.identifier(implementsClassName))], extendsClassName ? t.identifier(extendsClassName) : null));
|
123
|
-
};
|
124
|
-
exports.createExecuteClass = createExecuteClass;
|
125
|
-
var createExecuteInterface = function createExecuteInterface(context, className, extendsClassName, execMsg) {
|
126
|
-
var methods = (0, _utils.getMessageProperties)(execMsg).map(function (jsonschema) {
|
127
|
-
var underscoreName = Object.keys(jsonschema.properties)[0];
|
128
|
-
var methodName = (0, _case.camel)(underscoreName);
|
129
|
-
return createPropertyFunctionWithObjectParamsForExec(context, methodName, 'ExecuteResult', jsonschema.properties[underscoreName]);
|
130
|
-
});
|
131
|
-
var extendsAst = extendsClassName ? [t.tSExpressionWithTypeArguments(t.identifier(extendsClassName))] : [];
|
132
|
-
return t.exportNamedDeclaration(t.tsInterfaceDeclaration(t.identifier(className), null, extendsAst, t.tSInterfaceBody([
|
133
|
-
// contract address
|
134
|
-
t.tSPropertySignature(t.identifier('contractAddress'), t.tsTypeAnnotation(t.tsStringKeyword())),
|
135
|
-
// contract address
|
136
|
-
t.tSPropertySignature(t.identifier('sender'), t.tsTypeAnnotation(t.tsStringKeyword()))].concat((0, _toConsumableArray2["default"])(methods)))));
|
137
|
-
};
|
138
|
-
exports.createExecuteInterface = createExecuteInterface;
|
139
|
-
var createPropertyFunctionWithObjectParams = function createPropertyFunctionWithObjectParams(context, methodName, responseType, jsonschema) {
|
140
|
-
var obj = (0, _types2.createTypedObjectParams)(context, jsonschema);
|
141
|
-
var func = {
|
142
|
-
type: 'TSFunctionType',
|
143
|
-
typeAnnotation: (0, _utils.promiseTypeAnnotation)(responseType),
|
144
|
-
parameters: obj ? [obj] : []
|
145
|
-
};
|
146
|
-
return t.tSPropertySignature(t.identifier(methodName), t.tsTypeAnnotation(
|
147
|
-
// @ts-ignore:next-line
|
148
|
-
func));
|
149
|
-
};
|
150
|
-
exports.createPropertyFunctionWithObjectParams = createPropertyFunctionWithObjectParams;
|
151
|
-
var createPropertyFunctionWithObjectParamsForExec = function createPropertyFunctionWithObjectParamsForExec(context, methodName, responseType, jsonschema) {
|
152
|
-
context.addUtil('Coin');
|
153
|
-
var obj = (0, _types2.createTypedObjectParams)(context, jsonschema);
|
154
|
-
var func = {
|
155
|
-
type: 'TSFunctionType',
|
156
|
-
typeAnnotation: (0, _utils.promiseTypeAnnotation)(responseType),
|
157
|
-
parameters: obj ? [obj].concat((0, _toConsumableArray2["default"])(_utils.FIXED_EXECUTE_PARAMS)) : _utils.FIXED_EXECUTE_PARAMS
|
158
|
-
};
|
159
|
-
return t.tSPropertySignature(t.identifier(methodName), t.tsTypeAnnotation(
|
160
|
-
// @ts-ignore:next-line
|
161
|
-
func));
|
162
|
-
};
|
163
|
-
exports.createPropertyFunctionWithObjectParamsForExec = createPropertyFunctionWithObjectParamsForExec;
|
164
|
-
var createQueryInterface = function createQueryInterface(context, className, queryMsg) {
|
165
|
-
var methods = (0, _utils.getMessageProperties)(queryMsg).map(function (jsonschema) {
|
166
|
-
var underscoreName = Object.keys(jsonschema.properties)[0];
|
167
|
-
var methodName = (0, _case.camel)(underscoreName);
|
168
|
-
var responseType = (0, _types2.getResponseType)(context, underscoreName);
|
169
|
-
return createPropertyFunctionWithObjectParams(context, methodName, responseType, jsonschema.properties[underscoreName]);
|
170
|
-
});
|
171
|
-
return t.exportNamedDeclaration(t.tsInterfaceDeclaration(t.identifier(className), null, [], t.tSInterfaceBody([t.tSPropertySignature(t.identifier('contractAddress'), t.tsTypeAnnotation(t.tsStringKeyword()))].concat((0, _toConsumableArray2["default"])(methods)))));
|
172
|
-
};
|
173
|
-
exports.createQueryInterface = createQueryInterface;
|
174
|
-
var createTypeOrInterface = function createTypeOrInterface(context, Type, jsonschema) {
|
175
|
-
var _jsonschema$propertie2;
|
176
|
-
if (jsonschema.type !== 'object') {
|
177
|
-
if (!jsonschema.type) {
|
178
|
-
return t.exportNamedDeclaration(t.tsTypeAliasDeclaration(t.identifier(Type), null, t.tsTypeReference(t.identifier(jsonschema.title))));
|
179
|
-
}
|
180
|
-
return t.exportNamedDeclaration(t.tsTypeAliasDeclaration(t.identifier(Type), null, (0, _types2.getType)(jsonschema.type)));
|
181
|
-
}
|
182
|
-
var props = Object.keys((_jsonschema$propertie2 = jsonschema.properties) !== null && _jsonschema$propertie2 !== void 0 ? _jsonschema$propertie2 : {}).map(function (prop) {
|
183
|
-
var _getPropertyType = (0, _types2.getPropertyType)(context, jsonschema, prop),
|
184
|
-
type = _getPropertyType.type,
|
185
|
-
optional = _getPropertyType.optional;
|
186
|
-
return (0, _babel.propertySignature)((0, _case.camel)(prop), t.tsTypeAnnotation(type), optional);
|
187
|
-
});
|
188
|
-
return t.exportNamedDeclaration(t.tsInterfaceDeclaration(t.identifier(Type), null, [], t.tsInterfaceBody( // @ts-ignore:next-line
|
189
|
-
(0, _toConsumableArray2["default"])(props))));
|
190
|
-
};
|
191
|
-
exports.createTypeOrInterface = createTypeOrInterface;
|
192
|
-
var createTypeInterface = function createTypeInterface(context, jsonschema) {
|
193
|
-
var Type = jsonschema.title;
|
194
|
-
return createTypeOrInterface(context, Type, jsonschema);
|
195
|
-
};
|
196
|
-
exports.createTypeInterface = createTypeInterface;
|
package/main/client/index.js
DELETED
@@ -1,16 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
var _client = require("./client");
|
7
|
-
Object.keys(_client).forEach(function (key) {
|
8
|
-
if (key === "default" || key === "__esModule") return;
|
9
|
-
if (key in exports && exports[key] === _client[key]) return;
|
10
|
-
Object.defineProperty(exports, key, {
|
11
|
-
enumerable: true,
|
12
|
-
get: function get() {
|
13
|
-
return _client[key];
|
14
|
-
}
|
15
|
-
});
|
16
|
-
});
|
@@ -1,28 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
-
var _accountNft = _interopRequireDefault(require("../../../../../__fixtures__/idl-version/accounts-nft/account-nft.json"));
|
5
|
-
var _client = require("../client");
|
6
|
-
var _testUtils = require("../../../test-utils");
|
7
|
-
var message = _accountNft["default"].query;
|
8
|
-
var ctx = (0, _testUtils.makeContext)(message);
|
9
|
-
it('execute_msg_for__empty', function () {
|
10
|
-
(0, _testUtils.expectCode)((0, _client.createTypeInterface)(ctx, message));
|
11
|
-
});
|
12
|
-
it('query classes', function () {
|
13
|
-
(0, _testUtils.expectCode)((0, _client.createQueryClass)(ctx, 'SG721QueryClient', 'SG721ReadOnlyInstance', message));
|
14
|
-
});
|
15
|
-
|
16
|
-
// it('query classes response', () => {
|
17
|
-
// expectCode(createTypeInterface(
|
18
|
-
// ctx,
|
19
|
-
// contract.responses.all_debt_shares
|
20
|
-
// ))
|
21
|
-
// });
|
22
|
-
|
23
|
-
it('execute classes array types', function () {
|
24
|
-
(0, _testUtils.expectCode)((0, _client.createExecuteClass)(ctx, 'SG721Client', 'SG721Instance', null, message));
|
25
|
-
});
|
26
|
-
it('execute interfaces no extends', function () {
|
27
|
-
(0, _testUtils.expectCode)((0, _client.createExecuteInterface)(ctx, 'SG721Instance', null, message));
|
28
|
-
});
|
@@ -1,19 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
-
var _arraysRef = _interopRequireDefault(require("../../../../../__fixtures__/misc/schema/arrays-ref.json"));
|
5
|
-
var _client = require("../client");
|
6
|
-
var _testUtils = require("../../../test-utils");
|
7
|
-
var ctx = (0, _testUtils.makeContext)(_arraysRef["default"]);
|
8
|
-
it('execute_msg_for__empty', function () {
|
9
|
-
(0, _testUtils.expectCode)((0, _client.createTypeInterface)(ctx, _arraysRef["default"]));
|
10
|
-
});
|
11
|
-
it('query classes', function () {
|
12
|
-
(0, _testUtils.expectCode)((0, _client.createQueryClass)(ctx, 'SG721QueryClient', 'SG721ReadOnlyInstance', _arraysRef["default"]));
|
13
|
-
});
|
14
|
-
it('execute classes array types', function () {
|
15
|
-
(0, _testUtils.expectCode)((0, _client.createExecuteClass)(ctx, 'SG721Client', 'SG721Instance', null, _arraysRef["default"]));
|
16
|
-
});
|
17
|
-
it('execute interfaces no extends', function () {
|
18
|
-
(0, _testUtils.expectCode)((0, _client.createExecuteInterface)(ctx, 'SG721Instance', null, _arraysRef["default"]));
|
19
|
-
});
|
@@ -1,26 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
-
var _arrays = _interopRequireDefault(require("../../../../../__fixtures__/misc/schema/arrays.json"));
|
5
|
-
var _client = require("../client");
|
6
|
-
var _testUtils = require("../../../test-utils");
|
7
|
-
var _utils = require("../../utils");
|
8
|
-
var ctx = (0, _testUtils.makeContext)(_arrays["default"]);
|
9
|
-
it('getPropertyType', function () {
|
10
|
-
var ast = (0, _utils.getPropertyType)(ctx, _arrays["default"].oneOf[0].properties.update_edges, 'edges3');
|
11
|
-
(0, _testUtils.expectCode)(ast.type);
|
12
|
-
// printCode(ast.type)
|
13
|
-
});
|
14
|
-
|
15
|
-
it('execute_msg_for__empty', function () {
|
16
|
-
(0, _testUtils.expectCode)((0, _client.createTypeInterface)(ctx, _arrays["default"]));
|
17
|
-
});
|
18
|
-
it('query classes', function () {
|
19
|
-
(0, _testUtils.expectCode)((0, _client.createQueryClass)(ctx, 'SG721QueryClient', 'SG721ReadOnlyInstance', _arrays["default"]));
|
20
|
-
});
|
21
|
-
it('execute classes array types', function () {
|
22
|
-
(0, _testUtils.expectCode)((0, _client.createExecuteClass)(ctx, 'SG721Client', 'SG721Instance', null, _arrays["default"]));
|
23
|
-
});
|
24
|
-
it('execute interfaces no extends', function () {
|
25
|
-
(0, _testUtils.expectCode)((0, _client.createExecuteInterface)(ctx, 'SG721Instance', null, _arrays["default"]));
|
26
|
-
});
|