This commit is contained in:
Alexey Proshutinskiy 2022-03-24 20:59:25 +04:00
parent 848e91c0d7
commit adb39e31ae
6 changed files with 279 additions and 196 deletions

View File

@ -7,7 +7,8 @@
"compile-aqua": "aqua -i ./src/aqua -o ./src/generated",
"build": "npm run compile-aqua && tsc",
"prestart": "npm run build",
"start": "node dist/index.js"
"start": "node dist/index.js",
"start_client": "node dist/client.js"
},
"keywords": [],
"author": "Fluence Labs",

View File

@ -1,9 +1,17 @@
module Export
import createRouteAndRegister, resolveRoute from "@fluencelabs/registry/routing.aqua"
import Messaging from "./service.aqua"
export createRouteAndRegister, resolveRoute, Messaging, send_message
import createRouteAndRegister from "@fluencelabs/registry/routing.aqua"
import resolveRoute from "@fluencelabs/registry/routing.aqua"
func send_message(relay: string, peer_id: string, service_id: string, message: string):
on peer_id via HOST_PEER_ID via relay:
Messaging service_id
Messaging.receive(message)
import GreetingService from "./service.aqua"
export createRouteAndRegister, GreetingService, greeting
const ACK = 5
func greeting(route_id: string, message: string) -> []string:
providers <- resolveRoute(route_id, ACK)
res: *string
for p <- providers:
on p.peer_id via p.relay_id:
GreetingService p.service_id!
res <- GreetingService.greeting(message)
<- res

View File

@ -1,4 +1,4 @@
module Service declares Messaging
module Service declares GreetingService
service Messaging:
receive(msg: string)
service GreetingService:
greeting(name: string) -> string

View File

@ -1,14 +1,13 @@
import { resolveRoute, send_message} from "./generated/export"
import { greeting } from "./generated/export"
import { krasnodar } from "@fluencelabs/fluence-network-environment"
import {Fluence} from "@fluencelabs/fluence"
import { Fluence } from "@fluencelabs/fluence"
async function main(route_id: string) {
await Fluence.start({connectTo: krasnodar[0]});
console.log(route_id);
let providers = await resolveRoute(route_id, 3);
console.log("Providers:", providers);
let provider = providers[0];
await send_message(provider.relay_id[0], provider.peer_id, provider.service_id[0], "hello world");
await Fluence.start({connectTo: krasnodar[4]});
console.log(Fluence.getStatus().relayPeerId);
let results = await greeting(route_id, "Alexey");
console.log("Results:", results);
}
let route_id = process.argv[2];

View File

