Skip to content

A proxy to use the upcoming EPCIS 2.0 standard with EVRYTHNG

License

Notifications You must be signed in to change notification settings

evrythng/epcis2.0-to-evrythng

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EPCIS 2.0 Proxy Implementation for EVRYTHNG

A proxy to use the upcoming EPCIS 2.0 standard with the EVRYTHNG API. EPCIS 2.0 is the latest update of the GS1 EPCIS standard and is currently being developed by the EPCIS and CBV 2.0 MSWG. The standard has not been ratified yet, hence consider everything you see here tentative.

Developer documentation

You can find a full tutorial of how to use the proxy in the EVRYTHNG developer documentation.

Overview of the EPCIS 2.0 Proxy

Architecture

This proxy is a (partial) implementation of the EPCIS 2.0 bindings as a proxy for the EVRYTHNG platform. Currently supported are the /capture and /events endpoints. /capture is to store events, /events is to access events individually or entire event collections. The /queries endpoint will allow clients to run complex queries and to subscribe to queries to receive real-time updates when new events emerge that meet the query constraints. If you have an EVRYTHNG account, you can view events as Actions.

Setup

Requirements:

Installation:

  • Make sure serverless is installed globally npm install serverless -g
  • If you're deploying the gateway for the first time, follow these instructions.
  • Install evrythng npm i -s evrythng
  • Deploy the new gateway serverless deploy
  • Debugging information can be obtained by inspecting log files. For example, to read the latest log files for the capture interface, type serverless logs -f capture

Project structure:

  • evrythng-proxy contains the EPCIS 2.0 proxy, that will be deployed on AWS
  • An account on the EVRYTHNG platform, which serves as backend. If you don't provide an API key, you'll use the default public EPCIS 2.0 account on EVRYTHNG.

Some examples

You can either use the default account or create our own account and project. If you don't specify an API key, you'll automatically interact with the default account. If you want to create setup your own environment, you'll need an EVRYTHNG account, create a project and within that project, create an Application to obtain a Trusted App API. When you use the service, include the Trusted App API key in the header Authorization:O5yOC...7aEOwMa3o.

Capturing EPCIS Events

Danny Haak developed a handy EPCIS 2.0 XML to JSON converter. To create your first ObjectEvent, take for instance the first example from https://mimasu.nl/epcis/xmljson and try:

Request

curl -X POST "https://epcis.evrythng.io/v2_0/capture" -H "Content-Type: application/json" -d "@-" << EOF
{
    "@context": "https://id.gs1.org/epcis-context.jsonld",
    "isA": "EPCISDocument",
    "creationDate": "2019-13-06T11:30:47+00:00",
    "schemaVersion": 1.2,
    "format": "application/ld+json",
    "epcisBody": {
      "eventList": [
        {
          "eventID": "oe1",
          "eventTimeZoneOffset": "-06:00",
          "eventTime": "2005-04-03T20:33:31.116-06:00",
          "isA": "ObjectEvent",
          "epcList": [
            "urn:epc:id:sgtin:0614141.107346.2017",
            "urn:epc:id:sgtin:0614141.107346.2018"
          ],
          "action": "ADD",
          "bizStep": "urn:epcglobal:cbv:bizstep:shipping",
          "disposition": "urn:epcglobal:cbv:disp:in_transit",
          "readPoint": "urn:epc:id:sgln:0614141.07346.1234",
          "bizTransactionList": [
            {
              "type": "urn:epcglobal:cbv:btt:po",
              "bizTransaction": "http://transaction.acme.com/po/12345678"
            }
          ]
        },
        {
          "isA": "ObjectEvent",
          "eventID": ":event1",
          "eventTime": "2005-04-04T20:33:31.116-06:00",
          "eventTimeZoneOffset": "-06:00",
          "epcList": [
            "urn:epc:id:sgtin:0614141.107346.1701"
          ],
          "action": "ADD",
          "bizStep": "urn:epcglobal:cbv:bizstep:receiving",
          "disposition": "urn:epcglobal:cbv:disp:in_progress",
          "readPoint": "urn:epc:id:sgln:0012345.11111.400",
          "bizLocation": "urn:epc:id:sgln:0012345.11111.0",
          "bizTransactionList": [
            {
              "type": "urn:epcglobal:cbv:btt:po",
              "bizTransaction": "http://transaction.acme.com/po/12345678"
            },
            {
              "type": "urn:epcglobal:cbv:btt:desadv",
              "bizTransaction": "urn:epcglobal:cbv:bt:0614141073467:1152"
            }
          ]
        }
      ]
    }
  }
