wowok_agent 0.1.13 → 0.1.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -0
- package/dist/124.index.js +1 -0
- package/dist/account.d.ts +38 -0
- package/dist/account.d.ts.map +1 -0
- package/dist/account.js +273 -0
- package/dist/agent/empty.d.ts +1 -0
- package/dist/agent/empty.d.ts.map +1 -0
- package/dist/agent/src/account.d.ts +38 -0
- package/dist/agent/src/account.d.ts.map +1 -0
- package/dist/agent/src/cache.d.ts +46 -0
- package/dist/agent/src/cache.d.ts.map +1 -0
- package/dist/agent/src/call/arbitration.d.ts +63 -0
- package/dist/agent/src/call/arbitration.d.ts.map +1 -0
- package/dist/agent/src/call/base.d.ts +34 -0
- package/dist/agent/src/call/base.d.ts.map +1 -0
- package/dist/agent/src/call/demand.d.ts +55 -0
- package/dist/agent/src/call/demand.d.ts.map +1 -0
- package/dist/agent/src/call/guard.d.ts +44 -0
- package/dist/agent/src/call/guard.d.ts.map +1 -0
- package/dist/agent/src/call/machine.d.ts +109 -0
- package/dist/agent/src/call/machine.d.ts.map +1 -0
- package/dist/agent/src/call/object_permission.d.ts +13 -0
- package/dist/agent/src/call/object_permission.d.ts.map +1 -0
- package/dist/agent/src/call/permission.d.ts +47 -0
- package/dist/agent/src/call/permission.d.ts.map +1 -0
- package/dist/agent/src/call/personal.d.ts +43 -0
- package/dist/agent/src/call/personal.d.ts.map +1 -0
- package/dist/agent/src/call/repository.d.ts +53 -0
- package/dist/agent/src/call/repository.d.ts.map +1 -0
- package/dist/agent/src/call/service.d.ts +134 -0
- package/dist/agent/src/call/service.d.ts.map +1 -0
- package/dist/agent/src/call/treasury.d.ts +53 -0
- package/dist/agent/src/call/treasury.d.ts.map +1 -0
- package/dist/agent/src/call.d.ts +24 -0
- package/dist/agent/src/call.d.ts.map +1 -0
- package/dist/agent/src/events.d.ts +65 -0
- package/dist/agent/src/events.d.ts.map +1 -0
- package/dist/agent/src/index.d.ts +19 -0
- package/dist/agent/src/index.d.ts.map +1 -0
- package/dist/agent/src/objects.d.ts +308 -0
- package/dist/agent/src/objects.d.ts.map +1 -0
- package/dist/agent/src/permission.d.ts +12 -0
- package/dist/agent/src/permission.d.ts.map +1 -0
- package/dist/agent/src/private_info.d.ts +26 -0
- package/dist/agent/src/private_info.d.ts.map +1 -0
- package/dist/cache.d.ts +46 -0
- package/dist/cache.d.ts.map +1 -0
- package/dist/cache.js +59 -0
- package/dist/call/arbitration.d.ts +63 -0
- package/dist/call/arbitration.d.ts.map +1 -0
- package/dist/call/arbitration.js +182 -0
- package/dist/call/base.d.ts +34 -0
- package/dist/call/base.d.ts.map +1 -0
- package/dist/call/base.js +131 -0
- package/dist/call/demand.d.ts +55 -0
- package/dist/call/demand.d.ts.map +1 -0
- package/dist/call/demand.js +135 -0
- package/dist/call/guard.d.ts +44 -0
- package/dist/call/guard.d.ts.map +1 -0
- package/dist/call/guard.js +244 -0
- package/dist/call/machine.d.ts +109 -0
- package/dist/call/machine.d.ts.map +1 -0
- package/dist/call/machine.js +210 -0
- package/dist/call/object_permission.d.ts +13 -0
- package/dist/call/object_permission.d.ts.map +1 -0
- package/dist/call/object_permission.js +49 -0
- package/dist/call/permission.d.ts +47 -0
- package/dist/call/permission.d.ts.map +1 -0
- package/dist/call/permission.js +95 -0
- package/dist/call/personal.d.ts +43 -0
- package/dist/call/personal.d.ts.map +1 -0
- package/dist/call/personal.js +60 -0
- package/dist/call/repository.d.ts +53 -0
- package/dist/call/repository.d.ts.map +1 -0
- package/dist/call/repository.js +125 -0
- package/dist/call/service.d.ts +134 -0
- package/dist/call/service.d.ts.map +1 -0
- package/dist/call/service.js +340 -0
- package/dist/call/treasury.d.ts +53 -0
- package/dist/call/treasury.d.ts.map +1 -0
- package/dist/call/treasury.js +161 -0
- package/dist/call.d.ts +24 -0
- package/dist/call.d.ts.map +1 -0
- package/dist/call.js +58 -0
- package/dist/empty.d.ts +1 -0
- package/dist/empty.d.ts.map +1 -0
- package/dist/empty.js +1 -0
- package/dist/events.d.ts +65 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +59 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1 -0
- package/dist/objects.d.ts +308 -0
- package/dist/objects.d.ts.map +1 -0
- package/dist/objects.js +448 -0
- package/dist/permission.d.ts +12 -0
- package/dist/permission.d.ts.map +1 -0
- package/dist/permission.js +40 -0
- package/dist/private_info.d.ts +26 -0
- package/dist/private_info.d.ts.map +1 -0
- package/dist/private_info.js +243 -0
- package/dist/src/account.d.ts +38 -0
- package/dist/src/account.d.ts.map +1 -0
- package/dist/src/account.js +273 -0
- package/dist/src/cache.d.ts +46 -0
- package/dist/src/cache.d.ts.map +1 -0
- package/dist/src/cache.js +59 -0
- package/dist/src/call/arbitration.d.ts +63 -0
- package/dist/src/call/arbitration.d.ts.map +1 -0
- package/dist/src/call/arbitration.js +182 -0
- package/dist/src/call/base.d.ts +34 -0
- package/dist/src/call/base.d.ts.map +1 -0
- package/dist/src/call/base.js +131 -0
- package/dist/src/call/demand.d.ts +55 -0
- package/dist/src/call/demand.d.ts.map +1 -0
- package/dist/src/call/demand.js +135 -0
- package/dist/src/call/guard.d.ts +44 -0
- package/dist/src/call/guard.d.ts.map +1 -0
- package/dist/src/call/guard.js +244 -0
- package/dist/src/call/machine.d.ts +109 -0
- package/dist/src/call/machine.d.ts.map +1 -0
- package/dist/src/call/machine.js +210 -0
- package/dist/src/call/object_permission.d.ts +13 -0
- package/dist/src/call/object_permission.d.ts.map +1 -0
- package/dist/src/call/object_permission.js +49 -0
- package/dist/src/call/permission.d.ts +47 -0
- package/dist/src/call/permission.d.ts.map +1 -0
- package/dist/src/call/permission.js +95 -0
- package/dist/src/call/personal.d.ts +43 -0
- package/dist/src/call/personal.d.ts.map +1 -0
- package/dist/src/call/personal.js +60 -0
- package/dist/src/call/repository.d.ts +53 -0
- package/dist/src/call/repository.d.ts.map +1 -0
- package/dist/src/call/repository.js +125 -0
- package/dist/src/call/service.d.ts +134 -0
- package/dist/src/call/service.d.ts.map +1 -0
- package/dist/src/call/service.js +340 -0
- package/dist/src/call/treasury.d.ts +53 -0
- package/dist/src/call/treasury.d.ts.map +1 -0
- package/dist/src/call/treasury.js +161 -0
- package/dist/src/call.d.ts +24 -0
- package/dist/src/call.d.ts.map +1 -0
- package/dist/src/call.js +58 -0
- package/dist/src/events.d.ts +65 -0
- package/dist/src/events.d.ts.map +1 -0
- package/dist/src/events.js +59 -0
- package/dist/src/index.d.ts +19 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +18 -0
- package/dist/src/objects.d.ts +308 -0
- package/dist/src/objects.d.ts.map +1 -0
- package/dist/src/objects.js +448 -0
- package/dist/src/permission.d.ts +12 -0
- package/dist/src/permission.d.ts.map +1 -0
- package/dist/src/permission.js +40 -0
- package/dist/src/private_info.d.ts +26 -0
- package/dist/src/private_info.d.ts.map +1 -0
- package/dist/src/private_info.js +243 -0
- package/dist/webpack.config.d.ts +2 -0
- package/dist/webpack.config.d.ts.map +1 -0
- package/dist/webpack.config.js +17 -0
- package/dist/wowok/src/arbitration.d.ts +63 -0
- package/dist/wowok/src/arbitration.d.ts.map +1 -0
- package/dist/wowok/src/demand.d.ts +26 -0
- package/dist/wowok/src/demand.d.ts.map +1 -0
- package/dist/wowok/src/entity.d.ts +27 -0
- package/dist/wowok/src/entity.d.ts.map +1 -0
- package/dist/wowok/src/exception.d.ts +31 -0
- package/dist/wowok/src/exception.d.ts.map +1 -0
- package/dist/wowok/src/guard.d.ts +79 -0
- package/dist/wowok/src/guard.d.ts.map +1 -0
- package/dist/wowok/src/index.d.ts +35 -0
- package/dist/wowok/src/index.d.ts.map +1 -0
- package/dist/wowok/src/machine.d.ts +67 -0
- package/dist/wowok/src/machine.d.ts.map +1 -0
- package/dist/wowok/src/passport.d.ts +86 -0
- package/dist/wowok/src/passport.d.ts.map +1 -0
- package/dist/wowok/src/payment.d.ts +16 -0
- package/dist/wowok/src/payment.d.ts.map +1 -0
- package/dist/wowok/src/permission.d.ts +150 -0
- package/dist/wowok/src/permission.d.ts.map +1 -0
- package/dist/wowok/src/progress.d.ts +72 -0
- package/dist/wowok/src/progress.d.ts.map +1 -0
- package/dist/wowok/src/protocol.d.ts +226 -0
- package/dist/wowok/src/protocol.d.ts.map +1 -0
- package/dist/wowok/src/repository.d.ts +83 -0
- package/dist/wowok/src/repository.d.ts.map +1 -0
- package/dist/wowok/src/resource.d.ts +35 -0
- package/dist/wowok/src/resource.d.ts.map +1 -0
- package/dist/wowok/src/service.d.ts +138 -0
- package/dist/wowok/src/service.d.ts.map +1 -0
- package/dist/wowok/src/treasury.d.ts +55 -0
- package/dist/wowok/src/treasury.d.ts.map +1 -0
- package/dist/wowok/src/utils.d.ts +93 -0
- package/dist/wowok/src/utils.d.ts.map +1 -0
- package/dist/wowok/src/wowok.d.ts +15 -0
- package/dist/wowok/src/wowok.d.ts.map +1 -0
- package/dist/wowok_agent/empty.d.ts +1 -0
- package/dist/wowok_agent/empty.d.ts.map +1 -0
- package/dist/wowok_agent/src/account.d.ts +38 -0
- package/dist/wowok_agent/src/account.d.ts.map +1 -0
- package/dist/wowok_agent/src/cache.d.ts +46 -0
- package/dist/wowok_agent/src/cache.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/arbitration.d.ts +63 -0
- package/dist/wowok_agent/src/call/arbitration.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/base.d.ts +34 -0
- package/dist/wowok_agent/src/call/base.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/demand.d.ts +55 -0
- package/dist/wowok_agent/src/call/demand.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/guard.d.ts +44 -0
- package/dist/wowok_agent/src/call/guard.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/machine.d.ts +109 -0
- package/dist/wowok_agent/src/call/machine.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/object_permission.d.ts +13 -0
- package/dist/wowok_agent/src/call/object_permission.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/permission.d.ts +47 -0
- package/dist/wowok_agent/src/call/permission.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/personal.d.ts +43 -0
- package/dist/wowok_agent/src/call/personal.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/repository.d.ts +53 -0
- package/dist/wowok_agent/src/call/repository.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/service.d.ts +134 -0
- package/dist/wowok_agent/src/call/service.d.ts.map +1 -0
- package/dist/wowok_agent/src/call/treasury.d.ts +53 -0
- package/dist/wowok_agent/src/call/treasury.d.ts.map +1 -0
- package/dist/wowok_agent/src/call.d.ts +24 -0
- package/dist/wowok_agent/src/call.d.ts.map +1 -0
- package/dist/wowok_agent/src/events.d.ts +65 -0
- package/dist/wowok_agent/src/events.d.ts.map +1 -0
- package/dist/wowok_agent/src/index.d.ts +19 -0
- package/dist/wowok_agent/src/index.d.ts.map +1 -0
- package/dist/wowok_agent/src/objects.d.ts +308 -0
- package/dist/wowok_agent/src/objects.d.ts.map +1 -0
- package/dist/wowok_agent/src/permission.d.ts +12 -0
- package/dist/wowok_agent/src/permission.d.ts.map +1 -0
- package/dist/wowok_agent/src/private_info.d.ts +26 -0
- package/dist/wowok_agent/src/private_info.d.ts.map +1 -0
- package/empty.ts +0 -0
- package/package.json +12 -3
- package/src/account.ts +40 -37
- package/src/call/arbitration.ts +41 -19
- package/src/call/base.ts +14 -16
- package/src/call/demand.ts +8 -7
- package/src/call/guard.ts +2 -7
- package/src/call/machine.ts +56 -35
- package/src/call/repository.ts +17 -15
- package/src/call/service.ts +87 -55
- package/src/call/treasury.ts +11 -10
- package/src/call.ts +3 -3
- package/src/index.ts +1 -1
- package/tsconfig.json +6 -2
- package/webpack.config.cjs +26 -0
package/src/call/machine.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { PassportObject, IsValidAddress, Errors, ERROR, Permission, PermissionIndex, TransactionBlock, TxbAddress,
|
|
2
2
|
PermissionIndexType, Machine, Machine_Forward, Machine_Node, Deliverable, ParentProgress, Progress, ProgressNext,
|
|
3
|
+
ProgressObject,
|
|
3
4
|
} from 'wowok';
|
|
4
5
|
import { CallBase, CallResult, Namedbject } from "./base";
|
|
5
6
|
import { Account } from '../account';
|
|
@@ -18,11 +19,11 @@ export interface CallMachine_Data {
|
|
|
18
19
|
| {op:'remove forward'; data:{prior_node_name:string; node_name:string; forward_name:string}[]}
|
|
19
20
|
bPublished?: boolean;
|
|
20
21
|
progress_new?: {task_address?:string; namedNew?: Namedbject};
|
|
21
|
-
progress_context_repository?: {progress
|
|
22
|
-
progress_namedOperator?: {progress
|
|
23
|
-
progress_parent?: {progress
|
|
24
|
-
progress_task?: {progress
|
|
25
|
-
progress_hold?: {progress
|
|
22
|
+
progress_context_repository?: {progress?:string; repository:string};
|
|
23
|
+
progress_namedOperator?: {progress?:string; data:{name:string, operator:string[]}[]};
|
|
24
|
+
progress_parent?: {progress?:string, parent?:ParentProgress};
|
|
25
|
+
progress_task?: {progress?:string; task:string};
|
|
26
|
+
progress_hold?: {progress?:string; data:ProgressNext; bHold:boolean; adminUnhold?:boolean};
|
|
26
27
|
progress_next?: {progress:string; data:ProgressNext; deliverable:Deliverable; guard?:string | 'fetch'};
|
|
27
28
|
bPaused?: boolean;
|
|
28
29
|
clone_new?: {namedNew: Namedbject/*, description?:string*/};
|
|
@@ -86,7 +87,7 @@ export class CallMachine extends CallBase { //@ todo self-owned node operate
|
|
|
86
87
|
guards.push(this.data?.progress_next?.guard)
|
|
87
88
|
} else if (this.data?.object && IsValidAddress(object_address)) { // fetch guard
|
|
88
89
|
const guard = await Progress.QueryForwardGuard(this.data?.progress_next.progress, object_address,
|
|
89
|
-
Account.Instance().get_address() ?? '0xe386bb9e01b3528b75f3751ad8a1e418b207ad979fea364087deef5250a73d3f',
|
|
90
|
+
await Account.Instance().get_address() ?? '0xe386bb9e01b3528b75f3751ad8a1e418b207ad979fea364087deef5250a73d3f',
|
|
90
91
|
this.data.progress_next.data.next_node_name, this.data.progress_next.data.forward);
|
|
91
92
|
if (guard) {
|
|
92
93
|
guards.push(guard)
|
|
@@ -119,94 +120,114 @@ export class CallMachine extends CallBase { //@ todo self-owned node operate
|
|
|
119
120
|
}
|
|
120
121
|
|
|
121
122
|
if (obj) {
|
|
123
|
+
const perm = permission ? permission.get_object() : permission_address;
|
|
124
|
+
const pst = permission?undefined:passport;
|
|
125
|
+
|
|
122
126
|
if (this.data?.description !== undefined && object_address) {
|
|
123
|
-
obj?.set_description(this.data.description,
|
|
127
|
+
obj?.set_description(this.data.description, pst);
|
|
124
128
|
}
|
|
125
129
|
if (this.data?.endpoint !== undefined && object_address) {
|
|
126
|
-
obj?.set_endpoint(this.data.endpoint,
|
|
130
|
+
obj?.set_endpoint(this.data.endpoint, pst)
|
|
127
131
|
}
|
|
128
132
|
|
|
129
133
|
if (this.data?.consensus_repository !== undefined) {
|
|
130
134
|
switch (this.data.consensus_repository.op) {
|
|
131
135
|
case 'add':
|
|
132
|
-
this.data.consensus_repository.repositories.forEach(v=>obj?.add_repository(v,
|
|
136
|
+
this.data.consensus_repository.repositories.forEach(v=>obj?.add_repository(v, pst)) ;
|
|
133
137
|
break;
|
|
134
138
|
case 'remove':
|
|
135
|
-
obj?.remove_repository(this.data.consensus_repository.repositories, false,
|
|
139
|
+
obj?.remove_repository(this.data.consensus_repository.repositories, false, pst);
|
|
136
140
|
break;
|
|
137
141
|
case 'removeall':
|
|
138
|
-
obj?.remove_repository([], true,
|
|
142
|
+
obj?.remove_repository([], true, pst);
|
|
139
143
|
break;
|
|
140
144
|
case 'set':
|
|
141
|
-
obj?.remove_repository([], true,
|
|
142
|
-
this.data.consensus_repository.repositories.forEach(v=>obj?.add_repository(v,
|
|
145
|
+
obj?.remove_repository([], true, pst);
|
|
146
|
+
this.data.consensus_repository.repositories.forEach(v=>obj?.add_repository(v, pst)) ;
|
|
143
147
|
break;
|
|
144
148
|
}
|
|
145
149
|
}
|
|
146
150
|
if (this.data?.nodes !== undefined) {
|
|
147
151
|
switch (this.data?.nodes?.op) {
|
|
148
152
|
case 'add':
|
|
149
|
-
obj?.add_node(this.data.nodes.data,
|
|
153
|
+
obj?.add_node(this.data.nodes.data, pst)
|
|
150
154
|
break;
|
|
151
155
|
case 'remove':
|
|
152
|
-
obj?.remove_node(this.data.nodes.names, this.data.nodes?.bTransferMyself,
|
|
156
|
+
obj?.remove_node(this.data.nodes.names, this.data.nodes?.bTransferMyself, pst)
|
|
153
157
|
break;
|
|
154
158
|
case 'rename node':
|
|
155
|
-
this.data.nodes.data.forEach(v => obj?.rename_node(v.old, v.new,
|
|
159
|
+
this.data.nodes.data.forEach(v => obj?.rename_node(v.old, v.new, pst));
|
|
156
160
|
break;
|
|
157
161
|
case 'add from myself':
|
|
158
|
-
obj?.add_node2(this.data.nodes.addresses,
|
|
162
|
+
obj?.add_node2(this.data.nodes.addresses, pst);
|
|
159
163
|
break;
|
|
160
164
|
case 'add forward':
|
|
161
|
-
this.data.nodes.data.forEach(v => obj?.add_forward(v.prior_node_name, v.node_name, v.forward, v.threshold, v.old_need_remove,
|
|
165
|
+
this.data.nodes.data.forEach(v => obj?.add_forward(v.prior_node_name, v.node_name, v.forward, v.threshold, v.old_need_remove, pst))
|
|
162
166
|
break;
|
|
163
167
|
case 'remove forward':
|
|
164
|
-
this.data.nodes.data.forEach(v => obj?.remove_forward(v.prior_node_name, v.node_name, v.forward_name,
|
|
168
|
+
this.data.nodes.data.forEach(v => obj?.remove_forward(v.prior_node_name, v.node_name, v.forward_name, pst))
|
|
165
169
|
break;
|
|
166
170
|
}
|
|
167
171
|
}
|
|
168
172
|
if (this.data?.bPublished ) {
|
|
169
173
|
obj?.publish(passport)
|
|
170
174
|
}
|
|
175
|
+
var new_progress : Progress | undefined;
|
|
171
176
|
if (this.data?.progress_new !== undefined) {
|
|
172
|
-
|
|
173
|
-
if (addr) {
|
|
174
|
-
await this.new_with_mark(txb, addr, this.data?.progress_new?.namedNew, account);
|
|
175
|
-
}
|
|
177
|
+
new_progress = Progress?.New(txb, obj?.get_object(), perm, this.data?.progress_new.task_address, pst);
|
|
176
178
|
}
|
|
177
179
|
if (this.data?.progress_context_repository !== undefined) {
|
|
178
|
-
|
|
179
|
-
|
|
180
|
+
const p = this.data?.progress_context_repository.progress ?? new_progress?.get_object();
|
|
181
|
+
if (!p) ERROR(Errors.Fail, 'progress invalid: progress_context_repository');
|
|
182
|
+
|
|
183
|
+
Progress.From(txb, obj?.get_object(), perm, p!).set_context_repository(this.data?.progress_context_repository.repository, pst)
|
|
180
184
|
}
|
|
181
185
|
if (this.data?.progress_namedOperator !== undefined) {
|
|
182
|
-
const p =
|
|
183
|
-
|
|
186
|
+
const p = this.data?.progress_namedOperator.progress ?? new_progress?.get_object();
|
|
187
|
+
if (!p) ERROR(Errors.Fail, 'progress invalid: progress_namedOperator');
|
|
188
|
+
|
|
189
|
+
let pp = Progress.From(txb, obj?.get_object(), perm, p!);
|
|
190
|
+
this.data.progress_namedOperator.data.forEach(v => pp.set_namedOperator(v.name, v.operator, pst));
|
|
184
191
|
}
|
|
185
192
|
if (this.data?.progress_parent !== undefined) {
|
|
193
|
+
const p = this.data?.progress_parent.progress ?? new_progress?.get_object();
|
|
194
|
+
if (!p) ERROR(Errors.Fail, 'progress invalid: progress_parent');
|
|
195
|
+
|
|
186
196
|
if (this.data.progress_parent.parent) {
|
|
187
|
-
Progress.From(txb, obj?.get_object(),
|
|
197
|
+
Progress.From(txb, obj?.get_object(), perm, p!).parent(this.data.progress_parent.parent);
|
|
188
198
|
} else {
|
|
189
|
-
Progress.From(txb, obj?.get_object(),
|
|
199
|
+
Progress.From(txb, obj?.get_object(), perm, p!).parent_none();
|
|
190
200
|
}
|
|
191
201
|
}
|
|
192
202
|
if (this.data?.progress_task !== undefined) {
|
|
193
|
-
|
|
203
|
+
const p = this.data?.progress_task.progress ?? new_progress?.get_object();
|
|
204
|
+
if (!p) ERROR(Errors.Fail, 'progress invalid: progress_task');
|
|
205
|
+
|
|
206
|
+
Progress.From(txb, obj?.get_object(), perm, p!).bind_task(this.data.progress_task.task, pst)
|
|
194
207
|
}
|
|
195
208
|
if (this.data?.progress_hold !== undefined) {
|
|
209
|
+
const p = this.data?.progress_hold.progress ?? new_progress?.get_object();
|
|
210
|
+
if (!p) ERROR(Errors.Fail, 'progress invalid: progress_hold');
|
|
211
|
+
|
|
196
212
|
if (this.data?.progress_hold.adminUnhold) {
|
|
197
|
-
Progress.From(txb, obj?.get_object(),
|
|
213
|
+
Progress.From(txb, obj?.get_object(), perm, p!).unhold(this.data.progress_hold.data, pst)
|
|
198
214
|
} else {
|
|
199
|
-
Progress.From(txb, obj?.get_object(),
|
|
215
|
+
Progress.From(txb, obj?.get_object(), perm, p!).hold(this.data.progress_hold.data, this.data.progress_hold.bHold)
|
|
200
216
|
}
|
|
201
217
|
}
|
|
218
|
+
const addr = new_progress?.launch();
|
|
219
|
+
if (addr) {
|
|
220
|
+
await this.new_with_mark(txb, addr, this.data?.progress_new?.namedNew, account);
|
|
221
|
+
}
|
|
222
|
+
|
|
202
223
|
if (this.data?.progress_next !== undefined) {
|
|
203
|
-
Progress.From(txb, obj?.get_object(),
|
|
224
|
+
Progress.From(txb, obj?.get_object(), perm, this.data?.progress_next.progress).next(this.data.progress_next.data, this.data.progress_next.deliverable, pst)
|
|
204
225
|
}
|
|
205
226
|
if (this.data?.bPaused !== undefined) {
|
|
206
|
-
obj?.pause(this.data.bPaused,
|
|
227
|
+
obj?.pause(this.data.bPaused, pst)
|
|
207
228
|
}
|
|
208
229
|
if (this.data?.clone_new !== undefined && obj) {
|
|
209
|
-
await this.new_with_mark(txb, obj?.clone(true,
|
|
230
|
+
await this.new_with_mark(txb, obj?.clone(true, pst) as TxbAddress, (this.data?.clone_new as any)?.namedNew, account);
|
|
210
231
|
}
|
|
211
232
|
if (permission) {
|
|
212
233
|
await this.new_with_mark(txb, permission.launch(), (this.data?.permission as any)?.namedNew, account);
|
package/src/call/repository.ts
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { TransactionBlock
|
|
1
|
+
import { TransactionBlock } from 'wowok';
|
|
2
2
|
import { PassportObject, IsValidAddress, Errors, ERROR, Permission, PermissionIndex, PermissionIndexType, Repository,
|
|
3
3
|
Repository_Policy, Repository_Policy_Data, Repository_Policy_Data2, Repository_Policy_Data_Remove,
|
|
4
|
-
Repository_Policy_Mode,
|
|
4
|
+
Repository_Policy_Mode,
|
|
5
5
|
} from 'wowok';
|
|
6
6
|
import { CallBase, CallResult, Namedbject} from "./base";
|
|
7
7
|
|
|
8
|
+
|
|
8
9
|
/// The execution priority is determined by the order in which the object attributes are arranged
|
|
9
10
|
export interface CallRepository_Data {
|
|
10
11
|
object?: {address:string} | {namedNew: Namedbject}; // undefined or {named_new...} for creating a new object
|
|
@@ -70,47 +71,48 @@ export class CallRepository extends CallBase {
|
|
|
70
71
|
}
|
|
71
72
|
|
|
72
73
|
if (obj) {
|
|
74
|
+
const pst = permission?undefined:passport;
|
|
73
75
|
if (this.data?.description !== undefined && object_address) {
|
|
74
|
-
obj?.set_description(this.data.description,
|
|
76
|
+
obj?.set_description(this.data.description, pst);
|
|
75
77
|
}
|
|
76
78
|
if (this.data?.reference !== undefined) {
|
|
77
79
|
switch (this.data.reference.op) {
|
|
78
80
|
case 'set':
|
|
79
|
-
obj?.remove_reference([], true,
|
|
80
|
-
obj?.add_reference(this.data.reference.addresses,
|
|
81
|
+
obj?.remove_reference([], true, pst);
|
|
82
|
+
obj?.add_reference(this.data.reference.addresses, pst);
|
|
81
83
|
break;
|
|
82
84
|
case 'add':
|
|
83
|
-
obj?.add_reference(this.data.reference.addresses,
|
|
85
|
+
obj?.add_reference(this.data.reference.addresses, pst);
|
|
84
86
|
break;
|
|
85
87
|
case 'remove':
|
|
86
|
-
obj?.remove_reference(this.data.reference.addresses, false,
|
|
88
|
+
obj?.remove_reference(this.data.reference.addresses, false, pst);
|
|
87
89
|
break;
|
|
88
90
|
case 'removeall':
|
|
89
|
-
obj?.remove_reference([], true,
|
|
91
|
+
obj?.remove_reference([], true, pst);
|
|
90
92
|
break;
|
|
91
93
|
}
|
|
92
94
|
}
|
|
93
95
|
if (this.data?.mode !== undefined && object_address) { //@ priority??
|
|
94
|
-
obj?.set_policy_mode(this.data.mode,
|
|
96
|
+
obj?.set_policy_mode(this.data.mode, pst)
|
|
95
97
|
}
|
|
96
98
|
if (this.data?.policy !== undefined) {
|
|
97
99
|
switch(this.data.policy.op) {
|
|
98
100
|
case 'set':
|
|
99
|
-
obj?.remove_policies([], true,
|
|
100
|
-
obj?.add_policies(this.data.policy.data,
|
|
101
|
+
obj?.remove_policies([], true, pst);
|
|
102
|
+
obj?.add_policies(this.data.policy.data, pst);
|
|
101
103
|
break;
|
|
102
104
|
case 'add':
|
|
103
|
-
obj?.add_policies(this.data.policy.data,
|
|
105
|
+
obj?.add_policies(this.data.policy.data, pst);
|
|
104
106
|
break;
|
|
105
107
|
case 'remove':
|
|
106
|
-
obj?.remove_policies(this.data.policy.data, false,
|
|
108
|
+
obj?.remove_policies(this.data.policy.data, false, pst);
|
|
107
109
|
break;
|
|
108
110
|
case 'removeall':
|
|
109
|
-
obj?.remove_policies([], true,
|
|
111
|
+
obj?.remove_policies([], true, pst);
|
|
110
112
|
break;
|
|
111
113
|
case 'rename':
|
|
112
114
|
this.data.policy.data.forEach((v) => {
|
|
113
|
-
obj?.rename_policy(v.old, v.new,
|
|
115
|
+
obj?.rename_policy(v.old, v.new, pst);
|
|
114
116
|
})
|
|
115
117
|
break;
|
|
116
118
|
}
|
package/src/call/service.ts
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { TransactionBlock, IsValidArgType, TxbAddress, TagName, PassportObject, IsValidAddress, Errors, ERROR, Permission,
|
|
2
2
|
PermissionIndex, PermissionIndexType, BuyRequiredEnum, Customer_RequiredInfo, DicountDispatch, Service, Service_Buy,
|
|
3
|
-
Service_Guard_Percent, Service_Sale, WithdrawPayee, Treasury,
|
|
3
|
+
Service_Guard_Percent, Service_Sale, WithdrawPayee, Treasury,
|
|
4
|
+
OrderObject,
|
|
5
|
+
OrderResult,
|
|
4
6
|
} from 'wowok';
|
|
5
7
|
import { query_objects, ObjectService } from '../objects';
|
|
6
8
|
import { CallBase, CallResult, Namedbject } from "./base";
|
|
@@ -28,12 +30,13 @@ export interface CallService_Data {
|
|
|
28
30
|
refund_guard?: {op:'add' | 'set'; guards:Service_Guard_Percent[]}
|
|
29
31
|
| {op:'removeall'} | {op:'remove', addresses:string[]};
|
|
30
32
|
bPublished?: boolean;
|
|
31
|
-
order_new?: {buy_items:Service_Buy[], discount?:string, machine?:string, customer_info_crypto?: Customer_RequiredInfo, guard?:string | 'fetch',
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
33
|
+
order_new?: {buy_items:Service_Buy[], discount?:string, machine?:string, customer_info_crypto?: Customer_RequiredInfo, guard?:string | 'fetch',
|
|
34
|
+
namedNewOrder?: Namedbject, namedNewProgress?:Namedbject}
|
|
35
|
+
order_agent?: {order?:string; agents: string[]; progress?:string};
|
|
36
|
+
order_required_info?: {order?:string; info:Customer_RequiredInfo};
|
|
37
|
+
order_refund?: {order?:string; guard?:string;} | {order?:string; arb:string; arb_token_type:string}; // guard address
|
|
38
|
+
order_withdrawl?: {order?:string; data:WithdrawPayee}; // guard address
|
|
39
|
+
order_payer?: {order?:string; payer_new:string; progress?:string}; // transfer the order payer permission to someaddress
|
|
37
40
|
buy_guard?: string;
|
|
38
41
|
bPaused?: boolean;
|
|
39
42
|
clone_new?: {token_type_new?:string; namedNew?: Namedbject};
|
|
@@ -173,126 +176,130 @@ export class CallService extends CallBase {
|
|
|
173
176
|
}
|
|
174
177
|
|
|
175
178
|
if (obj) {
|
|
179
|
+
//const perm = permission ? permission.get_object() : permission_address;
|
|
180
|
+
const pst = permission?undefined:passport;
|
|
181
|
+
|
|
176
182
|
if (this.data?.description !== undefined && object_address) {
|
|
177
|
-
obj?.set_description(this.data.description,
|
|
183
|
+
obj?.set_description(this.data.description, pst);
|
|
178
184
|
}
|
|
179
185
|
if (this.data?.endpoint !== undefined) {
|
|
180
|
-
obj?.set_endpoint(this.data.endpoint,
|
|
186
|
+
obj?.set_endpoint(this.data.endpoint, pst)
|
|
181
187
|
}
|
|
182
188
|
if (this.data?.payee_treasury !== undefined && object_address) {
|
|
183
|
-
obj?.set_payee(treasury_address,
|
|
189
|
+
obj?.set_payee(treasury_address, pst);
|
|
184
190
|
}
|
|
185
191
|
if (this.data?.gen_discount !== undefined) {
|
|
186
|
-
obj?.discount_transfer(this.data.gen_discount,
|
|
192
|
+
obj?.discount_transfer(this.data.gen_discount, pst)
|
|
187
193
|
}
|
|
188
194
|
if (this.data?.repository !== undefined) {
|
|
189
195
|
switch (this.data.repository.op) {
|
|
190
196
|
case 'add':
|
|
191
|
-
this.data.repository.repositories.forEach(v => obj?.add_repository(v,
|
|
197
|
+
this.data.repository.repositories.forEach(v => obj?.add_repository(v, pst))
|
|
192
198
|
break;
|
|
193
199
|
case 'remove':
|
|
194
|
-
obj?.remove_repository(this.data.repository.repositories, false,
|
|
200
|
+
obj?.remove_repository(this.data.repository.repositories, false, pst)
|
|
195
201
|
break;
|
|
196
202
|
case 'set':
|
|
197
|
-
obj?.remove_repository([], true,
|
|
198
|
-
this.data.repository.repositories.forEach(v => obj?.add_repository(v,
|
|
203
|
+
obj?.remove_repository([], true, pst)
|
|
204
|
+
this.data.repository.repositories.forEach(v => obj?.add_repository(v, pst))
|
|
199
205
|
break;
|
|
200
206
|
case 'removeall':
|
|
201
|
-
obj?.remove_repository([], true,
|
|
207
|
+
obj?.remove_repository([], true, pst)
|
|
202
208
|
break;
|
|
203
209
|
}
|
|
204
210
|
}
|
|
205
211
|
if (this.data?.extern_withdraw_treasury !== undefined) {
|
|
206
212
|
switch(this.data.extern_withdraw_treasury.op) {
|
|
207
213
|
case 'add':
|
|
208
|
-
this.data.extern_withdraw_treasury.treasuries.forEach(v=>obj?.add_treasury(v.token_type, v.address,
|
|
214
|
+
this.data.extern_withdraw_treasury.treasuries.forEach(v=>obj?.add_treasury(v.token_type, v.address, pst))
|
|
209
215
|
break;
|
|
210
216
|
case 'set':
|
|
211
|
-
obj?.remove_treasury([], true,
|
|
212
|
-
this.data.extern_withdraw_treasury.treasuries.forEach(v=>obj?.add_treasury(v.token_type, v.address,
|
|
217
|
+
obj?.remove_treasury([], true, pst)
|
|
218
|
+
this.data.extern_withdraw_treasury.treasuries.forEach(v=>obj?.add_treasury(v.token_type, v.address, pst))
|
|
213
219
|
break;
|
|
214
220
|
case 'remove':
|
|
215
|
-
obj?.remove_treasury(this.data.extern_withdraw_treasury.addresses, false,
|
|
221
|
+
obj?.remove_treasury(this.data.extern_withdraw_treasury.addresses, false, pst)
|
|
216
222
|
break;
|
|
217
223
|
case 'removeall':
|
|
218
|
-
obj?.remove_treasury([], false,
|
|
224
|
+
obj?.remove_treasury([], false, pst)
|
|
219
225
|
break;
|
|
220
226
|
}
|
|
221
227
|
}
|
|
222
228
|
if (this.data?.machine !== undefined) {
|
|
223
|
-
obj?.set_machine(this.data.machine,
|
|
229
|
+
obj?.set_machine(this.data.machine, pst)
|
|
224
230
|
}
|
|
225
231
|
if (this.data?.arbitration !== undefined) {
|
|
226
232
|
switch(this.data.arbitration.op) {
|
|
227
233
|
case 'add':
|
|
228
|
-
this.data.arbitration.arbitrations.forEach(v=>obj?.add_arbitration(v.address, v.type_parameter,
|
|
234
|
+
this.data.arbitration.arbitrations.forEach(v=>obj?.add_arbitration(v.address, v.type_parameter, pst))
|
|
229
235
|
break;
|
|
230
236
|
case 'set':
|
|
231
|
-
obj?.remove_arbitration([], true,
|
|
232
|
-
this.data.arbitration.arbitrations.forEach(v=>obj?.add_arbitration(v.address, v.type_parameter,
|
|
237
|
+
obj?.remove_arbitration([], true, pst)
|
|
238
|
+
this.data.arbitration.arbitrations.forEach(v=>obj?.add_arbitration(v.address, v.type_parameter, pst))
|
|
233
239
|
break;
|
|
234
240
|
case 'remove':
|
|
235
|
-
obj?.remove_arbitration(this.data.arbitration.addresses, false,
|
|
241
|
+
obj?.remove_arbitration(this.data.arbitration.addresses, false, pst)
|
|
236
242
|
break;
|
|
237
243
|
case 'removeall':
|
|
238
|
-
obj?.remove_arbitration([], false,
|
|
244
|
+
obj?.remove_arbitration([], false, pst)
|
|
239
245
|
break;
|
|
240
246
|
}
|
|
241
247
|
}
|
|
242
248
|
if (this.data?.customer_required_info !== undefined) {
|
|
243
249
|
if (this.data.customer_required_info.required_info && this.data.customer_required_info.pubkey) {
|
|
244
|
-
obj?.set_customer_required(this.data.customer_required_info.pubkey, this.data.customer_required_info.required_info,
|
|
250
|
+
obj?.set_customer_required(this.data.customer_required_info.pubkey, this.data.customer_required_info.required_info, pst);
|
|
245
251
|
} else if (this.data.customer_required_info.pubkey) {
|
|
246
|
-
obj?.change_required_pubkey(this.data.customer_required_info.pubkey,
|
|
252
|
+
obj?.change_required_pubkey(this.data.customer_required_info.pubkey, pst);
|
|
247
253
|
}
|
|
248
254
|
}
|
|
249
255
|
if (this.data?.sales !== undefined) {
|
|
250
256
|
switch(this.data.sales.op) {
|
|
251
257
|
case 'add':
|
|
252
|
-
obj?.add_sales(this.data.sales.sales, false,
|
|
258
|
+
obj?.add_sales(this.data.sales.sales, false, pst)
|
|
253
259
|
break;
|
|
254
260
|
case 'remove':
|
|
255
|
-
obj?.remove_sales(this.data.sales.sales_name,
|
|
261
|
+
obj?.remove_sales(this.data.sales.sales_name, pst)
|
|
256
262
|
break;
|
|
257
263
|
}
|
|
258
264
|
}
|
|
259
265
|
if (this.data?.withdraw_guard !== undefined) {
|
|
260
266
|
switch(this.data.withdraw_guard.op) {
|
|
261
267
|
case 'add':
|
|
262
|
-
obj?.add_withdraw_guards(this.data.withdraw_guard.guards,
|
|
268
|
+
obj?.add_withdraw_guards(this.data.withdraw_guard.guards, pst)
|
|
263
269
|
break;
|
|
264
270
|
case 'set':
|
|
265
|
-
obj?.remove_withdraw_guards([], true,
|
|
266
|
-
obj?.add_withdraw_guards(this.data.withdraw_guard.guards,
|
|
271
|
+
obj?.remove_withdraw_guards([], true, pst)
|
|
272
|
+
obj?.add_withdraw_guards(this.data.withdraw_guard.guards, pst)
|
|
267
273
|
break;
|
|
268
274
|
case 'remove':
|
|
269
|
-
obj?.remove_withdraw_guards(this.data.withdraw_guard.addresses, false,
|
|
275
|
+
obj?.remove_withdraw_guards(this.data.withdraw_guard.addresses, false, pst)
|
|
270
276
|
break;
|
|
271
277
|
case 'removeall':
|
|
272
|
-
obj?.remove_withdraw_guards([], true,
|
|
278
|
+
obj?.remove_withdraw_guards([], true, pst)
|
|
273
279
|
break;
|
|
274
280
|
}
|
|
275
281
|
}
|
|
276
282
|
if (this.data?.refund_guard !== undefined) {
|
|
277
283
|
switch(this.data.refund_guard.op) {
|
|
278
284
|
case 'add':
|
|
279
|
-
obj?.add_refund_guards(this.data.refund_guard.guards,
|
|
285
|
+
obj?.add_refund_guards(this.data.refund_guard.guards, pst)
|
|
280
286
|
break;
|
|
281
287
|
case 'set':
|
|
282
|
-
obj?.remove_refund_guards([], true,
|
|
283
|
-
obj?.add_refund_guards(this.data.refund_guard.guards,
|
|
288
|
+
obj?.remove_refund_guards([], true, pst)
|
|
289
|
+
obj?.add_refund_guards(this.data.refund_guard.guards, pst)
|
|
284
290
|
break;
|
|
285
291
|
case 'remove':
|
|
286
|
-
obj?.remove_refund_guards(this.data.refund_guard.addresses, false,
|
|
292
|
+
obj?.remove_refund_guards(this.data.refund_guard.addresses, false, pst)
|
|
287
293
|
break;
|
|
288
294
|
case 'removeall':
|
|
289
|
-
obj?.remove_refund_guards([], true,
|
|
295
|
+
obj?.remove_refund_guards([], true, pst)
|
|
290
296
|
break;
|
|
291
297
|
}
|
|
292
298
|
}
|
|
293
299
|
if (this.data?.bPublished) {
|
|
294
|
-
obj?.publish(
|
|
300
|
+
obj?.publish(pst)
|
|
295
301
|
}
|
|
302
|
+
var order_new : OrderResult | undefined;
|
|
296
303
|
if (this.data?.order_new !== undefined) {
|
|
297
304
|
let b = BigInt(0); let coin : any;
|
|
298
305
|
this.data.order_new.buy_items.forEach(v => {
|
|
@@ -302,39 +309,64 @@ export class CallService extends CallBase {
|
|
|
302
309
|
const coin = await Account.Instance().get_coin_object(txb, b, account, this.data.type_parameter);
|
|
303
310
|
if (coin) {
|
|
304
311
|
//@ crypto tools support
|
|
305
|
-
|
|
306
|
-
this.data.order_new.
|
|
307
|
-
await this.new_with_mark(txb, addr, (this.data?.order_new as any)?.namedNew, account, [TagName.Launch, TagName.Order]);
|
|
312
|
+
order_new = obj.order(this.data.order_new.buy_items, coin, this.data.order_new.discount, this.data.order_new.machine,
|
|
313
|
+
this.data.order_new.customer_info_crypto, pst);
|
|
308
314
|
}
|
|
309
315
|
}
|
|
310
316
|
}
|
|
317
|
+
|
|
311
318
|
if (this.data?.order_agent !== undefined) {
|
|
312
|
-
|
|
319
|
+
const o = this.data.order_agent.order ?? order_new?.order;
|
|
320
|
+
if (!o) ERROR(Errors.Fail, 'order invalid: order_agent');
|
|
321
|
+
|
|
322
|
+
obj?.set_order_agent(o!, this.data.order_agent.agents, this.data.order_agent.progress)
|
|
313
323
|
}
|
|
314
324
|
if (this.data?.order_required_info !== undefined) {
|
|
315
|
-
|
|
325
|
+
const o = this.data.order_required_info.order ?? order_new?.order;
|
|
326
|
+
if (!o) ERROR(Errors.Fail, 'order invalid: order_required_info');
|
|
327
|
+
|
|
328
|
+
obj?.update_order_required_info(o!, this.data.order_required_info.info)
|
|
316
329
|
}
|
|
317
330
|
if (this.data?.order_refund !== undefined) {
|
|
331
|
+
const o = this.data.order_refund.order ?? order_new?.order;
|
|
332
|
+
if (!o) ERROR(Errors.Fail, 'order invalid: order_refund');
|
|
333
|
+
|
|
318
334
|
if ((this.data?.order_refund as any)?.arb && (this.data?.order_refund as any)?.arb_token_type) {
|
|
319
|
-
obj?.refund_withArb(
|
|
335
|
+
obj?.refund_withArb(o!, (this.data?.order_refund as any)?.arb, (this.data?.order_refund as any)?.arb_token_type)
|
|
320
336
|
} else {
|
|
321
|
-
obj?.refund(
|
|
337
|
+
obj?.refund(o!, (this.data?.order_refund as any)?.guard, pst)
|
|
322
338
|
}
|
|
323
339
|
}
|
|
324
|
-
if (this.data?.order_withdrawl !== undefined &&
|
|
325
|
-
|
|
340
|
+
if (this.data?.order_withdrawl !== undefined && pst) { //@ need withdrawal pst
|
|
341
|
+
const o = this.data.order_withdrawl.order ?? order_new?.order;
|
|
342
|
+
if (!o) ERROR(Errors.Fail, 'order invalid: order_withdrawl');
|
|
343
|
+
|
|
344
|
+
obj?.withdraw(o!, this.data.order_withdrawl.data, pst)
|
|
326
345
|
}
|
|
346
|
+
|
|
327
347
|
if (this.data?.order_payer !== undefined && obj) {
|
|
328
|
-
|
|
348
|
+
const o = this.data.order_payer.order ?? order_new?.order;
|
|
349
|
+
if (!o) ERROR(Errors.Fail, 'order invalid: order_payer');
|
|
350
|
+
|
|
351
|
+
obj?.change_order_payer(o!, this.data.order_payer.payer_new, this.data.order_payer.progress)
|
|
329
352
|
}
|
|
353
|
+
|
|
354
|
+
if (order_new && this?.data?.order_new) {
|
|
355
|
+
const buy = obj.order_launch(order_new);
|
|
356
|
+
await this.new_with_mark(txb, buy.order, (this.data?.order_new as any)?.namedNewOrder, account, [TagName.Launch, TagName.Order]);
|
|
357
|
+
if (buy?.progress) {
|
|
358
|
+
await this.new_with_mark(txb, buy.progress, (this.data?.order_new as any)?.namedNewProgress, account, [TagName.Launch]);
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
|
|
330
362
|
if (this.data?.buy_guard !== undefined) {
|
|
331
|
-
obj?.set_buy_guard(this.data.buy_guard,
|
|
363
|
+
obj?.set_buy_guard(this.data.buy_guard, pst)
|
|
332
364
|
}
|
|
333
365
|
if (this.data?.bPaused !== undefined) {
|
|
334
|
-
obj?.pause(this.data.bPaused,
|
|
366
|
+
obj?.pause(this.data.bPaused, pst)
|
|
335
367
|
}
|
|
336
368
|
if (this.data?.clone_new !== undefined && obj) {
|
|
337
|
-
await this.new_with_mark(txb, obj.clone(this.data.clone_new?.token_type_new, true,
|
|
369
|
+
await this.new_with_mark(txb, obj.clone(this.data.clone_new?.token_type_new, true, pst) as TxbAddress, (this.data?.clone_new as any)?.namedNew, account);
|
|
338
370
|
}
|
|
339
371
|
if (payee) {
|
|
340
372
|
await this.new_with_mark(txb, payee.launch(), (this.data?.payee_treasury as any)?.namedNew, account);
|
package/src/call/treasury.ts
CHANGED
|
@@ -120,8 +120,9 @@ export class CallTreasury extends CallBase {
|
|
|
120
120
|
}
|
|
121
121
|
|
|
122
122
|
if (obj) {
|
|
123
|
+
const pst = permission?undefined:passport;
|
|
123
124
|
if (this.data?.description !== undefined && object_address) {
|
|
124
|
-
obj?.set_description(this.data.description,
|
|
125
|
+
obj?.set_description(this.data.description, pst);
|
|
125
126
|
}
|
|
126
127
|
if (this.data.deposit !== undefined) {
|
|
127
128
|
const coin = await Account.Instance().get_coin_object(txb, this.data.deposit.data.balance, account, this.data.type_parameter);
|
|
@@ -134,34 +135,34 @@ export class CallTreasury extends CallBase {
|
|
|
134
135
|
}
|
|
135
136
|
}
|
|
136
137
|
if (this.data?.receive !== undefined) {
|
|
137
|
-
obj?.receive(this.data.receive.payment, this.data.receive.received_object,
|
|
138
|
+
obj?.receive(this.data.receive.payment, this.data.receive.received_object, pst);
|
|
138
139
|
}
|
|
139
140
|
if (this.data?.withdraw !== undefined) {
|
|
140
|
-
obj?.withdraw(this.data.withdraw,
|
|
141
|
+
obj?.withdraw(this.data.withdraw, pst)
|
|
141
142
|
}
|
|
142
143
|
|
|
143
144
|
if (this.data?.deposit_guard !== undefined) {
|
|
144
|
-
obj?.set_deposit_guard(this.data.deposit_guard,
|
|
145
|
+
obj?.set_deposit_guard(this.data.deposit_guard, pst);
|
|
145
146
|
}
|
|
146
147
|
if (this.data?.withdraw_guard !== undefined) {
|
|
147
148
|
switch (this.data.withdraw_guard.op) {
|
|
148
149
|
case 'add':
|
|
149
|
-
this.data.withdraw_guard.data.forEach(v => obj?.add_withdraw_guard(v.guard, BigInt(v.amount),
|
|
150
|
+
this.data.withdraw_guard.data.forEach(v => obj?.add_withdraw_guard(v.guard, BigInt(v.amount), pst))
|
|
150
151
|
break;
|
|
151
152
|
case 'remove':
|
|
152
|
-
obj?.remove_withdraw_guard(this.data.withdraw_guard.guards, false,
|
|
153
|
+
obj?.remove_withdraw_guard(this.data.withdraw_guard.guards, false, pst)
|
|
153
154
|
break;
|
|
154
155
|
case 'set':
|
|
155
|
-
obj?.remove_withdraw_guard([], true,
|
|
156
|
-
this.data.withdraw_guard.data.forEach(v => obj?.add_withdraw_guard(v.guard, BigInt(v.amount),
|
|
156
|
+
obj?.remove_withdraw_guard([], true, pst)
|
|
157
|
+
this.data.withdraw_guard.data.forEach(v => obj?.add_withdraw_guard(v.guard, BigInt(v.amount), pst))
|
|
157
158
|
break;
|
|
158
159
|
case 'removeall':
|
|
159
|
-
obj?.remove_withdraw_guard([], true,
|
|
160
|
+
obj?.remove_withdraw_guard([], true, pst)
|
|
160
161
|
break;
|
|
161
162
|
}
|
|
162
163
|
}
|
|
163
164
|
if (this.data?.withdraw_mode !== undefined) {
|
|
164
|
-
obj?.set_withdraw_mode(this.data.withdraw_mode,
|
|
165
|
+
obj?.set_withdraw_mode(this.data.withdraw_mode, pst)
|
|
165
166
|
}
|
|
166
167
|
if (permission) {
|
|
167
168
|
await this.new_with_mark(txb, permission.launch(), (this.data?.permission as any)?.namedNew, account);
|
package/src/call.ts
CHANGED
|
@@ -12,7 +12,7 @@ import { CallPersonal, CallPersonal_Data } from "./call/personal";
|
|
|
12
12
|
import { CallRepository, CallRepository_Data } from "./call/repository";
|
|
13
13
|
import { CallService, CallService_Data } from "./call/service";
|
|
14
14
|
import { CallTreasury, CallTreasury_Data } from "./call/treasury";
|
|
15
|
-
import { CallBase, CallResult,
|
|
15
|
+
import { CallBase, CallResult, GuardInfo_forCall } from "./call/base";
|
|
16
16
|
import { CallGuard, CallGuard_Data } from "./call/guard";
|
|
17
17
|
import { CallObjectPermission, CallObjectPermission_Data } from "./call/object_permission";
|
|
18
18
|
|
|
@@ -23,7 +23,7 @@ export interface CallObject {
|
|
|
23
23
|
type: CallObjectType;
|
|
24
24
|
data: CallObjectData;
|
|
25
25
|
account?: string;
|
|
26
|
-
witness?:
|
|
26
|
+
witness?: GuardInfo_forCall;
|
|
27
27
|
}
|
|
28
28
|
|
|
29
29
|
export const call_object_json = async (json: string) : Promise<string> => {
|
|
@@ -40,7 +40,7 @@ export const call_object = async (call: CallObject) : Promise<CallResult> => {
|
|
|
40
40
|
|
|
41
41
|
if (obj) {
|
|
42
42
|
if (call.witness) {
|
|
43
|
-
return obj.call_with_witness(call.witness);
|
|
43
|
+
return obj.call_with_witness(call.witness, call.account);
|
|
44
44
|
} else {
|
|
45
45
|
return obj.call(call.account);
|
|
46
46
|
}
|
package/src/index.ts
CHANGED