Files
aqua-playground/src/compiled/on.ts

184 lines
5.5 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-15 18:19:24 +03:00
import { FluenceClient, PeerIdB58 } from '@fluencelabs/fluence';
import { RequestFlowBuilder } from '@fluencelabs/fluence/dist/api.unstable';
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") [])
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
`,
)
.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', 'hasReleay', () => {// Not Used
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 getPeerExternalAddresses(client: FluenceClient, otherNodePeerId: string): Promise<string[]> {
let request;
const promise = new Promise<string[]>((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
(seq
(seq
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
2021-04-23 17:21:58 +03:00
(call %init_peer_id% ("getDataSrv" "otherNodePeerId") [] otherNodePeerId)
2021-04-15 18:19:24 +03:00
)
(seq
(call relay ("op" "identity") [])
(call otherNodePeerId ("peer" "identify") [] res)
)
)
(call relay ("op" "identity") [])
)
(call %init_peer_id% ("callbackSrv" "response") [res.$.external_addresses!])
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
`,
)
.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', 'hasReleay', () => {// Not Used
return client.relayPeerId !== undefined;
});
h.on('getDataSrv', 'otherNodePeerId', () => {return otherNodePeerId;});
2021-04-23 17:21:58 +03:00
h.onEvent('callbackSrv', 'response', (args) => {
2021-04-15 18:19:24 +03:00
const [res] = args;
resolve(res);
});
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 getPeerExternalAddresses');
2021-04-15 18:19:24 +03:00
})
.build();
});
await client.initiateFlow(request);
return promise;
}
export async function getDistantAddresses(client: FluenceClient, target: string, viaNode: string): Promise<string[]> {
let request;
const promise = new Promise<string[]>((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
(seq
(seq
(seq
(seq
2021-04-23 17:21:58 +03:00
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
2021-04-15 18:19:24 +03:00
(call %init_peer_id% ("getDataSrv" "target") [] target)
)
2021-04-23 17:21:58 +03:00
(call %init_peer_id% ("getDataSrv" "viaNode") [] viaNode)
2021-04-15 18:19:24 +03:00
)
(seq
(seq
(call relay ("op" "identity") [])
(call viaNode ("op" "identity") [])
)
(call target ("peer" "identify") [] res)
)
)
(call viaNode ("op" "identity") [])
)
(call relay ("op" "identity") [])
)
(call %init_peer_id% ("callbackSrv" "response") [res.$.external_addresses!])
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
)
`,
)
.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', 'hasReleay', () => {// Not Used
return client.relayPeerId !== undefined;
});
h.on('getDataSrv', 'target', () => {return target;});
h.on('getDataSrv', 'viaNode', () => {return viaNode;});
2021-04-23 17:21:58 +03:00
h.onEvent('callbackSrv', 'response', (args) => {
2021-04-15 18:19:24 +03:00
const [res] = args;
resolve(res);
});
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 getDistantAddresses');
2021-04-15 18:19:24 +03:00
})
.build();
});
await client.initiateFlow(request);
return promise;
}