blob: 39be231c476e52f41c8f88b69861e6445dd13d25 [file] [log] [blame]
Alexander Afanasyeveee8c252013-11-21 23:22:41 +00001.. _data:
2
3Data Packet
4-----------
5
6NDN Data packet is TLV defined as follows::
7
8 Data ::= DATA-TLV TLV-LENGTH
9 Name
10 MetaInfo
11 Content
12 Signature
13
14The Data packet represents some arbitrary binary data (held in the Content element) together with its Name, some additional bits of information (MetaInfo), and a digital Signature of the other three elements. The Name is the first element since all NDN packet processing starts with the name. Signature is put at the end of the packet to ease the implementation because signature computation covers all the elements before Signature.
15
16Name
17~~~~
18
Alexander Afanasyeve2800232013-11-27 02:24:14 +000019See :ref:`Name section <Name>` for details.
20
21.. _MetaInfo:
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000022
23MetaInfo
24~~~~~~~~
25
mzhang4333f2c22015-02-20 17:30:17 -060026.. [#f1] If ``ContentType``, ``FreshnessPeriod`` and ``FinalBlockId`` are optional, one may consider ``Metainfo`` itself should be optional. But would having all 4 parts of Data packet help simplify implementation? We leave this question to people who are more familiar with high speed implementations.
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000027
Alexander Afanasyeve2800232013-11-27 02:24:14 +000028::
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000029
30 MetaInfo ::= META-INFO-TYPE TLV-LENGTH
31 ContentType?
32 FreshnessPeriod?
Alexander Afanasyev08f39ce2014-02-12 19:53:50 +000033 FinalBlockId?
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000034
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000035ContentType
36+++++++++++
37
Alexander Afanasyeve2800232013-11-27 02:24:14 +000038::
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000039
Alexander Afanasyeva6fc7272014-06-13 11:58:06 -070040 ContentType ::= CONTENT-TYPE-TYPE TLV-LENGTH
Alexander Afanasyevca58dc22013-12-28 21:04:59 +000041 nonNegativeInteger
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000042
Alexander Afanasyev6b60ddd2015-11-13 00:18:58 +020043The following ContentTypes are currently defined:
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000044
Alexander Afanasyev6b60ddd2015-11-13 00:18:58 +020045+-----------------+----------------+--------------------------------------------------------------+
46| ContentType | Assigned value | Description of the content |
47+=================+================+==============================================================+
48| BLOB | 0 | payload identified by the data name; this is the default |
49| | | ContentType |
50+-----------------+----------------+--------------------------------------------------------------+
51| LINK | 1 | another name which identifies the actual data content |
52+-----------------+----------------+--------------------------------------------------------------+
53| KEY | 2 | public key |
54+-----------------+----------------+--------------------------------------------------------------+
55| NACK | 3 | application-level NACK |
56+-----------------+----------------+--------------------------------------------------------------+
57
Alexander Afanasyev9e7af4b2016-09-13 13:14:18 -070058Other ContentType numbers are assigned and maintained in `NDN Packet Specification Wiki <https://redmine.named-data.net/projects/ndn-tlv/wiki/ContentType>`__.
59
60
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000061FreshnessPeriod
62+++++++++++++++
63
Alexander Afanasyeve2800232013-11-27 02:24:14 +000064::
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000065
Alexander Afanasyeva6fc7272014-06-13 11:58:06 -070066 FreshnessPeriod ::= FRESHNESS-PERIOD-TLV TLV-LENGTH
Alexander Afanasyevca58dc22013-12-28 21:04:59 +000067 nonNegativeInteger
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000068
Alexander Afanasyeva6fc7272014-06-13 11:58:06 -070069The optional FreshnessPeriod indicates how long a node should wait after the arrival of this data before marking it as stale. The encoded value is number of milliseconds. Note that the stale data is still valid data; the expiration of FreshnessPeriod only means that the producer may have produced newer data.
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000070
Alexander Afanasyev7455e9b2014-06-25 09:41:08 -070071When FreshnessPeriod is omitted, the Data packet cannot be marked stale.
72
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000073Each content store associates every piece of Data with a staleness bit.
Alexander Afanasyeva6fc7272014-06-13 11:58:06 -070074The initial setting of this bit for newly-arrived content is "not stale". If the Data carries FreshnessPeriod, then after the Data has been residing in the content store for FreshnessPeriod, it will be marked as stale. This is per object staleness and local to the NDN node. Another possible way to set the staleness bit of a local content is for a local client to send a command to the local NDN daemon.
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000075
Alexander Afanasyeva6fc7272014-06-13 11:58:06 -070076If an Interest contains MustBeFresh TLV, a Data that has the staleness bit set is not eligible to be sent in response to that Interest.
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000077The effect is the same as if that stale Data did not exist (i.e., the Interest might be matched by some other Data in the store, or, failing that, get forwarded to other nodes).
78If an exact duplicate of a stale Data arrives, the effect is the same as if the stale Data had not been present. In particular, the Data in the store is no longer stale. As a practical matter, a stale Data should be ranked high on the list of things to discard from the store when a storage quota has been reached.
79
Alexander Afanasyev08f39ce2014-02-12 19:53:50 +000080FinalBlockId
81++++++++++++
82
83::
84
Alexander Afanasyeva6fc7272014-06-13 11:58:06 -070085 FinalBlockId ::= FINAL-BLOCK-ID-TLV TLV-LENGTH
Alexander Afanasyev08f39ce2014-02-12 19:53:50 +000086 NameComponent
87
88The optional FinalBlockId indicates the identifier of the final block
89in a sequence of fragments.
90It should be present in the final block itself, and may also be present in other fragments to provide advanced warning of the end to consumers.
91The value here should be equal to the last explicit Name Component of the final block.
92
93
Alexander Afanasyeve2800232013-11-27 02:24:14 +000094.. _Content:
Alexander Afanasyeveee8c252013-11-21 23:22:41 +000095
96Content
97~~~~~~~
98
Alexander Afanasyeve2800232013-11-27 02:24:14 +000099::
Alexander Afanasyeveee8c252013-11-21 23:22:41 +0000100
101 Content ::= CONTENT-TYPE TLV-LENGTH BYTE*