mirror of
https://github.com/fluencelabs/fluence-js.git
synced 2025-04-24 17:32:14 +00:00
* * Separate marine worker as a package * Trying to fix tests * Finalizing test fixes * fix: rename back to Fluence CLI (#320) chore: rename back to Fluence CLI * fix(deps): update dependency @fluencelabs/avm to v0.43.1 (#322) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore: release master (#324) * chore: release master * chore: Regenerate pnpm lock file * feat: use marine-js 0.7.2 (#321) * use marine-js 0.5.0 * increace some timeouts * increace some timeouts * use latest marine + remove larger timeouts * propagate CallParameters type * use marine 0.7.2 * Temp use node 18 and 20 * Comment out node 20.x --------- Co-authored-by: Anatoly Laskaris <github_me@nahsi.dev> * chore: Fix test with node 18/20 error message (#323) * Fix test with node 18/20 error message * Run tests on node 18 and 20 * Enhance description * Fix type and obj property --------- Co-authored-by: Anatoly Laskaris <github_me@nahsi.dev> * * Separate marine worker as a package * Trying to fix tests * Finalizing test fixes * * Refactoring packages. * Using CDN to load .wasm deps. * Setting up tests for new architecture * Fix almost all tests * Fix last strange test * Remove package specific packages * Remove avm class as it looks excessive * marine worker new version * misc refactoring/remove console.log's * Rename package js-peer to js-client * Move service info to marine worker * Change CDN path * Fix worker race confition * Remove buffer type * Remove turned off headless mode in platform tests * Remove async keyword to make tests pass * Remove util package * Make js-client.api package just reexport interface from js-client main package * Update package info in CI * Fix review comments * Remove test entry from marine-worker package * Misc fixes * Fix worker type * Add fetchers * Specify correct versions for js-client package * Set first ver for js-client * Update libp2p and related dep versions to the latest * Build all deps into package itself * Fix review * Refine package * Fix comment * Update packages/core/js-client/src/fetchers/browser.ts * Update packages/core/js-client/src/fetchers/index.ts * Update packages/core/js-client/src/fetchers/node.ts * Update packages/core/js-client/src/jsPeer/FluencePeer.ts * Update packages/core/js-client/src/keypair/__test__/KeyPair.spec.ts * Update packages/core/js-client/src/jsPeer/FluencePeer.ts Co-authored-by: shamsartem <shamsartem@gmail.com> * Delete outdated file * Need types for build to work * Inline func call * Add comments to replacement lines. P.S. we can remove some of them after update libp2p --------- Co-authored-by: shamsartem <shamsartem@gmail.com> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: fluencebot <116741523+fluencebot@users.noreply.github.com> Co-authored-by: Valery Antopol <valery.antopol@gmail.com> Co-authored-by: Anatoly Laskaris <github_me@nahsi.dev>
154 lines
4.2 KiB
TypeScript
154 lines
4.2 KiB
TypeScript
/*
|
|
* Copyright 2023 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 type { PeerIdB58 } from '@fluencelabs/interfaces';
|
|
import type { SecurityTetraplet } from '@fluencelabs/avm';
|
|
import { JSONValue } from '../util/commonTypes.js';
|
|
|
|
/**
|
|
* JS Service host a low level interface for managing pure javascript services.
|
|
* It operates on a notion of Call Service Handlers - functions which are called when a `call` air instruction is executed on the local peer.
|
|
*/
|
|
export interface IJsServiceHost {
|
|
/**
|
|
* Returns true if any handler for the specified serviceId is registered
|
|
*/
|
|
hasService(serviceId: string): boolean;
|
|
|
|
/**
|
|
* Find call service handler for specified particle
|
|
* @param serviceId Service ID as specified in `call` air instruction
|
|
* @param fnName Function name as specified in `call` air instruction
|
|
* @param particleId Particle ID
|
|
*/
|
|
getHandler(serviceId: string, fnName: string, particleId: string): GenericCallServiceHandler | null;
|
|
|
|
/**
|
|
* Execute service call for specified call service data
|
|
*/
|
|
callService(req: CallServiceData): Promise<CallServiceResult | null>;
|
|
|
|
/**
|
|
* Register handler for all particles
|
|
*/
|
|
registerGlobalHandler(serviceId: string, fnName: string, handler: GenericCallServiceHandler): void;
|
|
|
|
/**
|
|
* Register handler which will be called only for particle with the specific id
|
|
*/
|
|
registerParticleScopeHandler(
|
|
particleId: string,
|
|
serviceId: string,
|
|
fnName: string,
|
|
handler: GenericCallServiceHandler,
|
|
): void;
|
|
|
|
/**
|
|
* Removes all handlers associated with the specified particle scope
|
|
* @param particleId Particle ID to remove handlers for
|
|
*/
|
|
removeParticleScopeHandlers(particleId: string): void;
|
|
}
|
|
|
|
export enum ResultCodes {
|
|
success = 0,
|
|
error = 1,
|
|
}
|
|
|
|
/**
|
|
* Particle context. Contains additional information about particle which triggered `call` air instruction from AVM
|
|
*/
|
|
export interface ParticleContext {
|
|
/**
|
|
* 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
|
|
*/
|
|
timestamp: number;
|
|
|
|
/**
|
|
* Time to live in milliseconds. The time after the particle should be expired
|
|
*/
|
|
ttl: number;
|
|
|
|
/**
|
|
* Particle's signature
|
|
*/
|
|
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 returned to the AVM
|
|
*/
|
|
export type CallServiceResultType = JSONValue;
|
|
|
|
/**
|
|
* 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;
|
|
}
|