X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Ftypes%2FUIProtocol.ts;h=1f78671e2f6a4901c935b41736f1688459c2ff65;hb=02cde3b711fb54b1a72d9828680eea54024d4ea0;hp=3e4d6232ba6202ca395fa57791fe8886b0f332e5;hpb=ee0f106b09f38b1561d970ea4377eb199389298e;p=e-mobility-charging-stations-simulator.git diff --git a/src/types/UIProtocol.ts b/src/types/UIProtocol.ts index 3e4d6232..1f78671e 100644 --- a/src/types/UIProtocol.ts +++ b/src/types/UIProtocol.ts @@ -1,16 +1,52 @@ +import type { JsonObject } from './JsonType'; + +export enum Protocol { + UI = 'ui', +} + +export enum ApplicationProtocol { + HTTP = 'http', + WS = 'ws', +} export enum ProtocolVersion { '0.0.1' = '0.0.1', - '0.0.2' = '0.0.2', } -export enum ProtocolCommand { +export type ProtocolRequest = [string, ProcedureName, RequestPayload]; +export type ProtocolResponse = [string, ResponsePayload]; + +export type ProtocolRequestHandler = ( + uuid?: string, + payload?: RequestPayload +) => undefined | Promise | ResponsePayload | Promise; + +export enum ProcedureName { LIST_CHARGING_STATIONS = 'listChargingStations', + START_CHARGING_STATION = 'startChargingStation', + STOP_CHARGING_STATION = 'stopChargingStation', + START_SIMULATOR = 'startSimulator', + STOP_SIMULATOR = 'stopSimulator', + OPEN_CONNECTION = 'openConnection', + CLOSE_CONNECTION = 'closeConnection', START_TRANSACTION = 'startTransaction', STOP_TRANSACTION = 'stopTransaction', - UNKNOWN = 'unknown', + START_AUTOMATIC_TRANSACTION_GENERATOR = 'startAutomaticTransactionGenerator', + STOP_AUTOMATIC_TRANSACTION_GENERATOR = 'stopAutomaticTransactionGenerator', } -export type ProtocolRequest = [ProtocolVersion, ProtocolCommand, Record]; +export interface RequestPayload extends JsonObject { + hashIds?: string[]; + connectorIds?: number[]; +} -export type ProtocolRequestHandler = (payload: Record) => Record | Promise>; +export enum ResponseStatus { + SUCCESS = 'success', + FAILURE = 'failure', +} + +export interface ResponsePayload extends JsonObject { + status: ResponseStatus; + hashIdsSucceeded?: string[]; + hashIdsFailed?: string[]; +}