X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Ftypes%2Focpp%2FRequests.ts;h=ed9dac1a71fe2d8de071adb90093a945de149eff;hb=85c603dabe1b0415dfa956baec73f34267093cf0;hp=26d8bd7efbdb4b8469e592b5c08916d4ca7a960f;hpb=6ce0bca57a96ef920df4e0786d8f28b0b89a36ef;p=e-mobility-charging-stations-simulator.git diff --git a/src/types/ocpp/Requests.ts b/src/types/ocpp/Requests.ts index 26d8bd7e..ed9dac1a 100644 --- a/src/types/ocpp/Requests.ts +++ b/src/types/ocpp/Requests.ts @@ -1,39 +1,69 @@ -import { OCPP16AvailabilityType, OCPP16BootNotificationRequest, OCPP16IncomingRequestCommand, OCPP16RequestCommand } from './1.6/Requests'; - -import { MessageType } from './MessageType'; +import type ChargingStation from '../../charging-station/ChargingStation'; +import OCPPError from '../../exception/OCPPError'; +import { JsonType } from '../JsonType'; import { OCPP16DiagnosticsStatus } from './1.6/DiagnosticsStatus'; -import OCPPError from '../../charging-station/OCPPError'; +import { OCPP16MeterValuesRequest } from './1.6/MeterValues'; +import { + OCPP16AvailabilityType, + OCPP16BootNotificationRequest, + OCPP16HeartbeatRequest, + OCPP16IncomingRequestCommand, + OCPP16RequestCommand, + OCPP16StatusNotificationRequest, +} from './1.6/Requests'; +import { MessageType } from './MessageType'; + +export type RequestCommand = OCPP16RequestCommand; + +export const RequestCommand = { + ...OCPP16RequestCommand, +}; + +export type OutgoingRequest = [MessageType.CALL_MESSAGE, string, RequestCommand, JsonType]; -export default interface Requests { - [id: string]: Request; +export interface RequestParams { + skipBufferingOnError?: boolean; + triggerMessage?: boolean; } +export type IncomingRequestCommand = OCPP16IncomingRequestCommand; + +export const IncomingRequestCommand = { + ...OCPP16IncomingRequestCommand, +}; + +export type IncomingRequest = [MessageType.CALL_MESSAGE, string, IncomingRequestCommand, JsonType]; + +export type CachedRequest = [ + (payload: JsonType, requestPayload: JsonType) => void, + (error: OCPPError, requestStatistic?: boolean) => void, + RequestCommand | IncomingRequestCommand, + JsonType +]; + export type BootNotificationRequest = OCPP16BootNotificationRequest; -export type AvailabilityType = OCPP16AvailabilityType; +export type HeartbeatRequest = OCPP16HeartbeatRequest; -export const AvailabilityType = { - ...OCPP16AvailabilityType -}; +export type StatusNotificationRequest = OCPP16StatusNotificationRequest; -export type RequestCommand = OCPP16RequestCommand; +export type MeterValuesRequest = OCPP16MeterValuesRequest; -export const RequestCommand = { - ...OCPP16RequestCommand -}; +export type IncomingRequestHandler = ( + chargingStation: ChargingStation, + commandPayload: JsonType +) => JsonType | Promise; -export type IncomingRequestCommand = OCPP16IncomingRequestCommand; +export type AvailabilityType = OCPP16AvailabilityType; -export const IncomingRequestCommand = { - ...OCPP16IncomingRequestCommand +export const AvailabilityType = { + ...OCPP16AvailabilityType, }; export type DiagnosticsStatus = OCPP16DiagnosticsStatus; export const DiagnosticsStatus = { - ...OCPP16DiagnosticsStatus + ...OCPP16DiagnosticsStatus, }; -export type Request = [(payload: Record | string, requestPayload: Record) => void, (error: OCPPError) => void, Record]; - -export type IncomingRequest = [MessageType, string, IncomingRequestCommand, Record, Record]; +export type ResponseType = JsonType | OCPPError;