mirror of
https://github.com/fluencelabs/fluence-js.git
synced 2025-04-25 09:52:12 +00:00
159 lines
5.9 KiB
TypeScript
159 lines
5.9 KiB
TypeScript
/*
|
|
* Copyright 2020 Fluence Labs Limited
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { getService } from './globalState';
|
|
import { SecurityTetraplet } from './securityTetraplet';
|
|
|
|
export interface CallServiceResult {
|
|
ret_code: number;
|
|
result: string;
|
|
}
|
|
|
|
export abstract class Service {
|
|
serviceId: string;
|
|
|
|
/**
|
|
* Calls the function from local client
|
|
* @param fnName - name of the function to call
|
|
* @param args - arguments to be passed to the function
|
|
* @param tetraplets - array of arrays of tetraplets. First index corresponds to argument number.
|
|
* If the argument is not an array the second array will always contain exactly one element.
|
|
* If the argument is an array the second index will correspond to the index of element in argument's array
|
|
*/
|
|
abstract call(fnName: string, args: any[], tetraplets: SecurityTetraplet[][]): CallServiceResult;
|
|
}
|
|
|
|
/**
|
|
* Creates one function for all function names.
|
|
*/
|
|
export class ServiceOne implements Service {
|
|
serviceId: string;
|
|
fn: (fnName: string, args: any[], tetraplets: SecurityTetraplet[][]) => object;
|
|
|
|
constructor(serviceId: string, fn: (fnName: string, args: any[], tetraplets: SecurityTetraplet[][]) => object) {
|
|
this.serviceId = serviceId;
|
|
this.fn = fn;
|
|
}
|
|
|
|
/**
|
|
* Calls the function from local client
|
|
* @param fnName - name of the function to call
|
|
* @param args - arguments to be passed to the function
|
|
* @param tetraplets - array of arrays of tetraplets. First index corresponds to argument number.
|
|
* If the argument is not an array the second array will always contain exactly one element.
|
|
* If the argument is an array the second index will correspond to the index of element in argument's array
|
|
*/
|
|
call(fnName: string, args: any[], tetraplets: SecurityTetraplet[][]): CallServiceResult {
|
|
try {
|
|
let result = this.fn(fnName, args, tetraplets);
|
|
return {
|
|
ret_code: 0,
|
|
result: JSON.stringify(result),
|
|
};
|
|
} catch (err) {
|
|
return {
|
|
ret_code: 1,
|
|
result: JSON.stringify(err),
|
|
};
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Creates function per function name. Returns an error when call a name without registered function.
|
|
*/
|
|
export class ServiceMultiple implements Service {
|
|
serviceId: string;
|
|
functions: Map<string, (args: any[], tetraplets: SecurityTetraplet[][]) => object> = new Map();
|
|
|
|
constructor(serviceId: string) {
|
|
this.serviceId = serviceId;
|
|
}
|
|
|
|
/**
|
|
* Registers a callback function into Aquamarine
|
|
* @param fnName - the function name to be registered
|
|
* @param fn - callback function which will be called from Aquamarine.
|
|
* The callback function has the following parameters:
|
|
* args - arguments to be passed to the function
|
|
* tetraplets - array of arrays of tetraplets. First index corresponds to argument number.
|
|
* If the argument is not an array the second array will always contain exactly one element.
|
|
* If the argument is an array the second index will correspond to the index of element in argument's array
|
|
*/
|
|
registerFunction(fnName: string, fn: (args: any[], tetraplets: SecurityTetraplet[][]) => object) {
|
|
this.functions.set(fnName, fn);
|
|
}
|
|
|
|
/**
|
|
* Calls the function from local client
|
|
* @param fnName - name of the function to call
|
|
* @param args - arguments to be passed to the function
|
|
* @param tetraplets - array of arrays of tetraplets. First index corresponds to argument number.
|
|
* If the argument is not an array the second array will always contain exactly one element.
|
|
* If the argument is an array the second index will correspond to the index of element in argument's array
|
|
*/
|
|
call(fnName: string, args: any[], tetraplets: SecurityTetraplet[][]): CallServiceResult {
|
|
let fn = this.functions.get(fnName);
|
|
if (fn) {
|
|
try {
|
|
let result = fn(args, tetraplets);
|
|
return {
|
|
ret_code: 0,
|
|
result: JSON.stringify(result),
|
|
};
|
|
} catch (err) {
|
|
return {
|
|
ret_code: 1,
|
|
result: JSON.stringify(err),
|
|
};
|
|
}
|
|
} else {
|
|
let errorMsg = `Error. There is no function ${fnName}`;
|
|
return {
|
|
ret_code: 1,
|
|
result: JSON.stringify(errorMsg),
|
|
};
|
|
}
|
|
}
|
|
}
|
|
|
|
export function service(service_id: string, fn_name: string, args: string, tetraplets: string): CallServiceResult {
|
|
try {
|
|
let argsObject = JSON.parse(args);
|
|
if (!Array.isArray(argsObject)) {
|
|
throw new Error('args is not an array');
|
|
}
|
|
|
|
let tetrapletsObject: SecurityTetraplet[][] = JSON.parse(tetraplets);
|
|
|
|
let service = getService(service_id);
|
|
if (service) {
|
|
return service.call(fn_name, argsObject, tetrapletsObject);
|
|
} else {
|
|
return {
|
|
result: JSON.stringify(`Error. There is no service: ${service_id}`),
|
|
ret_code: 0,
|
|
};
|
|
}
|
|
} catch (err) {
|
|
console.error('Cannot parse arguments: ' + JSON.stringify(err));
|
|
return {
|
|
result: JSON.stringify('Cannot parse arguments: ' + JSON.stringify(err)),
|
|
ret_code: 1,
|
|
};
|
|
}
|
|
}
|