Example messages
Departure from the port of Vasa
{
"payload": {
"@type": "LocationState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"timeSequence": "departed_from",
"location": "tcmf:location:port:FIVAA",
"time": "2025-01-24T08:20:00:12.000Z"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:FIVAA:ar458"
],
"reportedAt": "2025-01-24T08:22:52.100Z",
"reportedBy": "tcmf:user:FIVAA:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:transport_leg:legit:123",
"timeSequence": "commenced",
"time": "2025-01-24T08:20:12.000Z",
"location": "tcmf:location:port:FIVAA"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:transport_leg:legit:123"
],
"reportedAt": "2025-01-24T08:22:52.100Z",
"reportedBy": "tcmf:user:FIVAA:pc"
}
Arrival to the port of Umeå
{
"payload": {
"@type": "LocationState",
"timeType": "planned",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"timeSequence": "arrived_to",
"location": "tcmf:location:port:SEUME",
"time": "2025-01-24T13:00:00.000Z"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-22T13:48:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:transport_leg:legit:123",
"timeSequence": "completeded",
"time": "2025-01-24T14:00:12.000Z",
"location": "tcmf:location:port:SEUME"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:transport_leg:legit:123"
],
"reportedAt": "2025-01-24T14:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "LocationState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"timeSequence": "arrived_to",
"location": "tcmf:location:port:SEUME",
"time": "2025-01-24T13:00:12.000Z"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
PortVisit begins
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:port_visit:portcall_id:SEUME:1556",
"timeSequence": "commenced",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:port_visit:portcall_id:SEUME:1556:commenced",
"attribute": "tcmf:attribute:ship:fuel_level:electricity:2 MWh",
"timeSequence": "set",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:wasaline:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:port_visit:portcall_id:SEUME:1556:commenced",
"attribute": "tcmf:attribute:ship:fuel_level:lbg:10 m³",
"timeSequence": "set",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:wasaline:pc"
}
Berthing begins
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:mooring_operations:port_visit:portcall_id:SEUME:1556",
"timeSequence": "commenced",
"time": "2025-01-24T13:15:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:22:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:mooring_operations:port_visit:portcall_id:SEUME:1556",
"timeSequence": "completed",
"time": "2025-01-24T13:32:53.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:32:53.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:mooring_operations:port_visit:portcall_id:SEUME:1556",
"attribute": "tcmf:attribute:ship:fuel_consumption:electricity:10 kWh",
"timeSequence": "set",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
Ship loading operation begins
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:cargo_operations:port_visit:portcall_id:SEUME:1556",
"timeSequence": "commenced",
"time": "2025-01-24T13:52:53.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-24T13:52:53.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:ship:name:Aurora Botnia",
"service": "tcmf:service:cargo_operations:port_visit:portcall_id:SEUME:1556",
"timeSequence": "completed",
"time": "2025-01-24T14:42:53.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-24T14:52:53.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
To express how much of the transported tonnage was in this shipment, we connect the attribute state through the reference object to cargo operations and through grouping to the shipment. Please note that this is not an ideal solution and we may have to add a layer of states to find a clearer expression
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:cargo_operations:port_visit:portcall_id:SEUME:1556",
"attribute": "tcmf:attribute:shipment:part_of_total_tonnage:5 %",
"timeSequence": "set",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:cargo_operations:port_visit:portcall_id:SEUME:1556:commenced",
"attribute": "tcmf:attribute:tractor1:fuel_level:diesel:300 litre",
"timeSequence": "set",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:cargo_operations:port_visit:portcall_id:SEUME:1556:completed",
"attribute": "tcmf:attribute:tractor1:fuel_level:diesel:250 litre",
"timeSequence": "set",
"time": "2025-01-24T13:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-24T13:02:52.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:port_visit:portcall_id:SEUME:1556:completed",
"attribute": "tcmf:attribute:ship:fuel_level:electricity:1 MWh",
"timeSequence": "set",
"time": "2025-01-24T16:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T16:02:52.100Z",
"reportedBy": "tcmf:user:wasaline:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:port_visit:portcall_id:SEUME:1556:completed",
"attribute": "tcmf:attribute:ship:fuel_level:lbg:5 m³",
"timeSequence": "set",
"time": "2025-01-24T16:00:12.000Z",
"location": "tcmf:location:port:SEUME:Södra Kajen"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-24T16:02:52.100Z",
"reportedBy": "tcmf:user:wasaline:pc"
}
Train, incoming journey
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:train:se:otn:4367",
"service": "tcmf:service:transport_leg:legit:124",
"timeSequence": "commenced",
"time": "2025-01-23T22:00:12.000Z",
"location": "tcmf:location:train:station:Gävle"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:transport_leg:legit:124"
],
"reportedAt": "2025-01-23T22:22:52.100Z",
"reportedBy": "tcmf:user:trv:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:train:se:otn:4367",
"service": "tcmf:service:transport_leg:legit:124",
"timeSequence": "completed",
"time": "2025-01-24T06:00:12.000Z",
"location": "tcmf:location:train:station:Umeå"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:transport_leg:legit:124"
],
"reportedAt": "2025-01-24T06:22:52.100Z",
"reportedBy": "tcmf:user:trv:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:transport_leg:legit:124:commenced",
"attribute": "tcmf:attribute:train:energy_meter:electricity:23765 MWh",
"timeSequence": "set",
"time": "2025-01-23T22:00:12.000Z"
},
"grouping": [
"tcmf:grouping:train:se:otn:4367"
],
"reportedAt": "2025-01-23T22:02:52.100Z",
"reportedBy": "tcmf:user:trv:pc"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:transport_leg:legit:124:completed",
"attribute": "tcmf:attribute:train:energy_meter:electricity:23800 MWh",
"timeSequence": "set",
"time": "2025-01-23T22:00:12.000Z"
},
"grouping": [
"tcmf:grouping:train:se:otn:4367"
],
"reportedAt": "2025-01-23T22:02:52.100Z",
"reportedBy": "tcmf:user:trv:pc"
}
Train loading operations
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:train:se:otn:4367",
"service": "tcmf:service:cargo_operations:train_departure:train:se:otn:4367:Hod",
"timeSequence": "commenced",
"time": "2025-01-25T08:42:53.000Z",
"location": "tcmf:location:port:SEUME"
},
"grouping": [
"tcmf:grouping:train:se:otn:4367",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-25T08:52:53.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:train:se:otn:4367",
"service": "tcmf:service:cargo_operations:train_departure:train:se:otn:4367:Hod",
"timeSequence": "completed",
"time": "2025-01-25T09:12:53.000Z",
"location": "tcmf:location:port:SEUME"
},
"grouping": [
"tcmf:grouping:train:se:otn:4367",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-25T08:52:53.100Z",
"reportedBy": "tcmf:user:SEUME:pc"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:train:se:otn:4367",
"service": "tcmf:service:transport:train:se:otn:4367",
"timeSequence": "commenced",
"time": "2025-01-25T10:00:03.000Z",
"location": "tcmf:location:railway:se:Hod"
},
"grouping": [
"tcmf:grouping:train:se:otn:4367",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-25T10:04:53.100Z",
"reportedBy": "tcmf:user:trv:rfid"
}
{
"payload": {
"@type": "ServiceState",
"timeType": "actual",
"referenceObject": "tcmf:reference_object:train:se:otn:4367",
"service": "tcmf:service:transport:train:se:otn:4367",
"timeSequence": "completed",
"time": "2025-01-27T08:00:13.000Z",
"location": "tcmf:location:railway:se:G"
},
"grouping": [
"tcmf:grouping:train:se:otn:4367",
"tcmf:grouping:shipment:rodo:12345A"
],
"reportedAt": "2025-01-27T08:02:23.100Z",
"reportedBy": "tcmf:user:trv:rfid"
}
{
"payload": {
"@type": "AttributeState",
"timeType": "actual",
"referenceObject": "tcmf:service:transport:train:se:otn:4367",
"attribute": "tcmf:attribute:train:fuel_consumption:electricity:500 MWh",
"timeSequence": "set",
"time": "2025-01-27T08:00:12.000Z"
},
"grouping": [
"tcmf:grouping:ship:name:Aurora Botnia",
"tcmf:grouping:port_visit:portcall_id:SEUME:1556"
],
"reportedAt": "2025-01-27T08:02:52.100Z",
"reportedBy": "tcmf:user:gc:mot"
}
Last modified: 11 March 2025