-
Notifications
You must be signed in to change notification settings - Fork 35
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
hashlink is no substitute for proper semantic description of content #548
Comments
It is true that just having a hashlink doesn't provide any semantic details other binding the information digitally signed over to a very specific serialization of something. In some use cases, that might be enough... for example, hashlinking to a PDF/PNG/JPG such that a manual human process can perform after-the-fact discovery if something goes wrong, knowing that they're looking at the same document that was linked to in the original message. It would be much better to hashlink to a document with some level of semantics, but that's not always possible or necessary. It really does depend on the use case. I can't speak to this specific example without doing a deep dive on the use case, which I (unfortunately) don't have the cycles to do right now. |
Thank you for this! We struggled a bit when creating this, our goal is to link to the product definition here: product, and indicate that this MUST be a hashlink, or a fully embedded product object, i.e. we want to semantically say this element is a product, and to reach it you must use a hashlink or embed the product schema. |
@mkhraisha Is it really important to capture immutability?
Your schema doesn't capture the "embedded product object" case. I've raised such need earlier in #280 (@OR13 @nissimsan). |
This line should be updated to not rely on hashlinks: |
Can we pull a commission event object schema from: https://ref.gs1.org/standards/epcis/ |
Look into EPCIS if there's a proper term we can use for this term definition. |
{
"type": "TransformationEvent",
"eventTime": "2020-01-14T00:00:00+01:00",
"eventTimeZoneOffset": "+01:00",
"eventID": "urn:uuid:374d95fc-9457-4a51-bd6a-0bba133845a8",
"inputEPCList": [
"urn:epc:id:sgtin:4012345.011111.987"
],
"outputEPCList": [
"urn:epc:id:sgtin:4012345.033333.AGHFG"
],
"inputQuantityList": [
{
"epcClass": "urn:epc:class:lgtin:4012345.022222.87545GHGH",
"quantity": 500,
"uom": "KGM"
}
],
"outputQuantityList": [
{
"epcClass": "urn:epc:idpat:sgtin:4012345.044444.*",
"quantity": 452,
"uom": "KGM"
}
],
"bizStep": "commissioning",
"readPoint": {"id": "urn:epc:id:sgln:0614141.07346.1234"},
"errorDeclaration": {
"declarationTime": "2020-01-15T00:00:00+01:00",
"reason": "incorrect_data",
"example:vendorExtension": "Test1",
"correctiveEventIDs": [
"urn:uuid:404d95fc-9457-4a51-bd6a-0bba133845a8"
]
}
}{
"type": "TransformationEvent",
"eventTime": "2020-01-14T00:00:00+01:00",
"eventTimeZoneOffset": "+01:00",
"eventID": "urn:uuid:374d95fc-9457-4a51-bd6a-0bba133845a8",
"inputEPCList": [
"urn:epc:id:sgtin:4012345.011111.987"
],
"outputEPCList": [
"urn:epc:id:sgtin:4012345.033333.AGHFG"
],
"inputQuantityList": [
{
"epcClass": "urn:epc:class:lgtin:4012345.022222.87545GHGH",
"quantity": 500,
"uom": "KGM"
}
],
"outputQuantityList": [
{
"epcClass": "urn:epc:idpat:sgtin:4012345.044444.*",
"quantity": 452,
"uom": "KGM"
}
],
"bizStep": "commissioning",
"readPoint": {"id": "urn:epc:id:sgln:0614141.07346.1234"},
"errorDeclaration": {
"declarationTime": "2020-01-15T00:00:00+01:00",
"reason": "incorrect_data",
"example:vendorExtension": "Test1",
"correctiveEventIDs": [
"urn:uuid:404d95fc-9457-4a51-bd6a-0bba133845a8"
]
}
} |
I believe a solution is at line to move from:
to:
|
Agreed, @mkhraisha. Ideally, though, we find an existing alternative to |
How about https://schema.org/Product |
(Split from #290)
https://github.com/w3c-ccg/traceability-vocab/blob/main/docs/openapi/components/schemas/common/CommissionEvent.yml#L43
@nissimsan @mkhraisha
Problems with this example:
products
to a general URL regarding one aspect of data representation ("content protected with hashlink"). If you want to protect e.g. a list of containers with hashlink, would you use another specific termcontainers
and still bind to that general URL?Hashlink protection can only be used in conjunction with some defined semantic representation, not on its own. @msporny do you agree?
If you want to follow a standard, please read about epcis:ObjectEvent (added to #385 that CommissionEvent seems to address the same event as epcis:ObjectEvent CREATE).
The text was updated successfully, but these errors were encountered: