mirror of
https://github.com/fluencelabs/aqua-playground
synced 2025-06-23 21:41:48 +00:00
140 lines
4.0 KiB
TypeScript
140 lines
4.0 KiB
TypeScript
/**
|
|
*
|
|
* 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
|
|
* Aqua version: 0.2.1-SNAPSHOT
|
|
*
|
|
*/
|
|
import { FluenceClient, PeerIdB58 } from '@fluencelabs/fluence';
|
|
import { RequestFlowBuilder } from '@fluencelabs/fluence/dist/api.unstable';
|
|
import { RequestFlow } from '@fluencelabs/fluence/dist/internal/RequestFlow';
|
|
|
|
|
|
// Services
|
|
|
|
//TestService
|
|
//defaultId = "test-service"
|
|
|
|
//get_records: (key: string) => string[]
|
|
//END TestService
|
|
|
|
|
|
|
|
// Functions
|
|
|
|
export async function append_records(client: FluenceClient, peer: string, srum: string[][], config?: {ttl?: number}): Promise<void> {
|
|
let request: RequestFlow;
|
|
const promise = new Promise<void>((resolve, reject) => {
|
|
const r = new RequestFlowBuilder()
|
|
.disableInjections()
|
|
.withRawScript(
|
|
`
|
|
(xor
|
|
(seq
|
|
(seq
|
|
(seq
|
|
(seq
|
|
(call %init_peer_id% ("getDataSrv" "-relay-") [] -relay-)
|
|
(call %init_peer_id% ("getDataSrv" "peer") [] peer)
|
|
)
|
|
(call %init_peer_id% ("getDataSrv" "srum") [] srum-iter)
|
|
)
|
|
(fold srum-iter srum-item
|
|
(seq
|
|
(ap srum-item $srum)
|
|
(next srum-item)
|
|
)
|
|
)
|
|
)
|
|
(call %init_peer_id% ("test-service" "get_records") [peer] $srum)
|
|
)
|
|
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 1])
|
|
)
|
|
|
|
`,
|
|
)
|
|
.configHandler((h) => {
|
|
h.on('getDataSrv', '-relay-', () => {
|
|
return client.relayPeerId!;
|
|
});
|
|
h.on('getDataSrv', 'peer', () => {return peer;});
|
|
h.on('getDataSrv', 'srum', () => {return srum;});
|
|
|
|
h.onEvent('errorHandlingSrv', 'error', (args) => {
|
|
// assuming error is the single argument
|
|
const [err] = args;
|
|
reject(err);
|
|
});
|
|
})
|
|
.handleScriptError(reject)
|
|
.handleTimeout(() => {
|
|
reject('Request timed out for append_records');
|
|
})
|
|
if(config && config.ttl) {
|
|
r.withTTL(config.ttl)
|
|
}
|
|
request = r.build();
|
|
});
|
|
await client.initiateFlow(request!);
|
|
return Promise.race([promise, Promise.resolve()]);
|
|
}
|
|
|
|
|
|
|
|
export async function retrieve_records(client: FluenceClient, peer: string, config?: {ttl?: number}): Promise<string[][]> {
|
|
let request: RequestFlow;
|
|
const promise = new Promise<string[][]>((resolve, reject) => {
|
|
const r = new RequestFlowBuilder()
|
|
.disableInjections()
|
|
.withRawScript(
|
|
`
|
|
(xor
|
|
(seq
|
|
(seq
|
|
(seq
|
|
(call %init_peer_id% ("getDataSrv" "-relay-") [] -relay-)
|
|
(call %init_peer_id% ("getDataSrv" "peer") [] peer)
|
|
)
|
|
(call %init_peer_id% ("test-service" "get_records") [peer] $records)
|
|
)
|
|
(xor
|
|
(call %init_peer_id% ("callbackSrv" "response") [$records])
|
|
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 1])
|
|
)
|
|
)
|
|
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 2])
|
|
)
|
|
|
|
`,
|
|
)
|
|
.configHandler((h) => {
|
|
h.on('getDataSrv', '-relay-', () => {
|
|
return client.relayPeerId!;
|
|
});
|
|
h.on('getDataSrv', 'peer', () => {return peer;});
|
|
h.onEvent('callbackSrv', 'response', (args) => {
|
|
const [res] = args;
|
|
resolve(res);
|
|
});
|
|
|
|
h.onEvent('errorHandlingSrv', 'error', (args) => {
|
|
// assuming error is the single argument
|
|
const [err] = args;
|
|
reject(err);
|
|
});
|
|
})
|
|
.handleScriptError(reject)
|
|
.handleTimeout(() => {
|
|
reject('Request timed out for retrieve_records');
|
|
})
|
|
if(config && config.ttl) {
|
|
r.withTTL(config.ttl)
|
|
}
|
|
request = r.build();
|
|
});
|
|
await client.initiateFlow(request!);
|
|
return promise;
|
|
}
|
|
|