TCMF Handbook Help

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