EOF

Response

[{"action":"OBSERVE","bizStep":"urn:epcglobal:cbv:bizstep:shipping","bizTransactionList":[{"bizTransaction":"http://transaction.acme.com/po/12345678","type":"urn:epcglobal:cbv:btt:po"}],"disposition":"urn:epcglobal:cbv:disp:in_transit","epcList":["urn:epc:id:sgtin:0614141.107346.2017","urn:epc:id:sgtin:0614141.107346.2018"],"eventTime":"2005-04-03T20:33:31.116-06:00","eventTimeZoneOffset":"-06:00","isA":"ObjectEvent","readPoint":"urn:epc:id:sgln:0614141.07346.1234"},{"action":"OBSERVE","bizLocation":"urn:epc:id:sgln:0012345.11111.0","bizStep":"urn:epcglobal:cbv:bizstep:receiving","bizTransactionList":[{"bizTransaction":"http://transaction.acme.com/po/12345678","type":"urn:epcglobal:cbv:btt:po"},{"bizTransaction":"urn:epcglobal:cbv:bt:0614141073467:1152","type":"urn:epcglobal:cbv:btt:desadv"}],"disposition":"urn:epcglobal:cbv:disp:in_progress","epcList":["urn:epc:id:sgtin:0614141.107346.2018"],"eventTime":"2005-04-04T20:33:31.116-06:00","eventTimeZoneOffset":"-06:00","example:myField":{"#text":"Example of a vendor/user extension","@xmlns:example":"http://ns.example.com/epcis"},"isA":"ObjectEvent","readPoint":"urn:epc:id:sgln:0012345.11111.400"}]

Sensors data

The EPCIS 2.0 proxy handles also the sensors data and the location.

You just need to add a sensorElementList field with a sensorReport. (It has to be an OBSERVE event)

You can try for example :

curl -X POST "https://epcis.evrythng.io/v2_0/capture" -H "Content-Type: application/json" -d "@-" << EOF
{
    "@context": "https://id.gs1.org/epcis-context.jsonld",
    "isA": "EPCISDocument",
    "creationDate": "2019-13-06T11:30:47+00:00",
    "schemaVersion": 1.2,
    "format": "application/ld+json",
    "epcisBody": {
      "eventList": [
        {
           "eventID":"eventID",
           "eventTimeZoneOffset":"-06:00",
           "eventTime":"2005-04-03T20:33:31.116-06:00",
           "isA":"ObjectEvent",
           "epcList":[
              "urn:epc:id:sgtin:0614141.107346.2017",
              "urn:epc:id:sgtin:0614141.107346.2018"
           ],
           "action":"OBSERVE",
           "bizStep":"urn:epcglobal:cbv:bizstep:shipping",
           "disposition":"urn:epcglobal:cbv:disp:in_transit",
           "readPoint":"urn:epc:id:sgln:0614141.07346.1234",
           "sensorElementList":[
              {
                 "sensorReport":[
                    {
                       "type":"gs1:Temperature",
                       "value":17.0
                    },
                    {
                       "type":"gs1:Latitude",
                       "stringValue":"53.553747"
                    },
                    {
                       "type":"gs1:Longitude",
                       "stringValue":"8.562372"
                    }
                 ]
              }
           ],
           "bizTransactionList":[
              {
                 "type":"urn:epcglobal:cbv:btt:po",
                 "bizTransaction":"http://transaction.acme.com/po/12345678"
              }
           ]
        }
      ]
    }
  }
EOF

Response

