2020-12-23 17:24:22 +03:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2021-10-20 22:20:43 +03:00
|
|
|
import { CallRequest, SecurityTetraplet } from '@fluencelabs/avm';
|
2021-09-08 12:42:30 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Peer ID's id as a base58 string (multihash/CIDv0).
|
|
|
|
*/
|
2021-01-19 15:47:49 +03:00
|
|
|
export type PeerIdB58 = string;
|
2021-09-08 12:42:30 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Additional information about a service call
|
2021-09-27 22:11:35 +03:00
|
|
|
* @typeparam ArgName
|
2021-09-08 12:42:30 +03:00
|
|
|
*/
|
|
|
|
export interface CallParams<ArgName extends string | null> {
|
|
|
|
/**
|
|
|
|
* The identifier of particle which triggered the call
|
|
|
|
*/
|
|
|
|
particleId: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The peer id which created the particle
|
|
|
|
*/
|
|
|
|
initPeerId: PeerIdB58;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Particle's timestamp when it was created
|
|
|
|
*/
|
2021-10-20 22:20:43 +03:00
|
|
|
timestamp: number;
|
2021-09-08 12:42:30 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Time to live in milliseconds. The time after the particle should be expired
|
|
|
|
*/
|
|
|
|
ttl: number;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Particle's signature
|
|
|
|
*/
|
|
|
|
signature: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Security tetraplets
|
|
|
|
*/
|
|
|
|
tetraplets: { [key in ArgName]: SecurityTetraplet[] };
|
|
|
|
}
|
2021-10-20 22:20:43 +03:00
|
|
|
|
|
|
|
export enum ResultCodes {
|
|
|
|
success = 0,
|
|
|
|
unknownError = 1,
|
|
|
|
exceptionInHandler = 2,
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Particle context. Contains additional information about particle which triggered `call` air instruction from AVM
|
|
|
|
*/
|
|
|
|
export interface ParticleContext {
|
|
|
|
/**
|
2021-11-09 14:37:44 +03:00
|
|
|
* The identifier of particle which triggered the call
|
2021-10-20 22:20:43 +03:00
|
|
|
*/
|
|
|
|
particleId: string;
|
2021-11-09 14:37:44 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The peer id which created the particle
|
|
|
|
*/
|
2021-10-20 22:20:43 +03:00
|
|
|
initPeerId: PeerIdB58;
|
2021-11-09 14:37:44 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Particle's timestamp when it was created
|
|
|
|
*/
|
2021-10-20 22:20:43 +03:00
|
|
|
timestamp: number;
|
2021-11-09 14:37:44 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Time to live in milliseconds. The time after the particle should be expired
|
|
|
|
*/
|
2021-10-20 22:20:43 +03:00
|
|
|
ttl: number;
|
2021-11-09 14:37:44 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Particle's signature
|
|
|
|
*/
|
2021-10-20 22:20:43 +03:00
|
|
|
signature: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents the information passed from AVM when a `call` air instruction is executed on the local peer
|
|
|
|
*/
|
|
|
|
export interface CallServiceData {
|
|
|
|
/**
|
|
|
|
* Service ID as specified in `call` air instruction
|
|
|
|
*/
|
|
|
|
serviceId: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function name as specified in `call` air instruction
|
|
|
|
*/
|
|
|
|
fnName: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Arguments as specified in `call` air instruction
|
|
|
|
*/
|
|
|
|
args: any[];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Security Tetraplets received from AVM
|
|
|
|
*/
|
|
|
|
tetraplets: SecurityTetraplet[][];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Particle context, @see {@link ParticleContext}
|
|
|
|
*/
|
|
|
|
particleContext: ParticleContext;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Type for all the possible objects that can be return to the AVM
|
|
|
|
*/
|
|
|
|
export type CallServiceResultType = object | boolean | number | string | null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generic call service handler
|
|
|
|
*/
|
|
|
|
export type GenericCallServiceHandler = (req: CallServiceData) => CallServiceResult | Promise<CallServiceResult>;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents the result of the `call` air instruction to be returned into AVM
|
|
|
|
*/
|
|
|
|
export interface CallServiceResult {
|
|
|
|
/**
|
|
|
|
* Return code to be returned to AVM
|
|
|
|
*/
|
|
|
|
retCode: ResultCodes;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Result object to be returned to AVM
|
|
|
|
*/
|
|
|
|
result: CallServiceResultType;
|
|
|
|
}
|