Documentation ¶
Overview ¶
Contains common and shared data types between OCPP 2.0 messages.
Index ¶
- Constants
- Variables
- func DateTimeIsNull(dateTime *DateTime) bool
- func FormatTimestamp(t time.Time) string
- type AdditionalInfo
- type Attribute
- type AuthorizationStatus
- type Certificate15118EVStatus
- type CertificateHashData
- type CertificateHashDataChain
- type CertificateSigningUse
- type CertificateUse
- type ChargingLimitSourceType
- type ChargingProfile
- type ChargingProfileKindType
- type ChargingProfilePurposeType
- type ChargingRateUnitType
- type ChargingSchedule
- type ChargingSchedulePeriod
- type Component
- type ComponentVariable
- type ConsumptionCost
- type CostKind
- type CostType
- type DateTime
- type EVSE
- type EncodingMethod
- type GenericDeviceModelStatus
- type GenericStatus
- type GroupIdToken
- type HashAlgorithmType
- type IdToken
- type IdTokenInfo
- type IdTokenType
- type Location
- type Measurand
- type MessageContent
- type MessageFormatType
- type MeterValue
- type OCSPRequestDataType
- type Phase
- type PropertyViolation
- type ReadingContext
- type RecurrencyKindType
- type RelativeTimeInterval
- type RemoteStartStopStatus
- type SalesTariff
- type SalesTariffEntry
- type SampledValue
- type SignatureMethod
- type SignedMeterValue
- type StatusInfo
- type UnitOfMeasure
- type Variable
Constants ¶
const ( V2Subprotocol = "ocpp2.0" V201Subprotocol = "ocpp2.0.1" )
const ( ChargingProfilePurposeChargingStationExternalConstraints ChargingProfilePurposeType = "ChargingStationExternalConstraints" ChargingProfilePurposeChargingStationMaxProfile ChargingProfilePurposeType = "ChargingStationMaxProfile" ChargingProfilePurposeTxDefaultProfile ChargingProfilePurposeType = "TxDefaultProfile" ChargingProfilePurposeTxProfile ChargingProfilePurposeType = "TxProfile" ChargingProfileKindAbsolute ChargingProfileKindType = "Absolute" ChargingProfileKindRecurring ChargingProfileKindType = "Recurring" ChargingProfileKindRelative ChargingProfileKindType = "Relative" RecurrencyKindDaily RecurrencyKindType = "Daily" RecurrencyKindWeekly RecurrencyKindType = "Weekly" ChargingRateUnitWatts ChargingRateUnitType = "W" ChargingRateUnitAmperes ChargingRateUnitType = "A" ChargingLimitSourceEMS ChargingLimitSourceType = "EMS" ChargingLimitSourceOther ChargingLimitSourceType = "Other" ChargingLimitSourceSO ChargingLimitSourceType = "SO" ChargingLimitSourceCSO ChargingLimitSourceType = "CSO" )
const ( ReadingContextInterruptionBegin ReadingContext = "Interruption.Begin" ReadingContextInterruptionEnd ReadingContext = "Interruption.End" ReadingContextOther ReadingContext = "Other" ReadingContextSampleClock ReadingContext = "Sample.Clock" ReadingContextSamplePeriodic ReadingContext = "Sample.Periodic" ReadingContextTransactionBegin ReadingContext = "Transaction.Begin" ReadingContextTransactionEnd ReadingContext = "Transaction.End" ReadingContextTrigger ReadingContext = "Trigger" MeasurandCurrentExport Measurand = "Current.Export" MeasurandCurrentImport Measurand = "Current.Import" MeasurandCurrentOffered Measurand = "Current.Offered" MeasurandEnergyActiveExportRegister Measurand = "Energy.Active.Export.Register" MeasurandEnergyActiveImportRegister Measurand = "Energy.Active.Import.Register" MeasurandEnergyReactiveExportRegister Measurand = "Energy.Reactive.Export.Register" MeasurandEnergyReactiveImportRegister Measurand = "Energy.Reactive.Import.Register" MeasurandEnergyActiveExportInterval Measurand = "Energy.Active.Export.Interval" MeasurandEnergyActiveImportInterval Measurand = "Energy.Active.Import.Interval" MeasurandEnergyActiveNet Measurand = "Energy.Active.Net" MeasurandEnergyReactiveExportInterval Measurand = "Energy.Reactive.Export.Interval" MeasurandEnergyReactiveImportInterval Measurand = "Energy.Reactive.Import.Interval" MeasurandEnergyReactiveNet Measurand = "Energy.Reactive.Net" MeasurandEnergyApparentNet Measurand = "Energy.Apparent.Net" MeasurandEnergyApparentImport Measurand = "Energy.Apparent.Import" MeasurandEnergyApparentExport Measurand = "Energy.Apparent.Export" MeasurandFrequency Measurand = "Frequency" MeasurandPowerActiveExport Measurand = "Power.Active.Export" MeasurandPowerActiveImport Measurand = "Power.Active.Import" MeasurandPowerFactor Measurand = "Power.Factor" MeasurandPowerOffered Measurand = "Power.Offered" MeasurandPowerReactiveExport Measurand = "Power.Reactive.Export" MeasurandPowerReactiveImport Measurand = "Power.Reactive.Import" MeasueandSoC Measurand = "SoC" MeasurandTemperature Measurand = "Temperature" MeasurandVoltage Measurand = "Voltage" PhaseL1 Phase = "L1" PhaseL2 Phase = "L2" PhaseL3 Phase = "L3" PhaseN Phase = "N" PhaseL1N Phase = "L1-N" PhaseL2N Phase = "L2-N" PhaseL3N Phase = "L3-N" PhaseL1L2 Phase = "L1-L2" PhaseL2L3 Phase = "L2-L3" PhaseL3L1 Phase = "L3-L1" LocationBody Location = "Body" LocationCable Location = "Cable" LocationEV Location = "EV" LocationInlet Location = "Inlet" LocationOutlet Location = "Outlet" )
Variables ¶
var DateTimeFormat = time.RFC3339
DateTimeFormat to be used when serializing all OCPP messages.
The default dateTime format is RFC3339. Change this if another format is desired.
var Validate = ocppj.Validate
Validator used for validating all OCPP 2.0 messages. Any additional custom validations must be added to this object for automatic validation.
Functions ¶
func DateTimeIsNull ¶
func FormatTimestamp ¶
Types ¶
type AdditionalInfo ¶
type Attribute ¶
type Attribute string
Attribute is an enumeration type used when requesting a variable value.
const ( AttributeActual Attribute = "Actual" // The actual value of the variable. AttributeTarget Attribute = "Target" // The target value for this variable. AttributeMinSet Attribute = "MinSet" // The minimal allowed value for this variable. AttributeMaxSet Attribute = "MaxSet" // The maximum allowed value for this variable )
type AuthorizationStatus ¶
type AuthorizationStatus string
const ( AuthorizationStatusAccepted AuthorizationStatus = "Accepted" AuthorizationStatusBlocked AuthorizationStatus = "Blocked" AuthorizationStatusExpired AuthorizationStatus = "Expired" AuthorizationStatusInvalid AuthorizationStatus = "Invalid" AuthorizationStatusConcurrentTx AuthorizationStatus = "ConcurrentTx" AuthorizationStatusNoCredit AuthorizationStatus = "NoCredit" AuthorizationStatusNotAllowedTypeEVSE AuthorizationStatus = "NotAllowedTypeEVS" AuthorizationStatusNotAtThisLocation AuthorizationStatus = "NotAtThisLocation" AuthorizationStatusNotAtThisTime AuthorizationStatus = "NotAtThisTime" AuthorizationStatusUnknown AuthorizationStatus = "Unknown" )
type Certificate15118EVStatus ¶
type Certificate15118EVStatus string
Certificate15118EVStatus
const ( Certificate15188EVStatusAccepted Certificate15118EVStatus = "Accepted" Certificate15118EVStatusFailed Certificate15118EVStatus = "Failed" )
type CertificateHashData ¶
type CertificateHashData struct { HashAlgorithm HashAlgorithmType `json:"hashAlgorithm" validate:"required,hashAlgorithm"` IssuerNameHash string `json:"issuerNameHash" validate:"required,max=128"` IssuerKeyHash string `json:"issuerKeyHash" validate:"required,max=128"` SerialNumber string `json:"serialNumber" validate:"required,max=40"` }
CertificateHashDataType
type CertificateHashDataChain ¶
type CertificateHashDataChain struct { CertificateType CertificateUse `json:"certificateType" validate:"required,certificateUse"` CertificateHashData CertificateHashData `json:"certificateHashData" validate:"required"` ChildCertificateHashData []CertificateHashData `json:"childCertificateHashData,omitempty" validate:"omitempty,dive"` }
CertificateHashDataChain
type CertificateSigningUse ¶
type CertificateSigningUse string
Indicates the type of the signed certificate that is returned. When omitted the certificate is used for both the 15118 connection (if implemented) and the Charging Station to CSMS connection. This field is required when a typeOfCertificate was included in the SignCertificateRequest that requested this certificate to be signed AND both the 15118 connection and the Charging Station connection are implemented.
const ( ChargingStationCert CertificateSigningUse = "ChargingStationCertificate" V2GCertificate CertificateSigningUse = "V2GCertificate" )
type CertificateUse ¶
type CertificateUse string
Indicates the type of the requested certificate. It is used in GetInstalledCertificateIdsRequest and InstallCertificateRequest messages.
const ( V2GRootCertificate CertificateUse = "V2GRootCertificate" MORootCertificate CertificateUse = "MORootCertificate" CSOSubCA1 CertificateUse = "CSOSubCA1" CSOSubCA2 CertificateUse = "CSOSubCA2" CSMSRootCertificate CertificateUse = "CSMSRootCertificate" V2GCertificateChain CertificateUse = "V2GCertificateChain" ManufacturerRootCertificate CertificateUse = "ManufacturerRootCertificate" )
type ChargingLimitSourceType ¶
type ChargingLimitSourceType string
type ChargingProfile ¶
type ChargingProfile struct { ID int `json:"id" validate:"gte=0"` StackLevel int `json:"stackLevel" validate:"gte=0"` ChargingProfilePurpose ChargingProfilePurposeType `json:"chargingProfilePurpose" validate:"required,chargingProfilePurpose201"` ChargingProfileKind ChargingProfileKindType `json:"chargingProfileKind" validate:"required,chargingProfileKind201"` RecurrencyKind RecurrencyKindType `json:"recurrencyKind,omitempty" validate:"omitempty,recurrencyKind201"` ValidFrom *DateTime `json:"validFrom,omitempty"` ValidTo *DateTime `json:"validTo,omitempty"` TransactionID string `json:"transactionId,omitempty" validate:"omitempty,max=36"` ChargingSchedule []ChargingSchedule `json:"chargingSchedule" validate:"required,min=1,max=3,dive"` }
func NewChargingProfile ¶
func NewChargingProfile(id int, stackLevel int, chargingProfilePurpose ChargingProfilePurposeType, chargingProfileKind ChargingProfileKindType, schedule []ChargingSchedule) *ChargingProfile
type ChargingProfileKindType ¶
type ChargingProfileKindType string
type ChargingProfilePurposeType ¶
type ChargingProfilePurposeType string
type ChargingRateUnitType ¶
type ChargingRateUnitType string
type ChargingSchedule ¶
type ChargingSchedule struct { ID int `json:"id" validate:"gte=0"` // Identifies the ChargingSchedule. StartSchedule *DateTime `json:"startSchedule,omitempty" validate:"omitempty"` Duration *int `json:"duration,omitempty" validate:"omitempty,gte=0"` ChargingRateUnit ChargingRateUnitType `json:"chargingRateUnit" validate:"required,chargingRateUnit201"` MinChargingRate *float64 `json:"minChargingRate,omitempty" validate:"omitempty,gte=0"` ChargingSchedulePeriod []ChargingSchedulePeriod `json:"chargingSchedulePeriod" validate:"required,min=1,max=1024"` SalesTariff *SalesTariff `json:"salesTariff,omitempty" validate:"omitempty"` // Sales tariff associated with this charging schedule. }
func NewChargingSchedule ¶
func NewChargingSchedule(id int, chargingRateUnit ChargingRateUnitType, schedulePeriod ...ChargingSchedulePeriod) *ChargingSchedule
type ChargingSchedulePeriod ¶
type ChargingSchedulePeriod struct { StartPeriod int `json:"startPeriod" validate:"gte=0"` Limit float64 `json:"limit" validate:"gte=0"` NumberPhases *int `json:"numberPhases,omitempty" validate:"omitempty,gte=0"` }
func NewChargingSchedulePeriod ¶
func NewChargingSchedulePeriod(startPeriod int, limit float64) ChargingSchedulePeriod
type Component ¶
type Component struct { Name string `json:"name" validate:"required,max=50"` // Name of the component. Name should be taken from the list of standardized component names whenever possible. Case Insensitive. strongly advised to use Camel Case. Instance string `json:"instance,omitempty" validate:"omitempty,max=50"` // Name of instance in case the component exists as multiple instances. Case Insensitive. strongly advised to use Camel Case. EVSE *EVSE `json:"evse,omitempty" validate:"omitempty"` // Specifies the EVSE when component is located at EVSE level, also specifies the connector when component is located at Connector level. }
Component represents a physical or logical component.
type ComponentVariable ¶
type ComponentVariable struct { Component Component `json:"component" validate:"required"` // Component for which a report of Variable is requested. Variable Variable `json:"variable" validate:"required"` // Variable for which report is requested. }
ComponentVariable is used to report components, variables and variable attributes and characteristics.
type ConsumptionCost ¶
type ConsumptionCost struct { StartValue float64 `json:"startValue"` // The lowest level of consumption that defines the starting point of this consumption block Cost []CostType `json:"cost" validate:"required,max=3,dive"` // Contains the cost details. }
Contains price information and/or alternative costs.
func NewConsumptionCost ¶
func NewConsumptionCost(startValue float64, cost []CostType) ConsumptionCost
NewConsumptionCost instantiates a new ConsumptionCost struct. No additional parameters need to be set.
type CostKind ¶
type CostKind string
The kind of cost referred to in a CostType.
const ( CostKindCarbonDioxideEmission CostKind = "CarbonDioxideEmission" // Carbon Dioxide emissions, in grams per kWh. CostKindRelativePricePercentage CostKind = "RelativePricePercentage" // Price per kWh, as percentage relative to the maximum price stated in any of all tariffs indicated to the EV. CostKindRenewableGenerationPercentage CostKind = "RenewableGenerationPercentage" // Percentage of renewable generation within total generation. )
type CostType ¶
type CostType struct { CostKind CostKind `json:"costKind" validate:"required,costKind"` // The kind of cost referred to in the message element amount. Amount int `json:"amount" validate:"gte=0"` // The estimated or actual cost per kWh. AmountMultiplier *int `json:"amountMultiplier,omitempty" validate:"omitempty,min=-3,max=3"` // The exponent to base 10 (dec). }
Cost details.
type DateTime ¶
DateTime wraps a time.Time struct, allowing for improved dateTime JSON compatibility.
func NewDateTime ¶
Creates a new DateTime struct, embedding a time.Time struct.
func (*DateTime) FormatTimestamp ¶
Formats the UTC timestamp using the DateTimeFormat setting. This function is used during JSON marshaling as well.
func (*DateTime) MarshalJSON ¶
func (*DateTime) UnmarshalJSON ¶
type EVSE ¶
type EVSE struct { ID int `json:"id" validate:"gte=0"` // The EVSE Identifier. When 0, the ID references the Charging Station as a whole. ConnectorID *int `json:"connectorId,omitempty" validate:"omitempty,gte=0"` // An id to designate a specific connector (on an EVSE) by connector index number. }
EVSE represents the Electric Vehicle Supply Equipment, formerly referred to as connector(s).
type EncodingMethod ¶
type EncodingMethod string
Enumeration of the method used to encode the meter value into binary data before applying the digital signature algorithm. If the EncodingMethod is set to Other, the CSMS MAY try to determine the encoding method from the encodedMeterValue field.
const ( EncodingOther EncodingMethod = "Other" // Encoding method is not included in the enumeration. EncodingDLMSMessage EncodingMethod = "DLMS Message" // The data is encoded in a digitally signed DLMS message, as described in the DLMS Green Book 8. EncodingCOSEMProtectedData EncodingMethod = "COSEM Protected Data" // The data is encoded according to the COSEM data protection methods, as described in the DLMS Blue Book 12. EncodingEDL EncodingMethod = "EDL" // The data is encoded in the format used by EDL meters. )
type GenericDeviceModelStatus ¶
type GenericDeviceModelStatus string
Generic Device Model Status
const ( GenericDeviceModelStatusAccepted GenericDeviceModelStatus = "Accepted" GenericDeviceModelStatusRejected GenericDeviceModelStatus = "Rejected" GenericDeviceModelStatusNotSupported GenericDeviceModelStatus = "NotSupported" GenericDeviceModelStatusEmptyResultSet GenericDeviceModelStatus = "EmptyResultSet" // If the combination of received criteria result in an empty result set. )
type GenericStatus ¶
type GenericStatus string
Generic Status
const ( GenericStatusAccepted GenericStatus = "Accepted" GenericStatusRejected GenericStatus = "Rejected" )
type GroupIdToken ¶
type GroupIdToken struct { IdToken string `json:"idToken" validate:"max=36"` Type IdTokenType `json:"type" validate:"required,idTokenType"` }
type HashAlgorithmType ¶
type HashAlgorithmType string
Hash Algorithms
const ( SHA256 HashAlgorithmType = "SHA256" SHA384 HashAlgorithmType = "SHA384" SHA512 HashAlgorithmType = "SHA512" )
type IdToken ¶
type IdToken struct { IdToken string `json:"idToken" validate:"max=36"` Type IdTokenType `json:"type" validate:"required,idTokenType"` AdditionalInfo []AdditionalInfo `json:"additionalInfo,omitempty" validate:"omitempty,dive"` }
type IdTokenInfo ¶
type IdTokenInfo struct { Status AuthorizationStatus `json:"status" validate:"required,authorizationStatus201"` CacheExpiryDateTime *DateTime `json:"cacheExpiryDateTime,omitempty" validate:"omitempty"` ChargingPriority int `json:"chargingPriority,omitempty" validate:"min=-9,max=9"` Language1 string `json:"language1,omitempty" validate:"max=8"` Language2 string `json:"language2,omitempty" validate:"max=8"` GroupIdToken *GroupIdToken `json:"groupIdToken,omitempty"` PersonalMessage *MessageContent `json:"personalMessage,omitempty"` }
func NewIdTokenInfo ¶
func NewIdTokenInfo(status AuthorizationStatus) *IdTokenInfo
NewIdTokenInfo creates an IdTokenInfo. Optional parameters may be set afterwards on the initialized struct.
type IdTokenType ¶
type IdTokenType string
ID Token
const ( IdTokenTypeCentral IdTokenType = "Central" IdTokenTypeEMAID IdTokenType = "eMAID" IdTokenTypeISO14443 IdTokenType = "ISO14443" IdTokenTypeISO15693 IdTokenType = "ISO15693" IdTokenTypeKeyCode IdTokenType = "KeyCode" IdTokenTypeLocal IdTokenType = "Local" IdTokenTypeMacAddress IdTokenType = "MacAddress" IdTokenTypeNoAuthorization IdTokenType = "NoAuthorization" )
type MessageContent ¶
type MessageContent struct { Format MessageFormatType `json:"format" validate:"required,messageFormat"` Language string `json:"language,omitempty" validate:"max=8"` Content string `json:"content" validate:"required,max=512"` }
type MessageFormatType ¶
type MessageFormatType string
ID Token Info
const ( MessageFormatASCII MessageFormatType = "ASCII" MessageFormatHTML MessageFormatType = "HTML" MessageFormatURI MessageFormatType = "URI" MessageFormatUTF8 MessageFormatType = "UTF8" )
type MeterValue ¶
type MeterValue struct { Timestamp DateTime `json:"timestamp" validate:"required"` SampledValue []SampledValue `json:"sampledValue" validate:"required,min=1,dive"` }
type OCSPRequestDataType ¶
type OCSPRequestDataType struct { HashAlgorithm HashAlgorithmType `json:"hashAlgorithm" validate:"required,hashAlgorithm"` IssuerNameHash string `json:"issuerNameHash" validate:"required,max=128"` IssuerKeyHash string `json:"issuerKeyHash" validate:"required,max=128"` SerialNumber string `json:"serialNumber" validate:"required,max=40"` ResponderURL string `json:"responderURL,omitempty" validate:"max=512"` }
OCSPRequestDataType
type PropertyViolation ¶
type PropertyViolation struct { Property string // contains filtered or unexported fields }
func (*PropertyViolation) Error ¶
func (e *PropertyViolation) Error() string
type ReadingContext ¶
type ReadingContext string
type RecurrencyKindType ¶
type RecurrencyKindType string
type RelativeTimeInterval ¶
type RelativeTimeInterval struct { Start int `json:"start"` // Start of the interval, in seconds from NOW. Duration *int `json:"duration,omitempty" validate:"omitempty,gte=0"` // Duration of the interval, in seconds. }
Defines the time interval the SalesTariffEntry is valid for, based upon relative times.
type RemoteStartStopStatus ¶
type RemoteStartStopStatus string
Remote Start/Stop
const ( RemoteStartStopStatusAccepted RemoteStartStopStatus = "Accepted" RemoteStartStopStatusRejected RemoteStartStopStatus = "Rejected" )
type SalesTariff ¶
type SalesTariff struct { ID int `json:"id"` // Identifier used to identify one sales tariff. SalesTariffDescription string `json:"salesTariffDescription,omitempty" validate:"omitempty,max=32"` // A human readable title/short description of the sales tariff e.g. for HMI display purposes. NumEPriceLevels *int `json:"numEPriceLevels,omitempty" validate:"omitempty"` // Defines the overall number of distinct price levels used across all provided SalesTariff elements. SalesTariffEntry []SalesTariffEntry `json:"salesTariffEntry" validate:"required,min=1,max=1024,dive"` // Encapsulates elements describing all relevant details for one time interval of the SalesTariff. }
Sales tariff associated with this charging schedule.
func NewSalesTariff ¶
func NewSalesTariff(id int, salesTariffEntries []SalesTariffEntry) *SalesTariff
NewSalesTariff instantiates a new SalesTariff struct. Only required fields are passed as parameters.
type SalesTariffEntry ¶
type SalesTariffEntry struct { EPriceLevel *int `json:"ePriceLevel,omitempty" validate:"omitempty,gte=0"` // The price level of this SalesTariffEntry (referring to NumEPriceLevels). Small values for the EPriceLevel represent a cheaper TariffEntry. RelativeTimeInterval RelativeTimeInterval `json:"relativeTimeInterval" validate:"required"` // The time interval the SalesTariffEntry is valid for, based upon relative times. ConsumptionCost []ConsumptionCost `json:"consumptionCost,omitempty" validate:"omitempty,max=3,dive"` // Additional means for further relative price information and/or alternative costs. }
Element describing all relevant details for one time interval of the SalesTariff.
type SampledValue ¶
type SampledValue struct { Value float64 `json:"value"` // Indicates the measured value. This value is required. Context ReadingContext `json:"context,omitempty" validate:"omitempty,readingContext201"` // Type of detail value: start, end or sample. Default = "Sample.Periodic" Measurand Measurand `json:"measurand,omitempty" validate:"omitempty,measurand201"` // Type of measurement. Default = "Energy.Active.Import.Register" Phase Phase `json:"phase,omitempty" validate:"omitempty,phase201"` // Indicates how the measured value is to be interpreted. For instance between L1 and neutral (L1-N) Please note that not all values of phase are applicable to all Measurands. When phase is absent, the measured value is interpreted as an overall value. Location Location `json:"location,omitempty" validate:"omitempty,location201"` // Indicates where the measured value has been sampled. SignedMeterValue *SignedMeterValue `json:"signedMeterValue,omitempty" validate:"omitempty"` // Contains the MeterValueSignature with sign/encoding method information. UnitOfMeasure *UnitOfMeasure `json:"unitOfMeasure,omitempty" validate:"omitempty"` // Represents a UnitOfMeasure including a multiplier. }
type SignatureMethod ¶
type SignatureMethod string
Enumeration of the cryptographic method used to create the digital signature. The list is expected to grow in future OCPP releases to allow other signature methods used by Smart Meters.
const ( SignatureECDSAP256SHA256 SignatureMethod = "ECDSAP256SHA256" // The encoded data is hashed with the SHA-256 hash function, and the hash value is then signed with the ECDSA algorithm using the NIST P-256 elliptic curve. SignatureECDSAP384SHA384 SignatureMethod = "ECDSAP384SHA384" // The encoded data is hashed with the SHA-384 hash function, and the hash value is then signed with the ECDSA algorithm using the NIST P-384 elliptic curve. SignatureECDSA192SHA256 SignatureMethod = "ECDSA192SHA256" // The encoded data is hashed with the SHA-256 hash function, and the hash value is then signed with the ECDSA algorithm using a 192-bit elliptic curve. )
type SignedMeterValue ¶
type SignedMeterValue struct { SignedMeterData string `json:"signedMeterData" validate:"required,max=2500"` // Base64 encoded, contains the signed data which might contain more then just the meter value. It can contain information like timestamps, reference to a customer etc. SigningMethod string `json:"signingMethod" validate:"required,max=50"` // Method used to create the digital signature. EncodingMethod string `json:"encodingMethod" validate:"required,max=50"` // Method used to encode the meter values before applying the digital signature algorithm. PublicKey string `json:"publicKey" validate:"required,max=2500"` // Base64 encoded, sending depends on configuration variable PublicKeyWithSignedMeterValue. }
type StatusInfo ¶
type StatusInfo struct { ReasonCode string `json:"reasonCode" validate:"required,max=20"` // A predefined code for the reason why the status is returned in this response. The string is case- insensitive. AdditionalInfo string `json:"additionalInfo,omitempty" validate:"omitempty,max=512"` // Additional text to provide detailed information. }
StatusInfo is an element providing more information about the message status.
func NewStatusInfo ¶
func NewStatusInfo(reasonCode string, additionalInfo string) *StatusInfo
NewStatusInfo creates a StatusInfo struct. If no additional info need to be set, an empty string may be passed.
type UnitOfMeasure ¶
type Variable ¶
type Variable struct { Name string `json:"name" validate:"required,max=50"` // Name of the variable. Name should be taken from the list of standardized variable names whenever possible. Case Insensitive. strongly advised to use Camel Case. Instance string `json:"instance,omitempty" validate:"omitempty,max=50"` // Name of instance in case the variable exists as multiple instances. Case Insensitive. strongly advised to use Camel Case. }
Variable is a reference key to a component-variable.