[
    {
        "action": "OBSERVE",
        "bizStep": "urn:epcglobal:cbv:bizstep:shipping",
        "bizTransactionList": [
            {
                "bizTransaction": "http://transaction.acme.com/po/12345678",
                "type": "urn:epcglobal:cbv:btt:po"
            }
        ],
        "disposition": "urn:epcglobal:cbv:disp:in_transit",
        "epcList": [
            "urn:epc:id:sgtin:0614141.107346.2017",
            "urn:epc:id:sgtin:0614141.107346.2018"
        ],
        "eventID": "eventID",
        "eventTime": "2005-04-03T20:33:31.116-06:00",
        "eventTimeZoneOffset": "-06:00",
        "isA": "ObjectEvent",
        "readPoint": "urn:epc:id:sgln:0614141.07346.1234",
        "sensorElementList": [
            {
                "sensorReport": [
                    {
                        "type": "gs1:Temperature",
                        "value": 17
                    },
                    {
                        "stringValue": "53.553747",
                        "type": "gs1:Latitude"
                    },
                    {
                        "stringValue": "8.562372",
                        "type": "gs1:Longitude"
                    }
                ]
            }
        ],
        "recordTime": "2020-09-29T09:32:07.350Z"
    }
]

Return events of any type

Try this link to get a list of all events from your browser. With curl:

Request

curl https://epcis.evrythng.io/v2_0/events/all -H "Content-Type: application/json"

Response

[{"action":"OBSERVE","bizLocation":"urn:epc:id:sgln:0614141.00888.0","bizStep":"urn:epcglobal:cbv:bizstep:receiving","childEPCs":["urn:epc:id:sgtin:0614141.107346.2017","urn:epc:id:sgtin:0614141.107346.2018"],"childQuantityList":[{"epcClass":"urn:epc:idpat:sgtin:4012345.098765.*","quantity":"10"},{"epcClass":"urn:epc:class:lgtin:4012345.012345.998877","quantity":"200.5","uom":"KGM"}],"disposition":"urn:epcglobal:cbv:disp:in_progress","eventTime":"2013-06-08T14:58:56.591Z","eventTimeZoneOffset":"+02:00","example:myField":"Example of a vendor/user extension","id":"_:event3","isA":"AggregationEvent","parentID":"urn:epc:id:sscc:0614141.1234567890","readPoint":"urn:epc:id:sgln:0614141.00777.0"}]

...

Return all object events

Try this link to get a list of ObjectEvents from your browser. With curl: Request

 curl https://epcis.evrythng.io/v2_0/events/ObjectEvent -H "Content-Type: application/json"

Response

[{"action":"ADD","bizLocation":"urn:epc:id:sgln:0614141.00888.1","bizStep":"urn:fosstrak:demo:bizstep:fmcg:production","bizTransactionList":[{"bizTransaction":"http://transaction.acme.com/po/12345678","type":"urn:epcglobal:cbv:btt:po"},{"bizTransaction":"urn:epcglobal:cbv:bt:0614141073467:1152","type":"urn:epcglobal:cbv:btt:desadv"}],"destinationList":[{"destination":"urn:epc:id:sgln:0614141.00001.0","type":"urn:epcglobal:cbv:sdt:owning_party"}],"disposition":"urn:fosstrak:demo:disp:fmcg:pendingQA","epcList":["urn:epc:id:sgtin:0614141.107346.2011","urn:epc:id:sgtin:0614141.107346.2012"],"eventID":"_:event1","eventTime":"2008-11-09T13:30:17Z","eventTimeZoneOffset":"+00:00","isA":"ObjectEvent","readPoint":"urn:epc:id:sgln:0614141.00777.0","sourceList":[{"source":"urn:epc:id:sgln:4012345.00001.0","type":"urn:epcglobal:cbv:sdt:possessing_party"}]},{"action":"ADD","bizLocation":"urn:epc:id:sgln:0614141.00888.0","bizStep":"urn:fosstrak:demo:bizstep:fmcg:production","bizTransactionList":[{"bizTransaction":"http://transaction.acme.com/po/12345678","type":"urn:epcglobal:cbv:btt:po"},{"bizTransaction":"urn:epcglobal:cbv:bt:0614141073467:1152","type":"urn:epcglobal:cbv:btt:desadv"}],"destinationList":[{"destination":"urn:epc:id:sgln:0614141.00001.0","type":"urn:epcglobal:cbv:sdt:owning_party"}],"disposition":"urn:fosstrak:demo:disp:fmcg:pendingQA","epcList":["urn:epc:id:sgtin:0614141.107346.2017","urn:epc:id:sgtin:0614141.107346.2018"],"eventID":"_:event2","eventTime":"2008-11-09T13:30:17Z","eventTimeZoneOffset":"+00:00","isA":"ObjectEvent","readPoint":"urn:epc:id:sgln:0614141.00777.0","sourceList":[{"source":"urn:epc:id:sgln:4012345.00001.0","type":"urn:epcglobal:cbv:sdt:possessing_party"}]}]

