Skip to content

Commit

Permalink
DT-730 eBL Surrender new identifier structure
Browse files Browse the repository at this point in the history
  • Loading branch information
gj0dcsa committed Dec 4, 2023
1 parent aad5591 commit 125f0ed
Show file tree
Hide file tree
Showing 5 changed files with 110 additions and 94 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ObjectNode;

import java.time.Instant;
import java.util.*;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
Expand All @@ -13,6 +15,7 @@
import org.dcsa.conformance.core.scenario.ConformanceAction;
import org.dcsa.conformance.core.state.JsonNodeMap;
import org.dcsa.conformance.core.state.StateManagementUtil;
import org.dcsa.conformance.core.toolkit.JsonToolkit;
import org.dcsa.conformance.core.traffic.ConformanceMessageBody;
import org.dcsa.conformance.core.traffic.ConformanceRequest;
import org.dcsa.conformance.core.traffic.ConformanceResponse;
Expand Down Expand Up @@ -42,13 +45,16 @@ public EblSurrenderPlatform(

@Override
protected void exportPartyJsonState(ObjectNode targetObjectNode) {
targetObjectNode.set("eblStatesById", StateManagementUtil.storeMap(objectMapper, eblStatesById, EblSurrenderState::name));
targetObjectNode.set(
"eblStatesById",
StateManagementUtil.storeMap(objectMapper, eblStatesById, EblSurrenderState::name));
targetObjectNode.set("tdrsBySrr", StateManagementUtil.storeMap(objectMapper, tdrsBySrr));
}

@Override
protected void importPartyJsonState(ObjectNode sourceObjectNode) {
StateManagementUtil.restoreIntoMap(eblStatesById, sourceObjectNode.get("eblStatesById"), EblSurrenderState::valueOf);
StateManagementUtil.restoreIntoMap(
eblStatesById, sourceObjectNode.get("eblStatesById"), EblSurrenderState::valueOf);
StateManagementUtil.restoreIntoMap(tdrsBySrr, sourceObjectNode.get("tdrsBySrr"));
}

Expand All @@ -75,40 +81,17 @@ private void requestSurrender(JsonNode actionPrompt) {
forAmendment
? EblSurrenderState.AMENDMENT_SURRENDER_REQUESTED
: EblSurrenderState.DELIVERY_SURRENDER_REQUESTED);
ObjectNode jsonRequestBody =
objectMapper
.createObjectNode()
.put("surrenderRequestReference", srr)
.put("transportDocumentReference", tdr)
.put("surrenderRequestCode", src);

jsonRequestBody.set(
"surrenderRequestedBy",
objectMapper
.createObjectNode()
.put("eblPlatformIdentifier", "[email protected]")
.put("legalName", "Legal Name One"));

ObjectNode endorsementChainLink =
objectMapper
.createObjectNode()
.put("action", "ETOF")
.put("actionDateTime", "2023-08-27T19:38:24.342Z");
endorsementChainLink.set(
"actor",
objectMapper
.createObjectNode()
.put("eblPlatformIdentifier", "[email protected]")
.put("legalName", "Legal Name Two"));
endorsementChainLink.set(
"recipient",
objectMapper
.createObjectNode()
.put("eblPlatformIdentifier", "[email protected]")
.put("legalName", "Legal Name Three"));
JsonNode jsonRequestBody =
JsonToolkit.templateFileToJsonNode(
"/standards/eblsurrender/messages/eblsurrender-api-%s-request.json"
.formatted(apiVersion.startsWith("3") ? "v30" : "v20"),
Map.ofEntries(
Map.entry("SURRENDER_REQUEST_REFERENCE_PLACEHOLDER", srr),
Map.entry("TRANSPORT_DOCUMENT_REFERENCE_PLACEHOLDER", tdr),
Map.entry("SURRENDER_REQUEST_CODE_PLACEHOLDER", src),
Map.entry("ACTION_DATE_TIME_PLACEHOLDER", Instant.now().toString())));

jsonRequestBody.set(
"endorsementChain", objectMapper.createArrayNode().add(endorsementChainLink));
asyncCounterpartPost(
"/%s/ebl-surrender-requests".formatted(apiVersion.startsWith("3") ? "v3" : "v2"),
jsonRequestBody);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"surrenderRequestReference": "SURRENDER_REQUEST_REFERENCE_PLACEHOLDER",
"transportDocumentReference": "TRANSPORT_DOCUMENT_REFERENCE_PLACEHOLDER",
"surrenderRequestCode": "SURRENDER_REQUEST_CODE_PLACEHOLDER",
"surrenderRequestedBy": {
"eblPlatform": "ASDF",
"legalName": "Legal Name"
},
"endorsementChain": [
{
"action": "ETOF",
"actionDateTime": "ACTION_DATE_TIME_PLACEHOLDER",
"actor": {
"eblPlatform": "ASDF",
"legalName": "Legal Name"
},
"recipient": {
"eblPlatform": "ASDF",
"legalName": "Legal Name"
}
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"surrenderRequestReference": "SURRENDER_REQUEST_REFERENCE_PLACEHOLDER",
"transportDocumentReference": "TRANSPORT_DOCUMENT_REFERENCE_PLACEHOLDER",
"surrenderRequestCode": "SURRENDER_REQUEST_CODE_PLACEHOLDER",
"surrenderRequestedBy": {
"eblPlatform": "ASDF",
"legalName": "Legal Name"
},
"endorsementChain": [
{
"action": "ETOF",
"actionDateTime": "ACTION_DATE_TIME_PLACEHOLDER",
"actor": {
"eblPlatform": "ASDF",
"legalName": "Legal Name"
},
"recipient": {
"eblPlatform": "ASDF",
"legalName": "Legal Name"
}
}
]
}
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@
"minLength": 2,
"pattern": "^[A-Z]+$",
"type": "string",
"description": "country code of the location of registration according to ISO 3166-1 alpha-2",
"description": "Country code of the location of registration according to ISO 3166-1 alpha-2",
"example": "NL"
},
"surrenderRequestReference": {
Expand All @@ -128,15 +128,17 @@
},
"transactionParty": {
"required": [
"eblPlatformIdentifier",
"eblPlatform",
"legalName"
],
"type": "object",
"properties": {
"eblPlatformIdentifier": {
"pattern": "\\S+@\\S+",
"eblPlatform": {
"maxLength": 4,
"pattern": "\\S+",
"type": "string",
"example": "[email protected]"
"description": "The EBL platform of the transaction party. Should be a code from https://github.com/dcsaorg/DCSA-Information-Model/blob/master/datamodel/referencedata.d/eblsolutionproviders.csv.",
"example": "BOLE"
},
"legalName": {
"$ref": "#/components/schemas/legalName"
Expand All @@ -150,19 +152,19 @@
"taxReference": {
"pattern": "^\\S+$",
"type": "string",
"description": "tax reference used in the location of registration",
"description": "Tax reference used in the location of registration",
"example": "NL859951480B01"
},
"supportingPartyCodes": {
"$ref": "#/components/schemas/supportingPartyCodes"
"partyCodes": {
"$ref": "#/components/schemas/partyCodes"
}
},
"description": "refers to a company or a legal entity."
},
"supportingPartyCodes": {
"partyCodes": {
"type": "array",
"items": {
"$ref": "#/components/schemas/supportingPartyCodes_inner"
"$ref": "#/components/schemas/partyCodes_inner"
}
},
"endorsementChainLink": {
Expand Down Expand Up @@ -363,7 +365,7 @@
"type": "string",
"description": "A unique number allocated by the shipping line to the transport document and the main number used for the tracking of the status of the shipment.\n"
},
"supportingPartyCodes_inner": {
"partyCodes_inner": {
"required": [
"partyCode",
"partyCodeListProvider"
Expand All @@ -374,16 +376,22 @@
"maxLength": 100,
"minLength": 1,
"pattern": "^\\S+(\\s+\\S+)*$",
"type": "string",
"example": "54930084UKLVMY22DS16"
"type": "string"
},
"partyCodeListProvider": {
"type": "string",
"description": "Describes which party code list the party code is from. Options are:\n\n - `LEI`: The party code is a Legal Entity Identifier (LEI) as issued by Global Legal Entity Identifier Foundation (GLEIF). See https://www.gleif.org/en\n - `DID`: The party code is a Decentralized Identifier (see https://www.w3.org/TR/did-core/).\n",
"description": "Describes the organisation that provides the party code.\n\n - `EPUI`:The party code is an EBL Platform User Identifier (that is, an identifier provided by a platform, used to transfer eBLs). EPIU should be combined with the `codeListName`, to identify the platform that issued the identifier.\n - `GLEIF`: The party code is issued by Global Legal Entity Identifier Foundation (GLEIF). See https://www.gleif.org/en. The `codeNameList` (if omitted) defaults to `LEI`.\n - `W3C`: The party code is issued by a standard created by World Wide Web Consortium (W3C). See https://www.w3.org/. The `codeNameList` (if omitted) defaults to `DID`.\n",
"enum": [
"LEI",
"DID"
"GLEIF",
"W3C",
"EPUI"
]
},
"codeListName": {
"maxLength": 100,
"pattern": "^\\S+(\\s+\\S+)*$",
"type": "string",
"description": "The name of the code list / code generation mechanism / code authority for the party code.\n\nFor `EPUI`:\n * `Wave`: An identifier provided by Wave BL.\n * `CargoX`: An identifier provided by CargoX\n * `EdoxOnline`: An identifier provided by EdoxOnline\n * `IQAX`: An identifier provided by IQAX\n * `EssDOCS`: An identifier provided by essDOCS\n * `Bolero`: An identifier provided by Bolero\n * `TradeGO`: An identifierprovided by TradeGo\n * `Secro`: An identifier provided by Secro\n * `GSBN`: An identifier provided by GSBN\n * `WiseTech`: An identifier provided by WiseTech\n\nFor `W3C`:\n * `DID`: The party code is a Decentralized Identifier (see https://www.w3.org/TR/did-core/).\n\nFor `GLEIF`:\n * `LEI`: The party code is a Legal Entity Identifier (LEI) as issued by Global Legal Entity Identifier Foundation (GLEIF). See https://www.gleif.org/en\n"
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@
"minLength": 2,
"pattern": "^[A-Z]+$",
"type": "string",
"description": "country code of the location of registration according to ISO 3166-1 alpha-2",
"description": "Country code of the location of registration according to ISO 3166-1 alpha-2",
"example": "NL"
},
"surrenderRequestReference": {
Expand All @@ -128,15 +128,17 @@
},
"transactionParty": {
"required": [
"eblPlatformIdentifier",
"eblPlatform",
"legalName"
],
"type": "object",
"properties": {
"eblPlatformIdentifier": {
"pattern": "\\S+@\\S+",
"eblPlatform": {
"maxLength": 4,
"pattern": "\\S+",
"type": "string",
"example": "[email protected]"
"description": "The EBL platform of the transaction party. Should be a code from https://github.com/dcsaorg/DCSA-Information-Model/blob/master/datamodel/referencedata.d/eblsolutionproviders.csv.",
"example": "BOLE"
},
"legalName": {
"$ref": "#/components/schemas/legalName"
Expand All @@ -150,19 +152,19 @@
"taxReference": {
"pattern": "^\\S+$",
"type": "string",
"description": "tax reference used in the location of registration",
"description": "Tax reference used in the location of registration",
"example": "NL859951480B01"
},
"supportingPartyCodes": {
"$ref": "#/components/schemas/supportingPartyCodes"
"partyCodes": {
"$ref": "#/components/schemas/partyCodes"
}
},
"description": "refers to a company or a legal entity."
},
"supportingPartyCodes": {
"partyCodes": {
"type": "array",
"items": {
"$ref": "#/components/schemas/supportingPartyCodes_inner"
"$ref": "#/components/schemas/partyCodes_inner"
}
},
"endorsementChainLink": {
Expand Down Expand Up @@ -239,9 +241,6 @@
"items": {
"$ref": "#/components/schemas/endorsementChainLink"
}
},
"surrenderToCarrier": {
"$ref": "#/components/schemas/surrenderRequestDetails_surrenderToCarrier"
}
},
"description": "A concrete surrender request related to a transport document.\n\nThe platform guarantees *all* of the following:\n\n 1) The surrender request was submitted by the sole possessor of the EBL.\n 2) Depending on the eBL type:\n * For non-negoitable (\"straight\") eBLs, the surrender request was submitted by either the original shipper OR the consignee.\n * For negotiable eBLs with a named titleholder, the surrender request was submitted by the named titleholder.\n * For negotiable eBLs without a named titleholder / blank eBLs, possession is sufficient for the entity surrendering the eBL.\n 3) The platform has the EBL in custody while the carrier is evaluating this surrender request. I.e., neither possession nor title holder changes can occur until the carrier responds to this surrender request.\n"
Expand Down Expand Up @@ -366,7 +365,7 @@
"type": "string",
"description": "A unique number allocated by the shipping line to the transport document and the main number used for the tracking of the status of the shipment.\n"
},
"supportingPartyCodes_inner": {
"partyCodes_inner": {
"required": [
"partyCode",
"partyCodeListProvider"
Expand All @@ -377,44 +376,24 @@
"maxLength": 100,
"minLength": 1,
"pattern": "^\\S+(\\s+\\S+)*$",
"type": "string",
"example": "54930084UKLVMY22DS16"
"type": "string"
},
"partyCodeListProvider": {
"type": "string",
"description": "Describes which party code list the party code is from. Options are:\n\n - `LEI`: The party code is a Legal Entity Identifier (LEI) as issued by Global Legal Entity Identifier Foundation (GLEIF). See https://www.gleif.org/en\n - `DID`: The party code is a Decentralized Identifier (see https://www.w3.org/TR/did-core/).\n",
"description": "Describes the organisation that provides the party code.\n\n - `EPUI`:The party code is an EBL Platform User Identifier (that is, an identifier provided by a platform, used to transfer eBLs). EPIU should be combined with the `codeListName`, to identify the platform that issued the identifier.\n - `GLEIF`: The party code is issued by Global Legal Entity Identifier Foundation (GLEIF). See https://www.gleif.org/en. The `codeNameList` (if omitted) defaults to `LEI`.\n - `W3C`: The party code is issued by a standard created by World Wide Web Consortium (W3C). See https://www.w3.org/. The `codeNameList` (if omitted) defaults to `DID`.\n",
"enum": [
"LEI",
"DID"
"GLEIF",
"W3C",
"EPUI"
]
}
}
},
"surrenderRequestDetails_surrenderToCarrier": {
"required": [
"partyCode",
"partyCodeListProvider"
],
"properties": {
"partyCode": {
"maxLength": 4,
"minLength": 3,
"pattern": "^\\S+$",
"type": "string",
"description": "The code containing the NMFTA/SCAC and/or the SMDG code to specify the carrier.\n",
"example": "MSC"
},
"partyCodeListProvider": {
"codeListName": {
"maxLength": 100,
"pattern": "^\\S+(\\s+\\S+)*$",
"type": "string",
"description": "Describes which party code list the party code is from. Options are:\n\n - `NMFTA`: The NMFTA (National Motor Freight Traffic Association) includes SPLC (Standard Point Location Code). This is sometimes also refered to as the SCAC code.\n - `SMDG`: The party code is a SMDG code from the Liner Code List.\n",
"example": "SMDG",
"enum": [
"NMFTA",
"SMDG"
]
"description": "The name of the code list / code generation mechanism / code authority for the party code.\n\nFor `EPUI`:\n * `Wave`: An identifier provided by Wave BL.\n * `CargoX`: An identifier provided by CargoX\n * `EdoxOnline`: An identifier provided by EdoxOnline\n * `IQAX`: An identifier provided by IQAX\n * `EssDOCS`: An identifier provided by essDOCS\n * `Bolero`: An identifier provided by Bolero\n * `TradeGO`: An identifierprovided by TradeGo\n * `Secro`: An identifier provided by Secro\n * `GSBN`: An identifier provided by GSBN\n * `WiseTech`: An identifier provided by WiseTech\n\nFor `W3C`:\n * `DID`: The party code is a Decentralized Identifier (see https://www.w3.org/TR/did-core/).\n\nFor `GLEIF`:\n * `LEI`: The party code is a Legal Entity Identifier (LEI) as issued by Global Legal Entity Identifier Foundation (GLEIF). See https://www.gleif.org/en\n"
}
},
"description": "Optinally, describe the carrier that the eBL should be surrendered to. "
}
}
},
"parameters": {
Expand Down

0 comments on commit 125f0ed

Please sign in to comment.