mirror of
https://github.com/fluencelabs/aqua-playground
synced 2025-05-02 08:22:22 +00:00
204 lines
6.0 KiB
TypeScript
204 lines
6.0 KiB
TypeScript
|
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()
|
||
|
.withRawScript(
|
||
|
`
|
||
|
(xor
|
||
|
(seq
|
||
|
(seq
|
||
|
(call %init_peer_id% ("getDataSrv" "str") [] str)
|
||
|
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
|
||
|
)
|
||
|
(call %init_peer_id% ("println-service-id" "print") [str])
|
||
|
)
|
||
|
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
|
||
|
)
|
||
|
|
||
|
`,
|
||
|
)
|
||
|
.configHandler((h) => {
|
||
|
h.on('getDataSrv', 'relay', () => {
|
||
|
return client.relayPeerId;
|
||
|
});
|
||
|
h.on('getRelayService', 'hasReleay', () => {// Not Used
|
||
|
return client.relayPeerId !== undefined;
|
||
|
});
|
||
|
h.on('getDataSrv', 'str', () => {return str;});
|
||
|
|
||
|
h.on('errorHandlingSrv', 'error', (args) => {
|
||
|
// assuming error is the single argument
|
||
|
const [err] = args;
|
||
|
reject(err);
|
||
|
});
|
||
|
})
|
||
|
.handleScriptError(reject)
|
||
|
.handleTimeout(() => {
|
||
|
reject('Request timed out');
|
||
|
})
|
||
|
.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()
|
||
|
.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', () => {
|
||
|
return client.relayPeerId;
|
||
|
});
|
||
|
h.on('getRelayService', 'hasReleay', () => {// Not Used
|
||
|
return client.relayPeerId !== undefined;
|
||
|
});
|
||
|
|
||
|
|
||
|
h.on('errorHandlingSrv', 'error', (args) => {
|
||
|
// assuming error is the single argument
|
||
|
const [err] = args;
|
||
|
reject(err);
|
||
|
});
|
||
|
})
|
||
|
.handleScriptError(reject)
|
||
|
.handleTimeout(() => {
|
||
|
reject('Request timed out');
|
||
|
})
|
||
|
.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()
|
||
|
.withRawScript(
|
||
|
`
|
||
|
(xor
|
||
|
(seq
|
||
|
(seq
|
||
|
(call %init_peer_id% ("getDataSrv" "strings") [] strings)
|
||
|
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
|
||
|
)
|
||
|
(fold strings s
|
||
|
(seq
|
||
|
(call %init_peer_id% ("println-service-id" "print") [s])
|
||
|
(next s)
|
||
|
)
|
||
|
)
|
||
|
)
|
||
|
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
|
||
|
)
|
||
|
|
||
|
`,
|
||
|
)
|
||
|
.configHandler((h) => {
|
||
|
h.on('getDataSrv', 'relay', () => {
|
||
|
return client.relayPeerId;
|
||
|
});
|
||
|
h.on('getRelayService', 'hasReleay', () => {// Not Used
|
||
|
return client.relayPeerId !== undefined;
|
||
|
});
|
||
|
h.on('getDataSrv', 'strings', () => {return strings;});
|
||
|
|
||
|
h.on('errorHandlingSrv', 'error', (args) => {
|
||
|
// assuming error is the single argument
|
||
|
const [err] = args;
|
||
|
reject(err);
|
||
|
});
|
||
|
})
|
||
|
.handleScriptError(reject)
|
||
|
.handleTimeout(() => {
|
||
|
reject('Request timed out');
|
||
|
})
|
||
|
.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()
|
||
|
.withRawScript(
|
||
|
`
|
||
|
(xor
|
||
|
(seq
|
||
|
(seq
|
||
|
(call %init_peer_id% ("getDataSrv" "nodes") [] nodes)
|
||
|
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
|
||
|
)
|
||
|
(fold nodes s
|
||
|
(par
|
||
|
(seq
|
||
|
(call relay ("op" "identity") [])
|
||
|
(seq
|
||
|
(call s ("peer" "identify") [] ads)
|
||
|
(seq
|
||
|
(call relay ("op" "identity") [])
|
||
|
(call %init_peer_id% ("callbackSrv" "c") [ads])
|
||
|
)
|
||
|
)
|
||
|
)
|
||
|
(next s)
|
||
|
)
|
||
|
)
|
||
|
)
|
||
|
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error%])
|
||
|
)
|
||
|
|
||
|
`,
|
||
|
)
|
||
|
.configHandler((h) => {
|
||
|
h.on('getDataSrv', 'relay', () => {
|
||
|
return client.relayPeerId;
|
||
|
});
|
||
|
h.on('getRelayService', 'hasReleay', () => {// Not Used
|
||
|
return client.relayPeerId !== undefined;
|
||
|
});
|
||
|
h.on('getDataSrv', 'nodes', () => {return nodes;});
|
||
|
h.on('callbackSrv', 'c', (args) => {return c(args[0]);});
|
||
|
|
||
|
h.on('errorHandlingSrv', 'error', (args) => {
|
||
|
// assuming error is the single argument
|
||
|
const [err] = args;
|
||
|
reject(err);
|
||
|
});
|
||
|
})
|
||
|
.handleScriptError(reject)
|
||
|
.handleTimeout(() => {
|
||
|
reject('Request timed out');
|
||
|
})
|
||
|
.build();
|
||
|
});
|
||
|
await client.initiateFlow(request);
|
||
|
return Promise.race([promise, Promise.resolve()]);
|
||
|
}
|
||
|
|