Show me the ObjectEvent _:event1

Try this link to access _:event1 from your browser. With curl:

Request

 curl https://epcis.evrythng.io/v2_0/events/ObjectEvent/_:event1 -H "Content-Type: application/json"
[{"action":"ADD","bizLocation":"urn:epc:id:sgln:0614141.00888.1","bizStep":"urn:fosstrak:demo:bizstep:fmcg:production","bizTransactionList":[{"bizTransaction":"http://transaction.acme.com/po/12345678","type":"urn:epcglobal:cbv:btt:po"},{"bizTransaction":"urn:epcglobal:cbv:bt:0614141073467:1152","type":"urn:epcglobal:cbv:btt:desadv"}],"destinationList":[{"destination":"urn:epc:id:sgln:0614141.00001.0","type":"urn:epcglobal:cbv:sdt:owning_party"}],"disposition":"urn:fosstrak:demo:disp:fmcg:pendingQA","epcList":["urn:epc:id:sgtin:0614141.107346.2011","urn:epc:id:sgtin:0614141.107346.2012"],"eventID":"_:event1","eventTime":"2008-11-09T13:30:17Z","eventTimeZoneOffset":"+00:00","isA":"ObjectEvent","readPoint":"urn:epc:id:sgln:0614141.00777.0","sourceList":[{"source":"urn:epc:id:sgln:4012345.00001.0","type":"urn:epcglobal:cbv:sdt:possessing_party"}]}]

Use filters to narrow down the collection of returned events

List events that are either Aggregation or Object Events and that occurred at the business location urn:epc:id:sgln:0614141.00888.0

Request

curl 'https://epcis.evrythng.io/v2_0/events/all?EQ_eventType=ObjectEvent,AggregationEvent&EQ_bizLocation=urn:epc:id:sgln:0614141.00888.0' -H "Content-Type: application/json"

Response

[{"action":"OBSERVE","bizLocation":"urn:epc:id:sgln:0614141.00888.0","bizStep":"urn:epcglobal:cbv:bizstep:receiving","destinationList":[{"destination":"urn:epc:id:sgln:0614141.00001.0","type":"urn:epcglobal:cbv:sdt:owning_party"},{"destination":"urn:epc:id:sgln:0614141.00777.0","type":"urn:epcglobal:cbv:sdt:location"}],"disposition":"urn:epcglobal:cbv:disp:in_progress","eventID":"oe3","eventTime":"2013-06-08T14:58:56.591+00:00","eventTimeZoneOffset":"+02:00","example:myField":{"#text":"Example of a vendor/user extension","@xmlns:example":"http://ns.example.com/epcis"},"isA":"ObjectEvent","quantityList":[{"epcClass":"urn:epc:class:lgtin:4012345.012345.998877","quantity":200,"uom":"KGM"}],"readPoint":"urn:epc:id:sgln:0614141.00777.0","sourceList":[{"source":"urn:epc:id:sgln:4012345.00001.0","type":"urn:epcglobal:cbv:sdt:possessing_party"},{"source":"urn:epc:id:sgln:4012345.00225.0","type":"urn:epcglobal:cbv:sdt:location"}],"recordTime":"2019-05-21T09:42:00.862Z"}]

Related projects

About

A proxy to use the upcoming EPCIS 2.0 standard with EVRYTHNG

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published