remotetrigger

package
v0.16.0-modified Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 20, 2023 License: MIT Imports: 6 Imported by: 0

Documentation

Overview

Contains support for remote triggering of Charge Point initiated messages.

Index

Constants

View Source
const ProfileName = "RemoteTrigger"

The profile name

View Source
const TriggerMessageFeatureName = "TriggerMessage"

Variables

Provides support for remote triggering of Charge Point initiated messages.

Functions

This section is empty.

Types

type CentralSystemHandler

type CentralSystemHandler interface {
}

Needs to be implemented by Central systems for handling messages part of the OCPP 1.6 RemoteTrigger profile.

type ChargePointHandler

type ChargePointHandler interface {
	OnTriggerMessage(request *TriggerMessageRequest) (confirmation *TriggerMessageConfirmation, err error)
}

Needs to be implemented by Charge points for handling messages part of the OCPP 1.6 RemoteTrigger profile.

type MessageTrigger

type MessageTrigger string

Type of request to be triggered in a TriggerMessageRequest

type TriggerMessageConfirmation

type TriggerMessageConfirmation struct {
	Status TriggerMessageStatus `json:"status" validate:"required,triggerMessageStatus"`
}

This field definition of the TriggerMessage confirmation payload, sent by the Charge Point to the Central System in response to a TriggerMessageRequest. In case the request was invalid, or couldn't be processed, an error will be sent instead.

func NewTriggerMessageConfirmation

func NewTriggerMessageConfirmation(status TriggerMessageStatus) *TriggerMessageConfirmation

Creates a new TriggerMessageConfirmation, containing all required fields. There are no optional fields for this message.

func (TriggerMessageConfirmation) GetFeatureName

func (c TriggerMessageConfirmation) GetFeatureName() string

type TriggerMessageFeature

type TriggerMessageFeature struct{}

During normal operation, the Charge Point informs the Central System of its state and any relevant occurrences. If there is nothing to report the Charge Point will send at least a heartBeat at a predefined interval. Under normal circumstances this is just fine, but what if the Central System has (whatever) reason to doubt the last known state? What can a Central System do if a firmware update is in progress and the last status notification it received about it was much longer ago than could reasonably be expected? The same can be asked for the progress of a diagnostics request. The problem in these situations is not that the information needed isn’t covered by existing messages, the problem is strictly a timing issue. The Charge Point has the information, but has no way of knowing that the Central System would like an update. The TriggerMessageRequest makes it possible for the Central System, to request the Charge Point, to send Charge Point-initiated messages. In the request the Central System indicates which message it wishes to receive. For every such requested message the Central System MAY optionally indicate to which connector this request applies. The requested message is leading: if the specified connectorId is not relevant to the message, it should be ignored. In such cases the requested message should still be sent. Inversely, if the connectorId is relevant but absent, this should be interpreted as “for all allowed connectorId values”. For example, a request for a statusNotification for connectorId 0 is a request for the status of the Charge Point. A request for a statusNotification without connectorId is a request for multiple statusNotifications: the notification for the Charge Point itself and a notification for each of its connectors. The Charge Point SHALL first send the TriggerMessage response, before sending the requested message. In the TriggerMessageConfirmation the Charge Point SHALL indicate whether it will send it or not, by returning ACCEPTED or REJECTED. It is up to the Charge Point if it accepts or rejects the request to send. If the requested message is unknown or not implemented the Charge Point SHALL return NOT_IMPLEMENTED. Messages that the Charge Point marks as accepted SHOULD be sent. The situation could occur that, between accepting the request and actually sending the requested message, that same message gets sent because of normal operations. In such cases the message just sent MAY be considered as complying with the request. The TriggerMessage mechanism is not intended to retrieve historic data. The messages it triggers should only give current information. A MeterValuesRequest message triggered in this way for instance SHALL return the most recent measurements for all measurands configured in configuration key MeterValuesSampledData. StartTransaction and StopTransaction have been left out of this mechanism because they are not state related, but by their nature describe a transition.

func (TriggerMessageFeature) GetFeatureName

func (f TriggerMessageFeature) GetFeatureName() string

func (TriggerMessageFeature) GetRequestType

func (f TriggerMessageFeature) GetRequestType() reflect.Type

func (TriggerMessageFeature) GetResponseType

func (f TriggerMessageFeature) GetResponseType() reflect.Type

type TriggerMessageRequest

type TriggerMessageRequest struct {
	RequestedMessage MessageTrigger `json:"requestedMessage" validate:"required,messageTrigger"`
	ConnectorId      *int           `json:"connectorId,omitempty" validate:"omitempty,gt=0"`
}

The field definition of the TriggerMessage request payload sent by the Central System to the Charge Point.

func NewTriggerMessageRequest

func NewTriggerMessageRequest(requestedMessage MessageTrigger) *TriggerMessageRequest

Creates a new TriggerMessageRequest, containing all required fields. Optional fields may be set afterwards.

func (TriggerMessageRequest) GetFeatureName

func (r TriggerMessageRequest) GetFeatureName() string

type TriggerMessageStatus

type TriggerMessageStatus string

Status reported in TriggerMessageConfirmation.

const (
	TriggerMessageStatusAccepted       TriggerMessageStatus = "Accepted"
	TriggerMessageStatusRejected       TriggerMessageStatus = "Rejected"
	TriggerMessageStatusNotImplemented TriggerMessageStatus = "NotImplemented"
)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL