Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 1 | .. _data: |
| 2 | |
| 3 | Data Packet |
| 4 | ----------- |
| 5 | |
| 6 | NDN Data packet is TLV defined as follows:: |
| 7 | |
| 8 | Data ::= DATA-TLV TLV-LENGTH |
| 9 | Name |
| 10 | MetaInfo |
| 11 | Content |
| 12 | Signature |
| 13 | |
| 14 | The 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 | |
| 16 | Name |
| 17 | ~~~~ |
| 18 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 19 | See :ref:`Name section <Name>` for details. |
| 20 | |
| 21 | .. _MetaInfo: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 22 | |
| 23 | MetaInfo |
| 24 | ~~~~~~~~ |
| 25 | |
mzhang4 | 333f2c2 | 2015-02-20 17:30:17 -0600 | [diff] [blame] | 26 | .. [#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 Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 27 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 28 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 29 | |
| 30 | MetaInfo ::= META-INFO-TYPE TLV-LENGTH |
| 31 | ContentType? |
| 32 | FreshnessPeriod? |
Alexander Afanasyev | 08f39ce | 2014-02-12 19:53:50 +0000 | [diff] [blame] | 33 | FinalBlockId? |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 34 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 35 | ContentType |
| 36 | +++++++++++ |
| 37 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 38 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 39 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 40 | ContentType ::= CONTENT-TYPE-TYPE TLV-LENGTH |
Alexander Afanasyev | ca58dc2 | 2013-12-28 21:04:59 +0000 | [diff] [blame] | 41 | nonNegativeInteger |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 42 | |
Alexander Afanasyev | 6b60ddd | 2015-11-13 00:18:58 +0200 | [diff] [blame] | 43 | The following ContentTypes are currently defined: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 44 | |
Alexander Afanasyev | 6b60ddd | 2015-11-13 00:18:58 +0200 | [diff] [blame] | 45 | +-----------------+----------------+--------------------------------------------------------------+ |
| 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 | +-----------------+----------------+--------------------------------------------------------------+ |
spirosmastorakis | 988e741 | 2016-10-27 14:01:59 -0700 | [diff] [blame] | 51 | | LINK | 1 | a list of delegations (see :ref:`link`) | |
Alexander Afanasyev | 6b60ddd | 2015-11-13 00:18:58 +0200 | [diff] [blame] | 52 | +-----------------+----------------+--------------------------------------------------------------+ |
| 53 | | KEY | 2 | public key | |
| 54 | +-----------------+----------------+--------------------------------------------------------------+ |
| 55 | | NACK | 3 | application-level NACK | |
| 56 | +-----------------+----------------+--------------------------------------------------------------+ |
| 57 | |
Alexander Afanasyev | 9e7af4b | 2016-09-13 13:14:18 -0700 | [diff] [blame] | 58 | Other ContentType numbers are assigned and maintained in `NDN Packet Specification Wiki <https://redmine.named-data.net/projects/ndn-tlv/wiki/ContentType>`__. |
| 59 | |
| 60 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 61 | FreshnessPeriod |
| 62 | +++++++++++++++ |
| 63 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 64 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 65 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 66 | FreshnessPeriod ::= FRESHNESS-PERIOD-TLV TLV-LENGTH |
Alexander Afanasyev | ca58dc2 | 2013-12-28 21:04:59 +0000 | [diff] [blame] | 67 | nonNegativeInteger |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 68 | |
Eric Newberry | 5651986 | 2017-02-13 13:26:19 -0700 | [diff] [blame^] | 69 | The optional FreshnessPeriod indicates how long a node should wait after the arrival of this data before marking it as stale. |
| 70 | The encoded value is number of milliseconds. |
| 71 | Note that the stale data is still valid data; the expiration of FreshnessPeriod only means that the producer may have produced newer data. |
Alexander Afanasyev | 7455e9b | 2014-06-25 09:41:08 -0700 | [diff] [blame] | 72 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 73 | Each content store associates every piece of Data with a staleness bit. |
Eric Newberry | 5651986 | 2017-02-13 13:26:19 -0700 | [diff] [blame^] | 74 | If the Data carries a FreshnessPeriod, it will initially be considered "fresh" and, after the Data has resided in the content store for FreshnessPeriod, it will be marked as stale. |
| 75 | This is per object staleness and is local to the NDN node. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 76 | |
Eric Newberry | 5651986 | 2017-02-13 13:26:19 -0700 | [diff] [blame^] | 77 | If an Interest contains MustBeFresh TLV, a content store MUST NOT return Data with the staleness bit set in response to this interest. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 78 | The 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). |
Eric Newberry | 5651986 | 2017-02-13 13:26:19 -0700 | [diff] [blame^] | 79 | When an exact duplicate of the "stale" Data packet, carrying a positive FreshnessPeriod value, is inserted into a content store, the store SHOULD remove the "stale" bit from the cached Data. |
| 80 | In particular, the Data in the store is no longer stale. |
| 81 | |
| 82 | When a content store receives a Data packet without a FreshnessPeriod or with a FreshnessPeriod equal to 0, then it can satisfy an Interest marked MustBeFresh. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 83 | |
Alexander Afanasyev | 08f39ce | 2014-02-12 19:53:50 +0000 | [diff] [blame] | 84 | FinalBlockId |
| 85 | ++++++++++++ |
| 86 | |
| 87 | :: |
| 88 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 89 | FinalBlockId ::= FINAL-BLOCK-ID-TLV TLV-LENGTH |
Alexander Afanasyev | 08f39ce | 2014-02-12 19:53:50 +0000 | [diff] [blame] | 90 | NameComponent |
| 91 | |
| 92 | The optional FinalBlockId indicates the identifier of the final block |
| 93 | in a sequence of fragments. |
| 94 | It 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. |
| 95 | The value here should be equal to the last explicit Name Component of the final block. |
| 96 | |
| 97 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 98 | .. _Content: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 99 | |
| 100 | Content |
| 101 | ~~~~~~~ |
| 102 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 103 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 104 | |
| 105 | Content ::= CONTENT-TYPE TLV-LENGTH BYTE* |