Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sync gridx_extensions #19

Merged
merged 50 commits into from
Mar 6, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
983d863
Add IsConnected utility method for charge points
lorenzodonini Nov 16, 2022
564c732
fix: use go-routines in handle functions to prevent blocking the unde…
Nov 16, 2022
956223d
Make SampledValue.Value field not required
lorenzodonini Dec 11, 2022
e66011a
v1.6: Change ChargingProfileStatus value from NotImplemented to NotSu…
lorenzodonini Dec 24, 2022
b542323
v2.0.1: Fix incorrect IdTokenType
lorenzodonini Dec 24, 2022
2fa5412
v2.0.1: Fix csms example after merging #163
lorenzodonini Dec 24, 2022
8c6098d
Use correct name to validate ClearChargingProfileConfirmation
Feb 23, 2023
0195c3f
Add debug logs for raw json messages
lorenzodonini Feb 4, 2023
70f4614
EscapeHTML configuration for json.Marshal
Feb 7, 2023
fc83394
Remove newline from encoded json byte array
lorenzodonini Mar 12, 2023
0374c84
Fix property constraint violation on ConfigurationKey nil values
lorenzodonini Mar 14, 2023
3c24b0d
Remove incorrect validation for IdToken in RequestStartTransactionReq…
lorenzodonini Mar 17, 2023
5869d11
feature to add a custom client validation handler before connected
dwibudut Feb 20, 2023
404fb1f
add/implement SetCheckClientHandler method on MockWebsocketServer
dwibudut Mar 21, 2023
7652fcf
fix/replace with direct func type arg on implement method SetCheckCli…
dwibudut Mar 21, 2023
fc3ab08
implement method `SetNewChargingStationValidationHandler` on ocpp1.6 …
dwibudut Mar 23, 2023
7d6d270
Add handler
shiv3 Feb 27, 2023
22b4f86
Add router to non tls server
shiv3 Mar 22, 2023
b979d02
Fix goimport
shiv3 Mar 22, 2023
3facaad
Fix CallError marshaling of empty fields
lorenzodonini Apr 7, 2023
c3dee61
Add send response error handling function
lorenzodonini Apr 7, 2023
3fbe338
Add error handling function for server SendResponse
lorenzodonini Apr 7, 2023
0ae68c7
Improve error handling and rewrite tests
lorenzodonini Apr 8, 2023
dfa368e
Convert v1.6 core listeners to pointer receiver
lorenzodonini Apr 8, 2023
830bc32
Fix v1.6 error handling in sendResponse functions
lorenzodonini Apr 8, 2023
9490eba
Add v1.6 tests for new error handling
lorenzodonini Apr 8, 2023
3430e25
Fix v2.0.1 error handling in sendResponse functions
lorenzodonini Apr 8, 2023
3ec1db9
Add v2.0.1 tests for new error handling
lorenzodonini Apr 8, 2023
782920b
Fix broken tests
lorenzodonini Apr 8, 2023
c38d419
resolves issues/173 checking and handling invalid message property fo…
sc-atompower Apr 17, 2023
3ecaf00
reverted go.mod
sc-atompower Apr 17, 2023
0c73967
Fix SetVariableStatus validation tag
lorenzodonini May 19, 2023
34d3b60
fix messagesinqueue json
May 10, 2023
e034d39
Change messageinqueue to messagesinqueue
May 19, 2023
c34f6ad
Fix validation override between v1.6 and v2.0.1
lorenzodonini Jun 11, 2023
694d985
fix certificateType on CertificateSignedRequest & GetInstalledCertifi…
dwibudut Jun 29, 2023
69eec62
add another FirmwareStatus type on FirmwareStatusNotification (suppor…
dwibudut Jun 29, 2023
118355f
Fix deadlock on double client stop
lorenzodonini Jul 3, 2023
290c89e
Override FormatViolation error code for v2.0.1
lorenzodonini Jul 4, 2023
2fef296
Add tests for FormatViolation value
lorenzodonini Jul 8, 2023
3760b41
Add hook for custom handling of invalid messages
lorenzodonini Jul 30, 2023
d0d7f6d
change serial number validate max to 40
Jul 25, 2023
ff45def
Serial number in OCS Request need to be change as well
Jul 26, 2023
139992c
add IdTokenType MacAddress
dwibudut Jul 27, 2023
fa5b59a
add key16 and key201 to resetType and resetStatus
Aug 17, 2023
f0af2ad
check type on action in call and add test
Aug 24, 2023
c686786
Fix assertion for invalid TLS certificate test
lorenzodonini Sep 3, 2023
607bfeb
Merge pull request #18 from grid-x/sync-fork
hnicolaysen Mar 5, 2024
ae287d7
Merge branch 'master' into sync-gridx_extensions
hnicolaysen Mar 5, 2024
add4e73
refactor(*): fix merge problems
hnicolaysen Mar 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix v2.0.1 error handling in sendResponse functions
Signed-off-by: Lorenzo <lorenzo.donini90@gmail.com>
  • Loading branch information
lorenzodonini committed Apr 16, 2023
commit 3430e25a8fb36f1cefd0bfb4a26c12c5337e36da
23 changes: 17 additions & 6 deletions ocpp2.0.1/charging_station.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package ocpp2

import (
"fmt"
"reflect"

"github.com/lorenzodonini/ocpp-go/internal/callbackqueue"
"github.com/lorenzodonini/ocpp-go/ocpp"
Expand Down Expand Up @@ -555,25 +556,35 @@ func (cs *chargingStation) asyncCallbackHandler() {
}

func (cs *chargingStation) sendResponse(response ocpp.Response, err error, requestId string) {
// send error response
if err != nil {
err = cs.client.SendError(requestId, ocppj.ProtocolError, err.Error(), nil)
// Send error response
err = cs.client.SendError(requestId, ocppj.InternalError, err.Error(), nil)
if err != nil {
cs.error(fmt.Errorf("replying cs to request %s with 'protocol error': %w", requestId, err))
// Error while sending an error. Will attempt to send a default error instead
cs.client.HandleFailedResponseError(requestId, err, "")
// Notify client implementation
err = fmt.Errorf("replying to request %s with 'internal error' failed: %w", requestId, err)
cs.error(err)
}
return
}

if response == nil {
if response == nil || reflect.ValueOf(response).IsNil() {
err = fmt.Errorf("empty response to request %s", requestId)
// Sending a dummy error to server instead, then notify client implementation
_ = cs.client.SendError(requestId, ocppj.GenericError, err.Error(), nil)
cs.error(err)
return
}

// send response
// send confirmation response
err = cs.client.SendResponse(requestId, response)
if err != nil {
cs.error(fmt.Errorf("replying to request %s with 'protocol error': %w", requestId, err))
// Error while sending an error. Will attempt to send a default error instead
cs.client.HandleFailedResponseError(requestId, err, response.GetFeatureName())
// Notify client implementation
err = fmt.Errorf("failed responding to request %s: %w", requestId, err)
cs.error(err)
}
}

Expand Down
22 changes: 17 additions & 5 deletions ocpp2.0.1/csms.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package ocpp2

import (
"fmt"
"reflect"

"github.com/lorenzodonini/ocpp-go/internal/callbackqueue"
"github.com/lorenzodonini/ocpp-go/ocpp"
Expand Down Expand Up @@ -814,22 +815,33 @@ func (cs *csms) Start(listenPort int, listenPath string) {

func (cs *csms) sendResponse(chargingStationID string, response ocpp.Response, err error, requestId string) {
if err != nil {
err := cs.server.SendError(chargingStationID, requestId, ocppj.ProtocolError, "Couldn't generate valid confirmation", nil)
// Send error response
err = cs.server.SendError(chargingStationID, requestId, ocppj.InternalError, err.Error(), nil)
if err != nil {
err = fmt.Errorf("replying cs %s to request %s with 'protocol error': %w", chargingStationID, requestId, err)
// Error while sending an error. Will attempt to send a default error instead
cs.server.HandleFailedResponseError(chargingStationID, requestId, err, "")
// Notify client implementation
err = fmt.Errorf("error replying cp %s to request %s with 'internal error': %w", chargingStationID, requestId, err)
cs.error(err)
}
return
}
if response == nil {

if response == nil || reflect.ValueOf(response).IsNil() {
err = fmt.Errorf("empty response to %s for request %s", chargingStationID, requestId)
// Sending a dummy error to server instead, then notify client implementation
_ = cs.server.SendError(chargingStationID, requestId, ocppj.GenericError, err.Error(), nil)
cs.error(err)
return
}
// send response

// send confirmation response
err = cs.server.SendResponse(chargingStationID, requestId, response)
if err != nil {
err = fmt.Errorf("replying cs %s to request %s: %w", chargingStationID, requestId, err)
// Error while sending an error. Will attempt to send a default error instead
cs.server.HandleFailedResponseError(chargingStationID, requestId, err, response.GetFeatureName())
// Notify client implementation
err = fmt.Errorf("error replying cp %s to request %s: %w", chargingStationID, requestId, err)
cs.error(err)
}
}
Expand Down