231 lines
6.8 KiB
TypeScript
Raw Normal View History

2021-04-23 17:21:58 +03:00
/**
*
* This file is auto-generated. Do not edit manually: changes may be erased.
* Generated by Aqua compiler: https://github.com/fluencelabs/aqua/.
* If you find any bugs, please write an issue on GitHub: https://github.com/fluencelabs/aqua/issues
2021-04-29 11:56:02 +03:00
* Aqua version: 0.1.1-SNAPSHOT
2021-04-23 17:21:58 +03:00
*
*/
2021-04-15 18:19:24 +03:00
import { FluenceClient, PeerIdB58 } from '@fluencelabs/fluence';
import { RequestFlowBuilder } from '@fluencelabs/fluence/dist/api.unstable';
export async function print(client: FluenceClient, str: string): Promise<void> {
let request;
const promise = new Promise<void>((resolve, reject) => {
request = new RequestFlowBuilder()
2021-04-23 17:21:58 +03:00
.disableInjections()
2021-04-15 18:19:24 +03:00
.withRawScript(
`
(xor
(seq
(seq
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
2021-04-23 17:21:58 +03:00
(call %init_peer_id% ("getDataSrv" "str") [] str)
2021-04-15 18:19:24 +03:00
)
(call %init_peer_id% ("println-service-id" "print") [str])
)
2021-04-29 11:56:02 +03:00
(seq
(call relay ("op" "identity") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
2021-04-15 18:19:24 +03:00
)
`,
)
.configHandler((h) => {
h.on('getDataSrv', 'relay', () => {
2021-04-23 17:21:58 +03:00
return client.relayPeerId!;
2021-04-15 18:19:24 +03:00
});
h.on('getRelayService', 'hasRelay', () => {// Not Used
2021-04-15 18:19:24 +03:00
return client.relayPeerId !== undefined;
});
h.on('getDataSrv', 'str', () => {return str;});
2021-04-23 17:21:58 +03:00
h.onEvent('errorHandlingSrv', 'error', (args) => {
2021-04-15 18:19:24 +03:00
// assuming error is the single argument
const [err] = args;
reject(err);
});
})
.handleScriptError(reject)
.handleTimeout(() => {
2021-04-23 17:21:58 +03:00
reject('Request timed out for print');
2021-04-15 18:19:24 +03:00
})
.build();
});
await client.initiateFlow(request);
return Promise.race([promise, Promise.resolve()]);
}
export async function id(client: FluenceClient): Promise<void> {
let request;
const promise = new Promise<void>((resolve, reject) => {
request = new RequestFlowBuilder()
2021-04-23 17:21:58 +03:00
.disableInjections()
2021-04-15 18:19:24 +03:00
.withRawScript(
`
(xor
(seq
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
(call %init_peer_id% ("op" "identity") [])
)
2021-04-29 11:56:02 +03:00
(seq
(call relay ("op" "identity") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
2021-04-15 18:19:24 +03:00
)
`,
)
.configHandler((h) => {
h.on('getDataSrv', 'relay', () => {
2021-04-23 17:21:58 +03:00
return client.relayPeerId!;
2021-04-15 18:19:24 +03:00
});
h.on('getRelayService', 'hasRelay', () => {// Not Used
2021-04-15 18:19:24 +03:00
return client.relayPeerId !== undefined;
});
2021-04-23 17:21:58 +03:00
h.onEvent('errorHandlingSrv', 'error', (args) => {
2021-04-15 18:19:24 +03:00
// assuming error is the single argument
const [err] = args;
reject(err);
});
})
.handleScriptError(reject)
.handleTimeout(() => {
2021-04-23 17:21:58 +03:00
reject('Request timed out for id');
2021-04-15 18:19:24 +03:00
})
.build();
});
await client.initiateFlow(request);
return Promise.race([promise, Promise.resolve()]);
}
export async function iterateAndPrint(client: FluenceClient, strings: string[]): Promise<void> {
let request;
const promise = new Promise<void>((resolve, reject) => {
request = new RequestFlowBuilder()
2021-04-23 17:21:58 +03:00
.disableInjections()
2021-04-15 18:19:24 +03:00
.withRawScript(
`
(xor
(seq
(seq
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
2021-04-23 17:21:58 +03:00
(call %init_peer_id% ("getDataSrv" "strings") [] strings)
2021-04-15 18:19:24 +03:00
)
(fold strings s
(seq
(call %init_peer_id% ("println-service-id" "print") [s])
(next s)
)
)
)
2021-04-29 11:56:02 +03:00
(seq
(call relay ("op" "identity") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
2021-04-15 18:19:24 +03:00
)
`,
)
.configHandler((h) => {
h.on('getDataSrv', 'relay', () => {
2021-04-23 17:21:58 +03:00
return client.relayPeerId!;
2021-04-15 18:19:24 +03:00
});
h.on('getRelayService', 'hasRelay', () => {// Not Used
2021-04-15 18:19:24 +03:00
return client.relayPeerId !== undefined;
});
h.on('getDataSrv', 'strings', () => {return strings;});
2021-04-23 17:21:58 +03:00
h.onEvent('errorHandlingSrv', 'error', (args) => {
2021-04-15 18:19:24 +03:00
// assuming error is the single argument
const [err] = args;
reject(err);
});
})
.handleScriptError(reject)
.handleTimeout(() => {
2021-04-23 17:21:58 +03:00
reject('Request timed out for iterateAndPrint');
2021-04-15 18:19:24 +03:00
})
.build();
});
await client.initiateFlow(request);
return Promise.race([promise, Promise.resolve()]);
}
export async function iterateAndPrintParallel(client: FluenceClient, nodes: string[], c: (arg0: {external_addresses:string[]}) => void): Promise<void> {
let request;
const promise = new Promise<void>((resolve, reject) => {
request = new RequestFlowBuilder()
2021-04-23 17:21:58 +03:00
.disableInjections()
2021-04-15 18:19:24 +03:00
.withRawScript(
`
(xor
(seq
(seq
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
2021-04-23 17:21:58 +03:00
(call %init_peer_id% ("getDataSrv" "nodes") [] nodes)
2021-04-15 18:19:24 +03:00
)
(fold nodes s
(par
(seq
(seq
(seq
2021-04-29 11:56:02 +03:00
(seq
(call relay ("op" "identity") [])
(call s ("peer" "identify") [] ads)
)
2021-04-15 18:19:24 +03:00
(call relay ("op" "identity") [])
)
2021-04-29 11:56:02 +03:00
(call %init_peer_id% ("callbackSrv" "c") [ads])
2021-04-15 18:19:24 +03:00
)
2021-04-29 11:56:02 +03:00
(call relay ("op" "identity") [])
2021-04-15 18:19:24 +03:00
)
(next s)
)
)
)
2021-04-29 11:56:02 +03:00
(seq
(call relay ("op" "identity") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
2021-04-15 18:19:24 +03:00
)
`,
)
.configHandler((h) => {
h.on('getDataSrv', 'relay', () => {
2021-04-23 17:21:58 +03:00
return client.relayPeerId!;
2021-04-15 18:19:24 +03:00
});
h.on('getRelayService', 'hasRelay', () => {// Not Used
2021-04-15 18:19:24 +03:00
return client.relayPeerId !== undefined;
});
h.on('getDataSrv', 'nodes', () => {return nodes;});
2021-04-23 17:21:58 +03:00
h.on('callbackSrv', 'c', (args) => {c(args[0]); return {};});
2021-04-15 18:19:24 +03:00
2021-04-23 17:21:58 +03:00
h.onEvent('errorHandlingSrv', 'error', (args) => {
2021-04-15 18:19:24 +03:00
// assuming error is the single argument
const [err] = args;
reject(err);
});
})
.handleScriptError(reject)
.handleTimeout(() => {
2021-04-23 17:21:58 +03:00
reject('Request timed out for iterateAndPrintParallel');
2021-04-15 18:19:24 +03:00
})
.build();
});
await client.initiateFlow(request);
return Promise.race([promise, Promise.resolve()]);
}