@ -16,33 +16,39 @@ import {
// Services
export interface MessagingDef {
receive: (msg: string, callParams: CallParams<'msg'>) => void | Promise<void>;
export interface GreetingServiceDef {
greeting: (name: string, callParams: CallParams<'name'>) => string | Promise<string>;
}
export function registerMessaging(serviceId: string, service: MessagingDef): void;
export function registerMessaging(peer: FluencePeer, serviceId: string, service: MessagingDef): void;
export function registerGreetingService(serviceId: string, service: GreetingServiceDef): void;
export function registerGreetingService(peer: FluencePeer, serviceId: string, service: GreetingServiceDef): void;
export function registerMessaging(...args: any) {
export function registerGreetingService(...args: any) {
registerService(
args,
{
"functions" : {
"tag" : "labeledProduct",
"fields" : {
"receive" : {
"greeting" : {
"tag" : "arrow",
"domain" : {
"tag" : "labeledProduct",
"fields" : {
"msg" : {
"name" : {
"tag" : "scalar",
"name" : "string"
}
}
},
"codomain" : {
"tag" : "nil"
"tag" : "unlabeledProduct",
"items" : [
{
"tag" : "scalar",
"name" : "string"
}
]
}
}
}
@ -54,165 +60,164 @@ export function registerMessaging(...args: any) {
// Functions
export function resolveRoute(
route_id: string,
ack: number,
export function registerForRouteNode(
subscriber_node_id: string,
label: string,
value: string,
service_id: string | null,
config?: {ttl?: number}
): Promise<{ peer_id: string; relay_id: string[]; route_id: string; service_id: string[]; set_by: string; signature: number[]; solution: number[]; timestamp_created: number; value: string; }[]>;
): Promise<void>;
export function resolveRoute(
export function registerForRouteNode(
peer: FluencePeer,
route_id: string,
ack: number,
subscriber_node_id: string,
label: string,
value: string,
service_id: string | null,
config?: {ttl?: number}
): Promise<{ peer_id: string; relay_id: string[]; route_id: string; service_id: string[]; set_by: string; signature: number[]; solution: number[]; timestamp_created: number; value: string; }[]>;
): Promise<void>;
export function resolveRoute(...args: any) {
export function registerForRouteNode(...args: any) {
let script = `
(xor
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(call %init_peer_id% ("getDataSrv" "-relay-") [] -relay-)
(call %init_peer_id% ("getDataSrv" "route_id") [] route_id)
(call %init_peer_id% ("getDataSrv" "subscriber_node_id") [] subscriber_node_id)
)
(call %init_peer_id% ("getDataSrv" "ack") [] ack)
(call %init_peer_id% ("getDataSrv" "label") [] label)
)
(call %init_peer_id% ("getDataSrv" "value") [] value)
)
(call %init_peer_id% ("getDataSrv" "service_id") [] service_id)
)
(call %init_peer_id% ("peer" "timestamp_sec") [] t)
)
(xor
(call -relay- ("registry" "get_route_bytes") [label [] t [] ""] bytes)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 1])
)
)
(call %init_peer_id% ("sig" "sign") [bytes] signature)
)
(xor
(call -relay- ("registry" "get_route_id") [label %init_peer_id%] route_id)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 2])
)
)
(xor
(call -relay- ("registry" "get_host_record_bytes") [route_id value [] service_id t []] bytes-0)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 3])
)
)
(call %init_peer_id% ("sig" "sign") [bytes-0] signature-0)
)
(call -relay- ("op" "noop") [])
)
(new $res
(xor
(seq
(seq
(seq
(seq
(call -relay- ("op" "string_to_b58") [route_id] k)
(call -relay- ("kad" "neighborhood") [k [] []] nodes)
(seq
(seq
(call subscriber_node_id ("peer" "timestamp_sec") [] t-0)
(call subscriber_node_id ("trust-graph" "get_weight") [%init_peer_id% t-0] weight)
)
(call subscriber_node_id ("registry" "put_host_record") [route_id value [] service_id t [] signature-0.$.signature.[0]! weight t-0] result)
)
(call subscriber_node_id ("op" "string_to_b58") [route_id] k)
)
(call subscriber_node_id ("kad" "neighborhood") [k [] []] nodes)
)
(par
(fold nodes n
(par
(seq
(xor
(xor
(seq
(seq
(call n ("peer" "timestamp_sec") [] t)
(call n ("registry" "get_records") [route_id t] get_result)
(seq
(seq
(seq
(call n ("peer" "timestamp_sec") [] t-1)
(call n ("trust-graph" "get_weight") [%init_peer_id% t-1] weight-0)
)
(ap get_result.$.result! $res)
(call n ("registry" "register_route") [label [] t [] "" signature.$.signature.[0]! false weight-0 t-1] result-0)
)
(call n ("peer" "timestamp_sec") [] t-2)
)
(call n ("trust-graph" "get_weight") [%init_peer_id% t-2] weight-1)
)
(call n ("registry" "propagate_host_record") [result t-2 weight-1] result-1)
)
(null)
)
(seq
(call -relay- ("op" "noop") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 1])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 4])
)
)
(call -relay- ("op" "noop") [])
)
(next n)
)
)
(null)
)
)
(call -relay- ("op" "noop") [$res.$.[ack]!])
(call -relay- ("op" "noop") [])
)
(call -relay- ("registry" "merge") [$res] result)
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 2])
(seq
(call -relay- ("op" "noop") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 5])
)
)
)
(xor
(call %init_peer_id% ("callbackSrv" "response") [result.$.result!])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 3])
)
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 4])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 6])
)
`
return callFunction(
args,
{
"functionName" : "resolveRoute",
"functionName" : "registerForRouteNode",
"arrow" : {
"tag" : "arrow",
"domain" : {
"tag" : "labeledProduct",
"fields" : {
"route_id" : {
"subscriber_node_id" : {
"tag" : "scalar",
"name" : "string"
},
"ack" : {
"tag" : "scalar",
"name" : "i16"
}
}
},
"codomain" : {
"tag" : "unlabeledProduct",
"items" : [
{
"tag" : "array",
"type" : {
"tag" : "struct",
"name" : "Record",
"fields" : {
"relay_id" : {
"tag" : "array",
"type" : {
"label" : {
"tag" : "scalar",
"name" : "string"
}
},
"signature" : {
"tag" : "array",
"type" : {
"tag" : "scalar",
"name" : "u8"
}
},
"solution" : {
"tag" : "array",
"type" : {
"tag" : "scalar",
"name" : "u8"
}
},
"route_id" : {
"tag" : "scalar",
"name" : "string"
},
"set_by" : {
"tag" : "scalar",
"name" : "string"
},
"peer_id" : {
"tag" : "scalar",
"name" : "string"
},
"service_id" : {
"tag" : "array",
"type" : {
"tag" : "scalar",
"name" : "string"
}
},
"value" : {
"tag" : "scalar",
"name" : "string"
},
"timestamp_created" : {
"service_id" : {
"tag" : "option",
"type" : {
"tag" : "scalar",
"name" : "u64"
"name" : "string"
}
}
}
}
]
},
"codomain" : {
"tag" : "nil"
}
},
"names" : {
@ -404,85 +409,144 @@ export function createRouteAndRegister(...args: any) {
export function send_message(
relay: string,
peer_id: string,
service_id: string,
export function greeting(
route_id: string,
message: string,
config?: {ttl?: number}
): Promise<void>;
): Promise<string[]>;
export function send_message(
export function greeting(
peer: FluencePeer,
relay: string,
peer_id: string,
service_id: string,
route_id: string,
message: string,
config?: {ttl?: number}
): Promise<void>;
): Promise<string[]>;
export function send_message(...args: any) {
export function greeting(...args: any) {
let script = `
(xor
(seq
(seq
(seq
(seq
(seq
(seq
(seq
(call %init_peer_id% ("getDataSrv" "-relay-") [] -relay-)
(call %init_peer_id% ("getDataSrv" "relay") [] relay)
)
(call %init_peer_id% ("getDataSrv" "peer_id") [] peer_id)
)
(call %init_peer_id% ("getDataSrv" "service_id") [] service_id)
(call %init_peer_id% ("getDataSrv" "route_id") [] route_id)
)
(call %init_peer_id% ("getDataSrv" "message") [] message)
)
(new $res
(seq
(seq
(new $res-0
(xor
(seq
(seq
(seq
(seq
(call -relay- ("op" "string_to_b58") [route_id] k)
(call -relay- ("kad" "neighborhood") [k [] []] nodes)
)
(par
(fold nodes n
(par
(seq
(xor
(xor
(seq
(seq
(call n ("peer" "timestamp_sec") [] t)
(call n ("registry" "get_records") [route_id t] get_result)
)
(ap get_result.$.result! $res-0)
)
(null)
)
(seq
(call -relay- ("op" "noop") [])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 1])
)
)
(call -relay- ("op" "noop") [])
)
(call relay ("op" "noop") [])
(next n)
)
)
(null)
)
)
(call -relay- ("op" "noop") [$res-0.$.[5]!])
)
(call -relay- ("registry" "merge") [$res-0] result)
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 2])
)
)
(fold result.$.result! p
(seq
(seq
(seq
(call -relay- ("op" "noop") [])
(fold p.$.relay_id! -via-peer-
(seq
(call -via-peer- ("op" "noop") [])
(next -via-peer-)
)
)
)
(xor
(seq
(seq
(call peer_id (service_id "receive") [message])
(call relay ("op" "noop") [])
(call p.$.peer_id! (p.$.service_id.[0]! "greeting") [message] $res)
(fold p.$.relay_id! -via-peer-
(seq
(next -via-peer-)
(call -via-peer- ("op" "noop") [])
)
)
)
(call -relay- ("op" "noop") [])
)
(seq
(seq
(call relay ("op" "noop") [])
(fold p.$.relay_id! -via-peer-
(seq
(call -via-peer- ("op" "noop") [])
(next -via-peer-)
)
)
(call -relay- ("op" "noop") [])
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 1])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 3])
)
)
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 2])
(next p)
)
)
)
(call %init_peer_id% ("op" "identity") [$res] res-fix)
)
)
)
(xor
(call %init_peer_id% ("callbackSrv" "response") [res-fix])
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 4])
)
)
(call %init_peer_id% ("errorHandlingSrv" "error") [%last_error% 5])
)
`
return callFunction(
args,
{
"functionName" : "send_message",
"functionName" : "greeting",
"arrow" : {
"tag" : "arrow",
"domain" : {
"tag" : "labeledProduct",
"fields" : {
"relay" : {
"tag" : "scalar",
"name" : "string"
},
"peer_id" : {
"tag" : "scalar",
"name" : "string"
},
"service_id" : {
"route_id" : {
"tag" : "scalar",
"name" : "string"
},
@ -493,7 +557,16 @@ export function send_message(...args: any) {
}
},
"codomain" : {
"tag" : "nil"
"tag" : "unlabeledProduct",
"items" : [
{
"tag" : "array",
"type" : {
"tag" : "scalar",
"name" : "string"
}
}
]
}
},
"names" : {

View File

@ -1,23 +1,25 @@
import {createRouteAndRegister, registerMessaging, resolveRoute, send_message} from "./generated/export"
import {createRouteAndRegister, registerGreetingService} from "./generated/export"
import { krasnodar } from "@fluencelabs/fluence-network-environment"
import {Fluence} from "@fluencelabs/fluence"
import { Fluence } from "@fluencelabs/fluence"
async function main() {
await Fluence.start({connectTo: krasnodar[0]});
console.log('our peer id', Fluence.getStatus().peerId);
let relay_id = Fluence.getStatus().relayPeerId;
console.log('connected to', Fluence.getStatus().relayPeerId);
let label = "messaging_label";
let value = "so important";
let service_id = "my_messaging";
await registerMessaging(service_id, {
receive: (msg) => {
console.log("Message received:", msg);
let relay_id = Fluence.getStatus().relayPeerId;
let service_id = "my_greeting_service";
await registerGreetingService(service_id, {
greeting: (name) => {
console.log("Message received:", name);
return "Hi, " + name;
}
})
let label = "my_greeting_label";
let value = "so important";
let route_id = await createRouteAndRegister(label, value, relay_id, service_id);
console.log("Route id:", route_id);
process.stdin.setRawMode(true);