Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 1 | .. _Interest: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 2 | |
| 3 | Interest Packet |
| 4 | --------------- |
| 5 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 6 | NDN Interest packet is TLV defined as follows: |
| 7 | |
| 8 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 9 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 10 | Interest ::= INTEREST-TYPE TLV-LENGTH |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 11 | Name |
| 12 | Selectors? |
| 13 | Nonce |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 14 | InterestLifetime? |
Junxiao Shi | cfc5d21 | 2017-06-02 17:48:51 +0000 | [diff] [blame] | 15 | ForwardingHint? |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 16 | |
Alexander Afanasyev | 7455e9b | 2014-06-25 09:41:08 -0700 | [diff] [blame] | 17 | ``Name`` and ``Nonce`` are the only two required elements in an Interest packet. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 18 | Selectors are optional elements that further qualify Data that may match the Interest. |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 19 | They are used for discovering and selecting the Data that matches best to what the application wants. Selectors are placed right after the Name to facilitate implementations that may use continuous memory block of Name and Selectors TLVs together as the index for PIT lookup. By using a TLV to group all the Selectors, an implementation can easily skip them to find Nonce, which is used together with Name to identify looping Interests. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 20 | If Selectors TLV is present in the Interest, it MUST contain at least one selector. |
| 21 | |
Junxiao Shi | cfc5d21 | 2017-06-02 17:48:51 +0000 | [diff] [blame] | 22 | ``InterestLifetime`` and ``ForwardingHint`` are optional and are referred to as *Guiders*. |
| 23 | They affect Interest forwarding behavior. |
Junxiao Shi | bdc7501 | 2015-01-13 22:09:12 -0700 | [diff] [blame] | 24 | |
| 25 | .. Guiders are not grouped. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 26 | |
| 27 | |
| 28 | Name |
| 29 | ~~~~ |
| 30 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 31 | The Name element in an Interest is synonymous with the term *prefix*. |
| 32 | See :ref:`Name section <Name>` for details. |
| 33 | |
Alexander Afanasyev | 2528636 | 2016-09-05 20:55:25 -0700 | [diff] [blame] | 34 | The Name element that can be put in the Interest is further restricted to have at least one NameComponent. |
| 35 | Interests that include Name TLV that has zero name components MUST BE discarded. |
| 36 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 37 | .. _Selectors: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 38 | |
| 39 | Selectors |
| 40 | ~~~~~~~~~ |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 41 | |
| 42 | :: |
| 43 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 44 | Selectors ::= SELECTORS-TYPE TLV-LENGTH |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 45 | MinSuffixComponents? |
| 46 | MaxSuffixComponents? |
| 47 | PublisherPublicKeyLocator? |
| 48 | Exclude? |
| 49 | ChildSelector? |
| 50 | MustBeFresh? |
| 51 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 52 | MinSuffixComponents, MaxSuffixComponents |
| 53 | ++++++++++++++++++++++++++++++++++++++++ |
| 54 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 55 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 56 | |
| 57 | MinSuffixComponents ::= MIN-SUFFIX-COMPONENTS-TYPE TLV-LENGTH |
| 58 | nonNegativeInteger |
| 59 | |
| 60 | MaxSuffixComponents ::= MAX-SUFFIX-COMPONENTS-TYPE TLV-LENGTH |
| 61 | nonNegativeInteger |
| 62 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 63 | When needed, ``MinSuffixComponents`` and ``MaxSuffixComponents`` allow a data consumer to indicate whether the Name in the Interest is the full name including the digest, or the full name except for the digest, or the content it is seeking has a known range of legitimate component counts. |
| 64 | These two parameters refer to the number of name components beyond those in the prefix, and counting the implicit digest, that may occur in the matching Data. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 65 | The default for ``MinSuffixComponents`` is 0 and for ``MaxSuffixComponents`` is effectively infinite, meaning that any Data whose name starts with the prefix is a match. Often only one of these will be needed to get the desired effect. |
| 66 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 67 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 68 | PublisherPublicKeyLocator |
| 69 | +++++++++++++++++++++++++ |
| 70 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 71 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 72 | |
Alexander Afanasyev | 23c2e41 | 2014-02-12 19:53:48 +0000 | [diff] [blame] | 73 | PublisherPublicKeyLocator ::= KeyLocator |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 74 | |
| 75 | This element specifies the name of the key which is used to sign the Data packet that the consumer is requesting. |
| 76 | This is a way for the Interest to select answers from a particular publisher. |
| 77 | |
Alexander Afanasyev | 23c2e41 | 2014-02-12 19:53:48 +0000 | [diff] [blame] | 78 | See :ref:`KeyLocator` section for more detail. |
| 79 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 80 | Exclude |
| 81 | +++++++ |
| 82 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 83 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 84 | |
Cenk Gündoğan | 9c0dbbd | 2016-09-14 19:21:07 +0200 | [diff] [blame] | 85 | Exclude ::= EXCLUDE-TYPE TLV-LENGTH AnyLeading? (NameComponent | AnyBetween)* AnyTrailing? |
| 86 | AnyLeading ::= Any NameComponent |
| 87 | AnyBetween ::= NameComponent Any NameComponent |
| 88 | AnyTrailing ::= NameComponent Any |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 89 | Any ::= ANY-TYPE TLV-LENGTH(=0) |
| 90 | |
Cenk Gündoğan | bc5f0ec | 2016-09-14 15:49:52 +0200 | [diff] [blame] | 91 | The ``Exclude`` selectors allow requesters to specify list and/or ranges of name components that MUST NOT appear as a continuation of the Name prefix in the responding Data packet to the Interest. |
Alexander Afanasyev | 4b8be21 | 2014-10-06 10:55:04 -0700 | [diff] [blame] | 92 | For example, if Interest is expressed for ``/ndn/edu`` and Exclude specifies one name component ``ucla``, then neither data producer nor conforming NDN routers are allowed to return any Data packet that has prefix ``/ndn/edu/ucla``. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 93 | |
| 94 | Exclude filter applies only to a name component of the Data packet name that is located at a position that numerically equals to the number of name components in the Interest packet, assuming 0 is the first name component. |
| 95 | |
| 96 | The Components in the exclusion list MUST occur in strictly increasing order according to the canonical NDN name component ordering (:ref:`Name Section<name>`), with optional leading, trailing, and interleaved ``Any`` components. The following defines processing of ``Any`` components: |
| 97 | |
Cenk Gündoğan | bc5f0ec | 2016-09-14 15:49:52 +0200 | [diff] [blame] | 98 | - If none of the ``Any`` components are specified, the filter excludes only the names specified in the Exclude list. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 99 | |
| 100 | - If a leading ``Any`` component is specified, then the filter excludes all names that are smaller or equal (in NDN name component canonical ordering) to the first NameComponent in the Exclude list. |
| 101 | |
| 102 | - If a trailing ``Any`` component is specified, then the filter excludes all names that are larger or equal (in NDN name component canonical ordering) to the last NameComponent in the Exclude list. |
| 103 | |
| 104 | - If ``Any`` component is specified between two NameComponents in the list, then the filter excludes all names from the range from the right NameComponent to the left NameComponent, including both ends. |
| 105 | |
| 106 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 107 | Exclude filter MUST not consist of a single ``Any`` component or one NameComponent with leading and trailing ``Any`` components. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 108 | |
| 109 | |
| 110 | ChildSelector |
| 111 | +++++++++++++ |
| 112 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 113 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 114 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 115 | ChildSelector ::= CHILD-SELECTOR-TYPE TLV-LENGTH |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 116 | nonNegativeInteger |
| 117 | |
| 118 | Often a given Interest can match more than one Data within a given content store. |
| 119 | The ``ChildSelector`` provides a way of expressing a preference for which of these should be returned. |
| 120 | If the value is 0, the leftmost child is preferred. |
| 121 | If 1, the rightmost child is preferred. |
| 122 | Here leftmost and rightmost refer to the least and greatest components according to the canonical NDN name component ordering (:ref:`Name Section<name>`). |
| 123 | This ordering is only done at the level of the name hierarchy one past the name prefix. |
Eric Newberry | 1c79995 | 2017-05-20 20:56:16 -0700 | [diff] [blame] | 124 | If the ``ChildSelector`` field is not present, the leftmost child is preferred (a value of 0). |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 125 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 126 | For example, assuming in the name hierarchy the component immediately after the name prefix is the version number, whose next level is the segment number, then setting ChildSelector to be 1 will retrieve the rightmost version number (i.e., the latest version) and the leftmost segment number (i.e., the first segment). However, this selection is only done with respect to a single content store, not globally. Additional rounds that exclude the earlier versions may be used to explore other content stores for newer versions. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 127 | In this case, the use of ChildSelector does not change the multi-round outcome, but it decreases the number of rounds needed to converge to an answer. |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 128 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 129 | MustBeFresh |
| 130 | +++++++++++ |
| 131 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 132 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 133 | |
| 134 | MustBeFresh ::= MUST-BE-FRESH-TYPE TLV-LENGTH(=0) |
| 135 | |
| 136 | This selector is encoded with Type and Length but no Value part. |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 137 | When it is absent from an Interest packet, the router can respond with a Data packet from its content store whose FreshnessPeriod is either still valid or expired. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 138 | When it is present in an Interest packet, the router should not return Data packet from its content store whose FreshnessPeriod has expired. |
| 139 | |
| 140 | The FreshnessPeriod carried in each Data packet (:ref:`Data Section<data>`) is set by the original producer. It starts counting down when the Data packet arrives at a node. Consequently if a node is N hops away from the original producer, it may not consider the Data stale until N *X* FreshnessPeriod after the Data is produced. |
| 141 | |
Alexander Afanasyev | fffabfb | 2013-12-11 21:29:05 +0000 | [diff] [blame] | 142 | .. _Nonce: |
| 143 | |
| 144 | Nonce |
| 145 | ~~~~~ |
| 146 | |
| 147 | Nonce defined as follows: |
| 148 | |
| 149 | :: |
| 150 | |
| 151 | Nonce ::= NONCE-TYPE TLV-LENGTH(=4) BYTE{4} |
| 152 | |
Alexander Afanasyev | 4b89611 | 2014-06-23 21:47:15 -0700 | [diff] [blame] | 153 | The Nonce carries a randomly-generated 4-octet long byte-string. |
Alexander Afanasyev | fffabfb | 2013-12-11 21:29:05 +0000 | [diff] [blame] | 154 | The combination of Name and Nonce should uniquely identify an Interest packet. |
| 155 | This is used to detect looping Interests. |
| 156 | |
| 157 | .. _Guiders: |
| 158 | |
| 159 | Guiders |
| 160 | ~~~~~~~ |
| 161 | |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 162 | InterestLifetime |
| 163 | ++++++++++++++++ |
| 164 | |
Alexander Afanasyev | e280023 | 2013-11-27 02:24:14 +0000 | [diff] [blame] | 165 | :: |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 166 | |
| 167 | InterestLifetime ::= INTEREST-LIFETIME-TYPE TLV-LENGTH nonNegativeInteger |
| 168 | |
Alexander Afanasyev | a6fc727 | 2014-06-13 11:58:06 -0700 | [diff] [blame] | 169 | ``InterestLifetime`` indicates the (approximate) time remaining before the Interest times out. |
Alexander Afanasyev | eee8c25 | 2013-11-21 23:22:41 +0000 | [diff] [blame] | 170 | The value is the number of milliseconds. The timeout is relative to the arrival time of the Interest at the current node. |
| 171 | |
| 172 | Nodes that forward Interests may decrease the lifetime to account for the time spent in the node before forwarding, but are not required to do so. It is recommended that these adjustments be done only for relatively large delays (measured in seconds). |
| 173 | |
| 174 | It is the application that sets the value for ``InterestLifetime``. |
| 175 | If the ``InterestLifetime`` element is omitted, a default value of 4 seconds is used (4000). |
| 176 | The missing element may be added before forwarding. |
spirosmastorakis | 988e741 | 2016-10-27 14:01:59 -0700 | [diff] [blame] | 177 | |
Junxiao Shi | cfc5d21 | 2017-06-02 17:48:51 +0000 | [diff] [blame] | 178 | ForwardingHint |
| 179 | ++++++++++++++ |
spirosmastorakis | 988e741 | 2016-10-27 14:01:59 -0700 | [diff] [blame] | 180 | |
Junxiao Shi | cfc5d21 | 2017-06-02 17:48:51 +0000 | [diff] [blame] | 181 | :: |
spirosmastorakis | 988e741 | 2016-10-27 14:01:59 -0700 | [diff] [blame] | 182 | |
Junxiao Shi | cfc5d21 | 2017-06-02 17:48:51 +0000 | [diff] [blame] | 183 | ForwardingHint ::= FORWARDING-HINT-TYPE TLV-LENGTH |
| 184 | Delegation+ |
spirosmastorakis | 988e741 | 2016-10-27 14:01:59 -0700 | [diff] [blame] | 185 | |
Junxiao Shi | cfc5d21 | 2017-06-02 17:48:51 +0000 | [diff] [blame] | 186 | The ForwardingHint field contains a list of name delegations, as defined in :ref:`link` section. |
| 187 | Each delegation implies that the requested Data packet can be retrieved by forwarding the Interest along the delegation path. |
| 188 | Specifics of the forwarding logic for Interests with ``ForwardingHint`` will be defined in a separated document. |