Network Working Group T. Herbert
Internet-Draft SiPanda
Intended status: Standards Track 7 October 2023
Expires: 9 April 2024
Firewall and Service Tickets
draft-herbert-fast-07
Abstract
This document describes the Firewalls and Service Tickets (FAST)
protocol. This is a generic and extensible protocol for hosts to
signal network nodes to request services or to gain admission into a
network. A ticket is data that accompanies a packet and indicates a
granted right to traverse a network or a request for network services
to be applied (in the latter case the ticket serves as a service
profile). Applications request tickets from a local agent in their
network and attach issued tickets to packets. Firewall tickets are
issued to grant packets the right to traverse a network; service
tickets indicate the desired service to be applied to packets. A
single ticket may provide both firewall and service ticket
information and semantics. Tickets are sent in IPv6 Hop-by-Hop
options.
Status of This Memo
This Internet-Draft is submitted in full conformance with the
provisions of BCP 78 and BCP 79.
Internet-Drafts are working documents of the Internet Engineering
Task Force (IETF). Note that other groups may also distribute
working documents as Internet-Drafts. The list of current Internet-
Drafts is at https://datatracker.ietf.org/drafts/current/.
Internet-Drafts are draft documents valid for a maximum of six months
and may be updated, replaced, or obsoleted by other documents at any
time. It is inappropriate to use Internet-Drafts as reference
material or to cite them other than as "work in progress."
This Internet-Draft will expire on 9 April 2024.
Copyright Notice
Copyright (c) 2023 IETF Trust and the persons identified as the
document authors. All rights reserved.
Herbert Expires 9 April 2024 [Page 1]
Internet-Draft FAST October 2023
This document is subject to BCP 78 and the IETF Trust's Legal
Provisions Relating to IETF Documents (https://trustee.ietf.org/
license-info) in effect on the date of publication of this document.
Please review these documents carefully, as they describe your rights
and restrictions with respect to this document. Code Components
extracted from this document must include Revised BSD License text as
described in Section 4.e of the Trust Legal Provisions and are
provided without warranty as described in the Revised BSD License.
Table of Contents
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 3
1.1. Motivation for FAST . . . . . . . . . . . . . . . . . . . 3
1.2. Terminology . . . . . . . . . . . . . . . . . . . . . . . 4
2. Hop-by-Hop Options as a signal carrier . . . . . . . . . . . 4
2.1. Motivation for using Hop-by-Hop Options . . . . . . . . . 4
2.2. Drawbacks of Hop-by-Hop Options . . . . . . . . . . . . . 5
2.2.1. Mitigating Hop-by-Hop Options packet drops . . . . . 5
2.2.2. Support in IPv4 . . . . . . . . . . . . . . . . . . . 6
3. Architecture . . . . . . . . . . . . . . . . . . . . . . . . 7
3.1. Example communications flow . . . . . . . . . . . . . . . 8
4. Protocol format . . . . . . . . . . . . . . . . . . . . . . . 10
4.1. Option format . . . . . . . . . . . . . . . . . . . . . . 10
4.2. Option types . . . . . . . . . . . . . . . . . . . . . . 11
4.3. Ticket Data format . . . . . . . . . . . . . . . . . . . 11
5. Operation . . . . . . . . . . . . . . . . . . . . . . . . . . 12
5.1. Origin and reflection properties . . . . . . . . . . . . 12
5.2. Origin application processing . . . . . . . . . . . . . . 13
5.2.1. Ticket requests . . . . . . . . . . . . . . . . . . . 13
5.2.2. Ticket identification . . . . . . . . . . . . . . . . 14
5.2.3. Ticket use . . . . . . . . . . . . . . . . . . . . . 14
5.2.4. Ticket agent delegation . . . . . . . . . . . . . . . 14
5.3. Origin network processing . . . . . . . . . . . . . . . . 15
5.4. Destination host processing . . . . . . . . . . . . . . . 16
5.5. Processing reflected tickets . . . . . . . . . . . . . . 16
5.5.1. Network processing . . . . . . . . . . . . . . . . . 16
5.5.2. Host processing . . . . . . . . . . . . . . . . . . . 16
5.6. Removing tickets from packets . . . . . . . . . . . . . . 17
5.6.1. Methods to remove tickets . . . . . . . . . . . . . . 17
5.6.1.1. Overwriting with a null ticket . . . . . . . . . 17
5.6.1.2. Removing Hop-by-Hop Options containing tickets . 17
5.6.2. Removing tickets without loss of functionality . . . 17
5.6.3. Removing tickets with loss of functionality . . . . . 18
6. Implementation considerations . . . . . . . . . . . . . . . . 19
6.1. Origin applications . . . . . . . . . . . . . . . . . . . 19
6.2. Router implementation . . . . . . . . . . . . . . . . . . 20
6.3. Ticket reflection . . . . . . . . . . . . . . . . . . . . 20
6.4. Security Considerations . . . . . . . . . . . . . . . . . 20
Herbert Expires 9 April 2024 [Page 2]
Internet-Draft FAST October 2023
7. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 21
8. References . . . . . . . . . . . . . . . . . . . . . . . . . 22
8.1. Normative References . . . . . . . . . . . . . . . . . . 22
8.2. Informative References . . . . . . . . . . . . . . . . . 22
Author's Address . . . . . . . . . . . . . . . . . . . . . . . . 23
1. Introduction
Firewall and Service Tickets (FAST) is a protocol to allow an
application to signal the network to request admission and services
for packets. FAST is the carrier of signals in host to network
signaling. The motivation and use cases of host to network signaling
are discussed in [I-D.herbert-host2netsig].
A ticket is data that is attached to a packet by a source node and is
validated and processed by some or all intermediate nodes in a
network. Tickets can express a grant for packets to traverse a
network or have services applied to them. Tickets can be opaque or
have a visible structure containing attributes of requested services.
Tickets may be encrypted and integrity protected to limit visibility
and prevent abuse.
An application requests tickets for admission or services from a
ticket agent in their local network. The agent issues tickets to the
application which in turn attaches them to its packets. In the
forwarding path, intermediate network nodes may interpret tickets and
apply requested services on packets.
Tickets are validated for authenticity by the network and may contain
an expiration time so that they cannot be easily forged. Tickets do
not have a global interpretation, they can only be interpreted in the
context of the network or limited domain [RFC8799] that issues them.
In order to apply services to inbound packets for a communication,
remote peers reflect received tickets in packets they send without
interpreting them. Tickets are stateless within the network, however
they can be used to attain per flow semantics. Firewall and service
tickets should be non-transferable and revocable.
Tickets are coded in IPv6 Hop-by-Hop options.
1.1. Motivation for FAST
The general motivation and use cases for host to network signaling is
discussed in [I-D.herbert-host2netsig]. The motivation for using
IPv6 Hop-by-Hop Options as the carrier of host to network signals is
discussed below.
Herbert Expires 9 April 2024 [Page 3]
Internet-Draft FAST October 2023
1.2. Terminology
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
document are to be interpreted as described in [RFC2119].
2. Hop-by-Hop Options as a signal carrier
The carrier of host to network signaling in FAST is IPv6 Hop-by-Hop
Options [RFC8200]. This section discusses the motivation for using
Hop-by-Hop Options, the drawbacks of Hop-by-Hop Options, and methods
to mitigate those drawbacks.
2.1. Motivation for using Hop-by-Hop Options
[I-D.herbert-host2netsig] discusses some alternatives that might be
considered for the carrier protocol of host to network signaling.
Compared to the these alternatives, Hop-by-Hop Options has a number
advantages that motivate the use of Hop-by-Hop Options as the
ubiquitous carrier of host to network signals:
* IPv6 Hop-by-Hop Options are explicitly designed to be a standard
and extensible protocol for host to network signaling on a per
packet basis. Hop-by-Hop options also facilitate network to host
signaling.
* Hop-by-Hop Options are defined as part of an Internet standard STD
86 [RFC8200].
* Hop-by-Hop Options are a network layer protocol and are
independent of both transport layer and link layer protocols.
* Hop-by-Hop Options work with any transport protocol, encrypted
IPsec tunnels, as well as any other encapsulation protocols in
IPv6.
* Hop-by-Hop Options are variable length to allow rich expression.
* Hop-by-Hop Options are stateless.
* Hop-by-Hop Options can change between packets of the same flow.
* Hop-by-Hop Options are explicitly intended to be processed by
intermediate nodes in the path of a packet.
Herbert Expires 9 April 2024 [Page 4]
Internet-Draft FAST October 2023
* Hop-by-Hop Options are located in headers of a packet as opposed
to trailers, and the Hop-by-Hop Options header immediately follows
the IPv6 header at a fixed offset in the packet. These
characteristics make Hop-by-Hop Options amenable to efficient
processing in both software and hardware implementations.
2.2. Drawbacks of Hop-by-Hop Options
Hop-by-Hop Options have two main drawbacks:
* Packets containing Hop-by-Hop Options headers may be summarily
discarded by some network providers as a matter of policy
[RFC7872],[RFC9098].
* Hop-by-Hop Options is an IPv6 specific protocol, there is no
equivalent protocol in IPv4.
The sections below describe mitigations for these drawbacks.
2.2.1. Mitigating Hop-by-Hop Options packet drops
The original processing requirements of IPv6 [RFC2460] Hop-by-Hop
Options required all routers in the path to process the Hop-by-Hop
Options header and its options. In response to this requirement,
some routers deferred processing of Hop-by-Hop Options to the
software slow path, others ignored them, and still others elected to
summarily discard all packets containing Hop-by-Hop Options. A
related issue was that the number of Hop-by-Hop Options in a packet
was only limited by the MTU for the packet. The lack of a limit,
combined with the requirement that nodes must skip over unknown
options when the high order bit in the option type isn't set, created
the opportunity for DOS attacks by sending long lists of unknown Hop-
by-Hop options. The net effect of these issues was that deployment
of Hop-by-Hop Options on the Internet was significantly impeded to
the point that the current data suggests that packet with Hop-by-Hop
Options have more than a 99% drop rate [APNIC-EH].
There is ongoing work to fix, or at least mitigate, the deployability
problems of Hop-by-Hop options:
* [RFC8200] specifies that intermediate nodes MAY ignore Hop-by-Hop
options. There is no concept of a Hop-by-Hop option that must be
processed by all nodes, and the current assumption in defining any
new option is that it may be processed by only by some nodes in
the path or even none at all. Allowing nodes to ignore options
they're not interested in, instead of just discarding the packets,
preserves the usability of Hop-by-Hop across the whole path.
Herbert Expires 9 April 2024 [Page 5]
Internet-Draft FAST October 2023
* [I-D.ietf-6man-hbh-processing] modifies the processing of Hop-by-
Hop options described in [RFC8200] to make processing of the IPv6
Hop-by-Hop Options header practical. In particular, this
clarifies the expectation that Hop-by-Hop Options should not be
processed in the slow path and that new Hop-by-Hop options are
designed to always be processed in the fast path.
* [I-D.ietf-6man-eh-limits] specifies that intermediate nodes that
process Hop-by-Hop Options may set and apply configurable limits
on Hop-by-Hop Options processing. For instance, one limit is for
the number of options that are processed; if the limit is exceeded
then options processing is terminated and the packet is forwarded
without any ill-effects. The use of limits is optional and while
specific default limits are recommended, there are no specific
"hard" limits that must be enforced.
* [I-D.herbert-eh-inflight-removal] describes a protocol to remove
Hop-by-Hop Options headers from packets in-flight. This could be
applied in FAST by arranging that the last router that processes a
ticket in a Hop-by-Hop option removes the Hop-by-Hop Options
header from the packet. By removing the Hop-by-Hop Options
header, downstream nodes would allow the packet and no
functionality is lost since the ticket isn't relevant to the
downstream routers.
2.2.2. Support in IPv4
A new IPv4 option could be defined to contain tickets. IPv4 options
are designed to be inspected by intermediate nodes, however support
is not widespread to the extent that they may be less deployable than
even IPv6 Hop-by-Hop Options. A major reason for this is that the
IPv4 header, unlike the IPv6 header, is variable length. Many
hardware devices have long assumed that the IPv4 header is twenty
bytes, processing a larger header will likely be problematic causing
packet discards or packets being relegated to slow path processing.
An alternative to IPv4 Options is to enable Extension Headers in IPv4
[I-D.herbert-ipv4-eh] and use Hop-by-Hop Options in IPv4 packets.
This solution doesn't affect the IP header, but does introduce a new
IP protocol to IPv4 devices. Some routers might need to be
configured to forward IPv4 packets with IP Protocol 0 for Hop-by-Hop
Options. This scheme would affect ECMP routing since the transport
layer headers, continuing the port numbers used in ECMP, would not be
parsed. [I-D.herbert-ipv4-eh] describes repurposing the
Identification field of the IPv4 header to be a flow label to
compensate for the effects on routers if they can't access transport
layer headers.
Herbert Expires 9 April 2024 [Page 6]
Internet-Draft FAST October 2023
3. Architecture
The figure below illustrates an example of network paths between
three communicating hosts. Each host connects to the Internet via a
provider network, and provider networks are connected in the Internet
by transit networks. In this example, User 1 and User 2 reside in
Provider A's network and User 2 is in Provider B's network. With
respect to FAST, we'll assume User 1 and User 2 are in the same
limited domain and User 3 is in a different limited domain than User
1 and User 2.
_____
__________ ( ) __________
+--------+ ( ) ( ) ( ) +--------+
| User 1 +---( Provider A )--( Transit )--( Provider B )---+ User 3 |
+--------+ (__________) ( ) (__________) +--------+
| (_____)
+--------+
| User 2 |
+--------+
Figure 1
Within each provider network, services may be provided on behalf of
the users of the network. In the figure above, Provider 1 may
provide services and service agreements for users in its network
including User 1 and User 2; and likewise Provider B can provide
services to users in its network including User 3. We assume transit
networks don't typically provide user specific services or service
differentiation. Services provided by different provider networks
may be very different and dependent on the implementation of the
network as well as the policies of the provider.
Based on this model, services and service differentiation can be
considered local to each network provider. FAST is a mechanism
whereby each user and application can request from its local provider
the services to be applied to its traffic. A request for service is
made to a FAST "ticket agent". The contents of the request describe
the services that the application desires. The ticket agent responds
with a "ticket" that the application sets in its packets. The ticket
has meaning in its "origin network", that is the provider network in
which the ticket was created. A ticket provided by a local ticket
agent is attached to packets as an "origin ticket".
When a packet is sent by the application with an attached origin
ticket, the ticket is interpreted by nodes in the local provider
network as the origin network of the ticket. The ticket is
interpreted and processed to allow the packet to traverse the network
and to map it to the appropriate services. A ticket is only relevant
Herbert Expires 9 April 2024 [Page 7]
Internet-Draft FAST October 2023
to the origin network that issued the ticket; to the application
itself and nodes outside of the provider's network and its limited
domain, the ticket is an uninterpretable opaque object.
To facilitate network traversal and service mapping in the reverse
direction for a flow, that is packets sent from a peer host, peer
hosts reflect tickets without modification or interpretation. This
is done by saving the ticket received in packets of a flow and
attaching the ticket as a "reflected ticket" to packets being sent on
the flow. When a packet with a reflected ticket enters the origin
network of the ticket, the ticket is processed by a network node to
allow the packet to traverse the network and to map it to the
appropriate services.
The use of tickets may be bilateral for a flow so that each peer
requests service from its local network. Therefore packets may
contain two types of tickets: one that is set by the sending host to
signal its local provider network, and the other is the reflected
ticket that is a signal to the provider network of the peer endpoint.
Tickets are scoped values, they only have meaning in the network in
which they were issued. The format, meaning, and interpretation of
tickets are network specific. By mutual agreement, two networks may
share the policy and interpretations of tickets. For instance, there
could be an agreement between two provider networks to interpret each
others tickets or to use a common format.
3.1. Example communications flow
Figure 2 provides an example communications flow using FAST with
reflected tickets.
Herbert Expires 9 April 2024 [Page 8]
Internet-Draft FAST October 2023
1. Ticket +--------+
request +------------> | Ticket |
/ +---------- | Agent |
+---+ / 2. Ticket +--------+
/ +-----+ reply ______
/ v __________ ( )
+--------+ ( ) ( ) +--------+
| Client +----------( Provider A )--( Internet )---+ Server |
+--------+ (__________) ( ) +--------+
(______)
3. App sends, 4,5. Net applies 6. Ignore ticket 7,8. Server
ticket attached services in Internet reflect
-------------------> -----------------> --------------------+
\
Reverse path /
------------------ ----------------- --------------------+
12. Validate 10,11. Network applies 9. Ignore ticket
reflected ticket services in Internet
Figure 2
Referencing figure 2, consider that the Client is establishing a
video chat with the Server and wishes to have low latency service for
video applied by its local network (Provider A). The flow of events
may be:
1. The Client makes a ticket request to a ticket agent of Provider
A that describes the video application and may include detailed
characteristics such as resolution, frame rate, latency, etc.
2. The ticket agent issues a ticket to the Client that indicates
that packets of the flow have a right to traverse the network
and the services to be applied to the packets of the flow. A
ticket reply is sent to the Client.
3. The video chat application sends packets for the video chat with
the ticket attached in Hop-by-Hop Options.
4. The first hop node in Provider A's network interprets the ticket
in packets and applies the appropriate services (e.g. sets
diffserv, forwards on a network slice, encapsulates in MPLS,
encapsulates with segment routing, etc.).
5. Packets traverse Provider A's network with the appropriate
services being applied.
Herbert Expires 9 April 2024 [Page 9]
Internet-Draft FAST October 2023
6. Packets traverse transit networks and the Server's provider
network, the attached tickets are ignored.
7. Packets are received at the Server. Attached tickets are saved
in the context of the flow for the video chat.
8. The Server's video chat application sends packets back to the
Client. The last ticket previously received from the Client is
now reflected in these packets.
9. Packets traverse the Server's provider network and transit
networks, the reflected ticket is ignored.
10. An ingress node in Provider A's network interprets the reflected
ticket and applies appropriate services to the packets for
traversing the local network.
11. Packets are forwarded within Provider's A network with the
appropriate services applied.
12. Packets are received at the host for the Client. The reflected
ticket may be validated by comparing the received reflected
ticket with that being sent for the flow.
4. Protocol format
A ticket is sent in an option in a Hop-by-Hop Options header.
4.1. Option format
The format of a Hop-by-Hop option containing a ticket is:
1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Option Type | Opt Data Len | Pr| Ticket Type |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| |
~ Ticket Data ~
| |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Fields:
* Option Type: Type of Hop-by-Hop option. This document proposes
two possible types for FAST ticket options: an unmodifiable and a
modifiable variant.
Herbert Expires 9 April 2024 [Page 10]
Internet-Draft FAST October 2023
* Opt Data Len: Length of the option data field. The option data is
comprised the Pr, Ticket Type, and Ticket Data fields.
* Pr: Indicates the origin and reflection properties of the ticket.
Possible values are:
- 0x0: Origin ticket not reflected. Don't reflect at receiver
- 0x1: Origin ticket to be reflected. Ticket is requested to be
reflected by the destination host
- 0x2: Reflected ticket. The ticket was reflected by a
destination host and is being returned to the origin source
host
- 0x3: Reserved
* Ticket Type: The type and format of the ticket. This value is
used by nodes in the origin network to interpret the rest of the
ticket data. Values for this field are specific to the network
that issues the ticket. The type is an IANA managed number space.
A type of 0 indicates a "null" ticket that isn't to be processed
by receivers.
* Ticket Data: Contains the ticket data that describes the service
applied. The format of the data is determined by the Ticket Type.
4.2. Option types
The are two option numbers requested for the ticket option: 0x0F and
0x2F. The latter allows modification by network nodes. Since
tickets are secured, only the nodes in the network that created a
ticket will be able to modify it.
4.3. Ticket Data format
The Ticket Data in FAST Ticket option encodes service parameters that
describe the desired services as well as additional fields that would
be used to provide privacy and integrity.
The format of Ticket Data is not fixed and is determined by the
Ticket Type and the origin network of the ticket. A ticket should be
obfuscated or encrypted for privacy so that only the local network
can interpret it. It should be uninterpretable to any nodes outside
the network and to the application or host that is granted a ticket.
A ticket should be resistant to spoofing so that an attacker cannot
illegitimately get service by applying a ticket observed on other
flows.
Herbert Expires 9 April 2024 [Page 11]
Internet-Draft FAST October 2023
It is RECOMMENDED that tickets are encrypted to prevent unnecessary
information exposure and abuse of tickets. It is also RECOMMENDED
that tickets have an expiration time. For instance, a ticket may be
created by encrypting the ticket data with an expiration time and
using the source address, destination address, and a shared key as
the key for encryption.
For example, a ticket with an expiration time may have the format:
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Expiration Time |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| |
~ Service Parameters ~
| |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Where the Expiration Time is in a format understood by the local
network nodes which maintain synchronized time. The Service
Parameters are relevant to local network nodes and describe the
services to be applied. The Service Parameters could simply be a set
of flags for services, an index to a service profile table shared
amongst the network nodes, or possibly have more elaborate structure
that could indicate numerical values for characteristics that have a
range.
A simple ticket containing a service protocol index might have the
format:
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Expiration time |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Service Profile Index |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Where the Ticket Type would indicate the Ticket Data contains a
service profile index. Service Profile Index could be used as an
index into a table that describes the services to be applied.
5. Operation
5.1. Origin and reflection properties
There are three origin and reflection properties that may be applied
to a ticket:
Herbert Expires 9 April 2024 [Page 12]
Internet-Draft FAST October 2023
* Origin tickets not reflected
* Origin tickets to be reflected
* Reflected tickets
Origin tickets are those set by an application that was issued a
ticket and have an additional property indicating whether they are to
be reflected by a peer host. Reflected tickets are those that have
been received and reflected by a peer host.
A sender SHOULD set at most one ticket option for each property in a
packet. If ticket options with different properties are set within a
single packet, they SHOULD have the following ordering in the Hop-by-
Hop Options list:
* Origin ticket not reflected
* Reflected ticket
* Origin ticket to be reflected
If a packet contains more than one ticket option with the same origin
and reflection property, only the first ticket option appearing in
the list for the property is processed. Additional options for the
same property MAY be parsed but SHOULD NOT be processed.
5.2. Origin application processing
An origin application requests tickets, sets them in packets, and
validates reflected tickets.
5.2.1. Ticket requests
An application that wishes to use network services first requests
tickets from a ticket agent. The application request could be in the
form of an XML structure with canonical elements (the definition is
outside the scope of this document). The application makes a request
to a ticket agent in its local network. This could be done via a web
service using REST APIs. Internally in the host, the ticket agent
might be accessed through a library that interfaces to a ticket
daemon that in turn arbitrates requests between the applications and
a ticket agent in the network.
An issued ticket is opaque to the application and the application
SHOULD NOT attempt to interpret it or take any other action other
than to attach the ticket to its packets.
Herbert Expires 9 April 2024 [Page 13]
Internet-Draft FAST October 2023
A ticket agent MAY provide both an origin ticket not reflected and
one that is to be reflected. The intent is that different tickets
can be used between the forward and return paths for the flow. In
the case that two tickets are provided, the origin ticket not
reflected MUST appear first in the options list and the origin ticket
to be reflected SHOULD NOT be processed in the forward path.
The protocols and details for making requests to ticket agents are
out of scope for this specification.
5.2.2. Ticket identification
Tickets are valid for the specific IP source and destination
addresses for which they were issued. Transport layer ports and
other transport layer information are not included ticket
identification, however an application can request tickets and
validate reflected tickets on a per flow basis. Issued tickets are
stored in the flow context and the saved information is used to
validate reflected tickets.
5.2.3. Ticket use
When the ticket agent issues and returns a ticket, the application
sets the ticket as a Hop-by-Hop option in packets. This is typically
done by setting a socket option on a socket (in the case of TCP) or
by indicating the option in the ancillary data when sending on a
unconnected socket (in the case of UDP). The application SHOULD
continue to use the same ticket for the flow until it is updated with
a new ticket.
The ticket agent SHOULD return an expiration time with the ticket.
An application can use the ticket until the expiration time, at which
point it can request a new ticket to continue communications. In
order to make the ticket transition process seamless, an application
MAY request a new ticket before the old one expires.
5.2.4. Ticket agent delegation
A network MAY delegate creation of tickets to hosts in a limited
fashion. This would entail the network ticket agent issuing a master
ticket to a host ticket agent which in turn can use the master ticket
to create a limited number of tickets for its own use. The details
of ticket agent delegation are outside the scope of this document.
Herbert Expires 9 April 2024 [Page 14]
Internet-Draft FAST October 2023
5.3. Origin network processing
When a packet with a ticket enters a network, an ingress network node
can determine if the ticket originated in its network and must be
processed. This is done by considering the origin of the ticket and
the source or destination IP address. For an origin ticket (i.e. a
ticket is not reflected), the source address is considered. If the
source address is local to the network then the ticket can be
interpreted. For a reflected ticket, the destination address is
considered. If the destination address is local to the network then
the ticket can be interpreted.
If the ticket origin is determined to be the local network then the
ticket is processed. The ticket is decrypted if necessary and the
expiration time is checked. If the ticket is verified to be
authentic and valid then the packet is mapped to be processed by the
requested services. For instance, in a 5G network the packet may be
forwarded on a network slice for the characteristics that the
application has requested (real-time video for instance).
If an origin ticket cannot be verified, for instance the ticket
cannot be authenticated, then the ticket SHOULD be ignored and the
packet processed as though no ticket were present.
Note that there are logically only two ingress points into the
network at which a provider needs to process tickets: when a local
user sends a packet into the provider network with an origin ticket,
and when a packet from an external network enters the provider's
network with a reflected ticket. Typically, a ticket should only
need to be processed at most once within a network at one of these
ingress points. Once a ticket is processed and mapped to the
network's service mechanisms, it should not normally need further
processing or examination.
If there is more than one origin ticket present, then the first one
encountered is processed and any additional origin tickets SHOULD be
ignored by a network node. Note that this will be the case if a
ticket agent issued both a origin ticket not reflected and one to be
reflected; the origin ticket not reflected should appear first in the
packet and thus would be the one processed by nodes in the origin
network of the ticket.
If there is more than one reflected ticket present, then the first
one encountered is processed and any additional reflected tickets
SHOULD be ignored.
Herbert Expires 9 April 2024 [Page 15]
Internet-Draft FAST October 2023
5.4. Destination host processing
When a host receives a packet with an origin ticket to be reflected,
it SHOULD save the ticket in its flow context and reflect it on
subsequent packets. When the application reflects the option, it
copies the whole option and only modifies the type to indicate a
"reflected ticket". The application SHOULD continue to reflect the
ticket for packets of the flow until a different one is received from
the origin or a packet without an origin ticket to be reflected is
received on the flow. Note that the latest ticket received is the
one to be reflected, if packets have been received out of order for a
flow it is possible that the reflected ticket is from an earlier
packet in a flow.
If there is more than one origin ticket to be reflected present, then
the first one encountered is processed and any additional origin
tickets to be reflected SHOULD be ignored.
A destination host MUST ignore received origin tickets not reflected.
5.5. Processing reflected tickets
5.5.1. Network processing
When a packet with a reflected ticket enters the origin network of
the ticket, the ticket SHOULD be processed. The ticket is validated.
Validation entails decoding or decrypting the ticket and checking the
expiration time. If the ticket is valid and has not expired then the
ticket is processed.
A network MAY accept expired reflected tickets for some configurable
period after the expiration time. Rate limiting MAY be applied to
packets with expired reflected tickets. Accepting expired tickets is
useful in the case that a connection goes idle and after sometime the
remote peer starts to send. The ticket it reflects may be expired
and presumably the receiving host of the reflected ticket will
quickly respond with a new origin ticket to be reflected.
5.5.2. Host processing
Upon receiving a packet with a reflected ticket, an end host MAY
validate the ticket before accepting the packet. This verification
is done by comparing the received ticket to that which is set to be
sent on the corresponding flow. If the tickets do not match then the
event SHOULD be logged.
A host MAY accept expired tickets that are reflected to allow a peer
time to receive and reflect an updated ticket.
Herbert Expires 9 April 2024 [Page 16]
Internet-Draft FAST October 2023
5.6. Removing tickets from packets
Once the last node in a network path has processed a ticket in a
packet, any network downstream nodes won't need to access the ticket.
As stated above, typically only one node in the network needs to
process a ticket. Once a ticket has been processed by the last node
that processes it, it can safely be removed from the packet since
it's not needed by any downstream nodes. The motivation for removing
tickets in-flight is two-fold: 1) It's a security measure to minimize
visibility of the data, and 2) It simplifies the packet to increase
chances of successful delivery across a network.
5.6.1. Methods to remove tickets
There are two methods to remove a ticket from a packet:
* Create a "null" ticket option by writing zeros in the option data.
* Remove the Hop-by-Hop Options header containing the ticket
5.6.1.1. Overwriting with a null ticket
A ticket can be removed from a packet by overwriting the option data
of the ticket with all zeroes. The ticket option type MUST be the
modifiable variant. Ticket Type 0 is reserved as the "null" type and
is not processed by any receivers. Using this method to remove the
option eliminates visibility of ticket data to downstream network
nodes.
5.6.1.2. Removing Hop-by-Hop Options containing tickets
Tickets can be removed from packets by removing the Hop-by-Hop Option
header containing the tickets. The protocol for removing the Hop-by-
Hop Options header in-flight is specified in
[I-D.herbert-eh-inflight-removal]. Note that a Hop-by-Hop Options
may contain multiple tickets or other unrelated options, if multiple
options are present then the effects of removing the whole Hop-by-Hop
Options header should be considered
([I-D.herbert-eh-inflight-removal] offers some guidance).
5.6.2. Removing tickets without loss of functionality
A ticket may be removed from a packet without loss of functionality
under these conditions:
Herbert Expires 9 April 2024 [Page 17]
Internet-Draft FAST October 2023
* The last network node that processes a packet containing an origin
ticket not reflected MAY remove the ticket from a packet. It may
be typical that the last network node that processes the ticket is
the first hop router in the network, so removing the ticket
minimizes visibility of the ticket data to network nodes.
* The last network node that processes a reflected ticket MAY remove
the ticket from a packet. It may be typical that the last network
node to process a reflected ticket will be the ingress network
node of packets received from an external network.
An origin ticket to be reflected cannot be removed from a packet
without affecting functionality. In order for the ticket to be
reflected back to the source host, it must be received by the
destination host.
5.6.3. Removing tickets with loss of functionality
In some cases it may be beneficial to remove tickets from packets at
the cost of losing some functionality. For instance, when a packet
with tickets is exiting a limited domain, it may be better to remove
the Hop-by-Hop Options header containing the ticket rather than
forwarding the packet outside of the limited domain and risking that
the packet will be discarded because it contains a Hop-by-Hop Options
header. In the case of FAST, the effects of removing Hop-by-Hop
Options depends on the properties of tickets in the Hop-by-Hop
Options that are being removed:
* If an origin ticket not reflected is removed then presumably no
intermediate nodes outside the limited domain would process the
ticket, so there is no expected loss of functionality.
* If an origin ticket to be reflected is removed then the ticket
will not be seen by the peer host and will thus never be
reflected. Ingress routers in the return path from the peer will
need to employ alternative mechanisms to deduce packet
characteristics for applying services or may just perform default
processing of packets.
Herbert Expires 9 April 2024 [Page 18]
Internet-Draft FAST October 2023
* If a reflected ticket is removed then the peer network will not
see the ticket and thus its ingress nodes may need to employ
alternate mechanisms to deduce packet characteristics for applying
services or may just perform default processing of packets. Note
that when a reflected ticket is sent this indicates that an origin
ticket to be reflected was received by a destination host. This
establishes that Hop-by-Hop Options are viable over the path from
the original source of the ticket to the reflecting host. If the
network path is symmetric in both directions, then this might
indicate that Hop-by-Hop Options are viable in the return
direction as well.
Removing a Hop-by-Hop Options header containing reflected tickets or
tickets to be reflected when a packet exits a limited domain
represents a tradeoff. On one hand, the benefits and functionality
of ticket reflection are lost, but on the other hand packet discards
may be avoided so communications are still viable and any origin
tickets sent can still be applied in the origin network before the
Hop-by-Hop Options header is removed. To preserve the benefits as
much as possible, the limited domain can be extended to be as large
as possible. As suggested in Figure 1, if two hosts reside in the
same limited domain, like User 1 and User 2, then there is no need to
discard packets with tickets to be reflected or reflected tickets.
It conceivable that methods like probing could be used to extend the
limited domain for Hop-by-Hop Options header viability. For
instance, a type of Happy Eyeballs probing could be done where hosts
or network nodes probe the capabilities of a path to a destination by
sending a number of packets with tickets to be reflected. The
sending host can observe whether packets with tickets are being
properly reflected. If tickets are successfully being reflected then
that is evidence that Hop-by-Hop Options are viable the network path
to and from the destination. A table of destination networks could
be distributed to egress routers of the network, and when they
forward packets with tickets, the routers could consult the table to
determine if the Hop-by-Hop Options header containing the tickets
should be removed.
6. Implementation considerations
6.1. Origin applications
Existing client applications can be modified to request tickets and
set them in packets. The OS networking stack may need some changes
or configuration to enable an application to specify the Hop-by-Hop
option in its packets.
Herbert Expires 9 April 2024 [Page 19]
Internet-Draft FAST October 2023
The interface to the ticket agent would likely be via a library API.
For a connected socket (TCP, SCTP, or connected UDP socket), a Hop-
by-Hop option can be set on the socket via the setsockopt system call
in BSD sockets API. For an unconnected socket (UDP) the ticket
option can be set as ancillary data in the sendmsg system call.
6.2. Router implementation
Routers that process tickets will need to process Hob-by-Hop Options
headers. As described in [I-D.ietf-6man-hbh-processing], routers
should process the ticket options in the fast path. Routers can also
apply the limits described in [I-D.ietf-6man-eh-limits] to limit
processing to only FAST options. For instance, if a Hop-by-Hop
Options header contains FAST options, the router would need to
process or parse at most two options (an origin ticket and a
reflected ticket). Thus the router could enforce a limit on number
of Hop-by-Hop options in a packet to be two (presuming there are no
other Hop-by-Hop Options of interest and that the FAST options always
precede other Hop-by-Hop options that might not be relevant to the
router).
If the tickets defined in a network are all some well known fixed
length then a router could implement processing of fixed length Hop-
by-Hop Options headers instead of variable length ones. Since the
Hop-by-Hop Options header immediately follows the IPv6 header, the
combination of the IPv6 header and the Hop-by-Hop Options header
could be processed as one extended fixed length header.
6.3. Ticket reflection
To perform ticket reflection, servers must be updated. In the case
of a connected socket (TCP, SCTP, or a connected UDP socket) this can
be done as relatively minor change to the kernel networking stack
which would be transparent to applications. For unconnected UDP, an
application could receive the ticket as part of the ancillary data in
recvmsg system call, and then send the reflected ticket in a reply
using ancillary data in sendmsg.
6.4. Security Considerations
There are two main security considerations:
* Leakage of content specific information to untrusted third parties
must be avoided.
Herbert Expires 9 April 2024 [Page 20]
Internet-Draft FAST October 2023
* Tickets cannot be forged, illegitimately used, or otherwise
abused.
Tickets may be visible to the Internet including untrusted and
unknown networks in the path of sent packets. Therefore, tickets
should be encrypted or obfuscated by the origin network. The details
of encrypting tickets are outside the scope of this document.
Tickets need to have an expiration time, must be resistant to
forgery, and must be non-transferable. A ticket should be valid for
the specific source and destination addresses that it was issued for.
Tickets may be revocable by implemented a black-list contained
revoked tickets.
7. IANA Considerations
IANA is requested to assigned the following Hop-By-Hop options:
+-----------+---------------+-------------+---------------+
| Hex Value | Binary value | Description | Reference |
| | act chg rest | | |
+-----------+---------------+-------------+---------------+
| 0x0F | 00 0 01111 | Firewall | This document |
| | | and Service | |
| | | Ticket | |
+-----------+---------------+-------------+---------------+
| 0x2F | 00 1 01111 | Modifiable | This document |
| | | Firewall | |
| | | and Service | |
| | | Ticket | |
+-----------+---------------+-------------+---------------+
IANA is requested to set up a registry for the Ticket Property.
These types are 2 bit values.
+----------------+--------------------+---------------+
| Ticket type | Description | Reference |
+----------------+--------------------+---------------+
| 0x0 | Ticket from origin | This document |
| | and don't reflect | |
+----------------+--------------------+---------------+
| 0x1 | Ticket from origin | This document |
| | and reflect | |
+----------------+--------------------+---------------+
| 0x2 | Reflected ticket | This document |
+----------------+--------------------+---------------+
| 0x3 | Reserved | This document |
+----------------+--------------------+---------------+
Herbert Expires 9 April 2024 [Page 21]
Internet-Draft FAST October 2023
IANA is requested to create a new sub-registry titled "FAST Ticket
Types" for ticket types. The "FAST Ticket Types" registry consists
of 14-bit hexadecimal values along with descriptive strings,
assignee/contact information, and references. The registration rules
for the new registry are (as defined by [RFC8126]):
+-------------------+------------------------------------+
| Range | Registration Procedures |
+-------------------+------------------------------------+
| 0x0000 | This document ("null" type) |
+-------------------+------------------------------------+
| 0x0001-0x00FF | IETF Review |
+-------------------+------------------------------------+
| 0x0100-0x3EFF | First Come First Served |
+-------------------+------------------------------------+
| 0x3F00-0x3FFF | Experimental Use |
+-------------------+------------------------------------+
8. References
8.1. Normative References
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
Requirement Levels", BCP 14, RFC 2119,
DOI 10.17487/RFC2119, March 1997,
<https://www.rfc-editor.org/info/rfc2119>.
[RFC8200] Deering, S. and R. Hinden, "Internet Protocol, Version 6
(IPv6) Specification", STD 86, RFC 8200,
DOI 10.17487/RFC8200, July 2017,
<https://www.rfc-editor.org/info/rfc8200>.
8.2. Informative References
[APNIC-EH] Huston, G., "IPv6 extension headers revisited", October
2022, <https://blog.apnic.net/2022/10/13/ipv6-extension-
headers-revisited>.
[I-D.herbert-eh-inflight-removal]
Herbert, T., "Infight Removal of IPv6 Hop-by-Hop and
Routing Headers", Work in Progress, Internet-Draft, draft-
herbert-eh-inflight-removal-01, 2 October 2023,
<https://datatracker.ietf.org/doc/html/draft-herbert-eh-
inflight-removal-01>.
Herbert Expires 9 April 2024 [Page 22]
Internet-Draft FAST October 2023
[I-D.herbert-host2netsig]
Herbert, T., "Host to Network Signaling", Work in
Progress, Internet-Draft, draft-herbert-host2netsig-00, 4
October 2023, <https://datatracker.ietf.org/doc/html/
draft-herbert-host2netsig-00>.
[I-D.herbert-ipv4-eh]
Herbert, T., "IPv4 Extension Headers and Flow Label", Work
in Progress, Internet-Draft, draft-herbert-ipv4-eh-01, 2
May 2019, <https://datatracker.ietf.org/doc/html/draft-
herbert-ipv4-eh-01>.
[I-D.ietf-6man-eh-limits]
Herbert, T., "Limits on Sending and Processing IPv6
Extension Headers", Work in Progress, Internet-Draft,
draft-ietf-6man-eh-limits-07, 27 September 2023,
<https://datatracker.ietf.org/doc/html/draft-ietf-6man-eh-
limits-07>.
[I-D.ietf-6man-hbh-processing]
Hinden, R. M. and G. Fairhurst, "IPv6 Hop-by-Hop Options
Processing Procedures", Work in Progress, Internet-Draft,
draft-ietf-6man-hbh-processing-10, 26 September 2023,
<https://datatracker.ietf.org/doc/html/draft-ietf-6man-
hbh-processing-10>.
[RFC2460] Deering, S. and R. Hinden, "Internet Protocol, Version 6
(IPv6) Specification", RFC 2460, DOI 10.17487/RFC2460,
December 1998, <https://www.rfc-editor.org/info/rfc2460>.
[RFC7872] Gont, F., Linkova, J., Chown, T., and W. Liu,
"Observations on the Dropping of Packets with IPv6
Extension Headers in the Real World", RFC 7872,
DOI 10.17487/RFC7872, June 2016,
<https://www.rfc-editor.org/info/rfc7872>.
[RFC8799] Carpenter, B. and B. Liu, "Limited Domains and Internet
Protocols", RFC 8799, DOI 10.17487/RFC8799, July 2020,
<https://www.rfc-editor.org/info/rfc8799>.
[RFC9098] Gont, F., Hilliard, N., Doering, G., Kumari, W., Huston,
G., and W. Liu, "Operational Implications of IPv6 Packets
with Extension Headers", RFC 9098, DOI 10.17487/RFC9098,
September 2021, <https://www.rfc-editor.org/info/rfc9098>.
Author's Address
Herbert Expires 9 April 2024 [Page 23]
Internet-Draft FAST October 2023
Tom Herbert
SiPanda
Santa Clara, CA,
United States of America
Email: tom@herbertland.com
Herbert Expires 9 April 2024 [Page 24]