wowok_agent
Version:
Create, collaborate, and transact on your own terms with the AI-driven web3 collaboration protocol.
144 lines (134 loc) • 6.81 kB
text/typescript
import { TransactionBlock } from 'wowok';
import { PassportObject, IsValidAddress, Errors, ERROR, Permission, PermissionIndex, PermissionIndexType, Repository,
Repository_Policy, Repository_Policy_Data, Repository_Policy_Data2, Repository_Policy_Data_Remove,
Repository_Policy_Mode,
} from 'wowok';
import { CallBase, CallResult, Namedbject} from "./base";
/// The execution priority is determined by the order in which the object attributes are arranged
export interface CallRepository_Data {
object?: {address:string} | {namedNew?: Namedbject}; // undefined or {named_new...} for creating a new object
permission?: {address:string} | {namedNew?: Namedbject, description?:string};
description?: string;
reference?: {op:'set' | 'add' | 'remove' ; addresses:string[]} | {op:'removeall'};
mode?: Repository_Policy_Mode; // default: 'Relax' (POLICY_MODE_FREE)
policy?: {op:'add' | 'set'; data:Repository_Policy[]} | {op:'remove'; keys:string[]} | {op:'removeall'} | {op:'rename'; data:{old:string; new:string}[]};
data?: {op:'add', data: Repository_Policy_Data | Repository_Policy_Data2} | {op:'remove'; data: Repository_Policy_Data_Remove[]};
}
export class CallRepository extends CallBase {
data: CallRepository_Data;
constructor(data:CallRepository_Data) {
super();
this.data = data;
}
async call(account?:string) : Promise<CallResult> {
var checkOwner = false;
const perms : PermissionIndexType[] = [];
const permission_address = (this.data?.permission as any)?.address;
const object_address = (this.data?.object as any)?.address;
if (permission_address && IsValidAddress(permission_address)) {
if (!this.data?.object) {
perms.push(PermissionIndex.repository)
}
if (this.data?.description !== undefined && object_address) {
perms.push(PermissionIndex.repository_description)
}
if (this.data?.mode !== undefined && object_address) {
perms.push(PermissionIndex.repository_mode)
}
if (this.data?.reference !== undefined) {
perms.push(PermissionIndex.repository_reference)
}
if (this.data?.policy !== undefined) {
perms.push(PermissionIndex.repository_policies)
}
return await this.check_permission_and_call(permission_address, perms, [], checkOwner, undefined, account)
}
return await this.exec(account);
}
protected async operate(txb:TransactionBlock, passport?:PassportObject, account?:string) {
let obj : Repository | undefined ; let permission: any;
const permission_address = (this.data?.permission as any)?.address;
const object_address = (this.data?.object as any)?.address;
if (!object_address) {
if (!permission_address || !IsValidAddress(permission_address)) {
const d = (this.data?.permission as any)?.description ?? '';
permission = Permission.New(txb, d);
}
obj = Repository.New(txb, permission ? permission.get_object() : permission_address, this.data?.description??'', this.data?.mode, permission?undefined:passport)
} else {
if (IsValidAddress(object_address) && this.data.permission && IsValidAddress(permission_address)) {
obj = Repository.From(txb, permission_address, object_address)
} else {
ERROR(Errors.InvalidParam, 'object or permission address invalid.')
}
}
if (obj) {
const pst = permission?undefined:passport;
if (this.data?.description !== undefined && object_address) {
obj?.set_description(this.data.description, pst);
}
if (this.data?.reference !== undefined) {
switch (this.data.reference.op) {
case 'set':
obj?.remove_reference([], true, pst);
obj?.add_reference(this.data.reference.addresses, pst);
break;
case 'add':
obj?.add_reference(this.data.reference.addresses, pst);
break;
case 'remove':
obj?.remove_reference(this.data.reference.addresses, false, pst);
break;
case 'removeall':
obj?.remove_reference([], true, pst);
break;
}
}
if (this.data?.mode !== undefined && object_address) { //@ priority??
obj?.set_policy_mode(this.data.mode, pst)
}
if (this.data?.policy !== undefined) {
switch(this.data.policy.op) {
case 'set':
obj?.remove_policies([], true, pst);
obj?.add_policies(this.data.policy.data, pst);
break;
case 'add':
obj?.add_policies(this.data.policy.data, pst);
break;
case 'remove':
obj?.remove_policies(this.data.policy.keys, false, pst);
break;
case 'removeall':
obj?.remove_policies([], true, pst);
break;
case 'rename':
this.data.policy.data.forEach((v) => {
obj?.rename_policy(v.old, v.new, pst);
})
break;
}
}
if (this.data?.data !== undefined) {
switch(this.data.data.op) {
case 'add':
if ((this.data.data?.data as any)?.key !== undefined) {
obj?.add_data(this.data.data.data as Repository_Policy_Data);
} else if ((this.data.data?.data as any)?.address !== undefined) {
obj?.add_data2(this.data.data.data as Repository_Policy_Data2);
}
break;
case 'remove':
this.data.data.data.forEach(v => obj?.remove(v.address, v.key));
break;
}
}
if (permission) {
await this.new_with_mark(txb, permission.launch(), (this.data?.permission as any)?.namedNew, account);
}
if (!this.data.object) {
await this.new_with_mark(txb, obj.launch(), (this.data?.object as any)?.namedNew, account);
}
}
};
}