<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.19 (Ruby 3.3.3) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-watal-spring-srv6-sfc-sr-aware-functions-01" category="info" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.23.0 -->
  <front>
    <title abbrev="SRv6 SFC with SR-aware Functions">SRv6 SFC Architecture with SR-aware Functions</title>
    <seriesInfo name="Internet-Draft" value="draft-watal-spring-srv6-sfc-sr-aware-functions-01"/>
    <author initials="W." surname="Mishima" fullname="Wataru Mishima">
      <organization>NTT Communications</organization>
      <address>
        <postal>
          <country>Japan</country>
        </postal>
        <email>w.mishima@ntt.com</email>
      </address>
    </author>
    <author initials="Y." surname="Fukagawa" fullname="Yuta Fukagawa">
      <organization>NTT Communications</organization>
      <address>
        <postal>
          <country>Japan</country>
        </postal>
        <email>y.fukagawa@ntt.com</email>
      </address>
    </author>
    <date year="2024" month="September" day="04"/>
    <area>Routing</area>
    <workgroup>SPRING</workgroup>
    <keyword>SRv6</keyword>
    <keyword>SFC</keyword>
    <abstract>
      <?line 35?>

<t>This document describes the architecture of Segment Routing over IPv6 (SRv6) Service Function Chaining (SFC) with SR-aware functions.
This architecture provides the following benefits:</t>
      <ul spacing="normal">
        <li>
          <t>Comprehensive management: a centralized controller for SFC, handling SR Policy, link-state, and network metrics.</t>
        </li>
        <li>
          <t>Simplicity: no SFC proxies, so that reduces nodes and address resource consumption.</t>
        </li>
      </ul>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the
    Source Packet Routing in Networking Working Group mailing list (spring@ietf.org),
    which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/spring/"/>.</t>
      <t>Source for this draft and an issue tracker can be found at
    <eref target="https://https/github.com/watal"/>.</t>
    </note>
  </front>
  <middle>
    <?line 43?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>Segment Routing over IPv6 (SRv6) <xref target="RFC8986"/> enables packet steering through a set of instructions called a segment list.
Each SR segment endpoint node provides SRv6 Endpoint Behaviors, including Prefix/Adjacency Segments, VPNs, and Binding Segments.</t>
      <t>Service Function Chaining (SFC) <xref target="RFC7665"/> can be used in various scenarios (e.g. FW, IPS, IDS, NAT, and DPI).
SFC based on Segment Routing (SR) is defined in <xref target="I-D.draft-ietf-spring-sr-service-programming"/>, which describes some SRv6 Endpoint Behaviors, such as End.AS/AD/AM, are necessary for using SR-unaware functions.</t>
      <t>This document describes an architecture for SRv6 SFC with SR-aware functions, which provides comprehensive management of SRv6 network resources and services.</t>
    </section>
    <section anchor="terminology">
      <name>Terminology</name>
      <section anchor="terminology-defined-in-related-rfcs-and-internet-drafts">
        <name>Terminology Defined in Related RFCs and Internet-Drafts</name>
        <t>The following terms are used in this document as defined in the related RFCs and Internet-Drafts:</t>
        <ul spacing="normal">
          <li>
            <t>SR, SR Domain, Segment ID (SID), SRv6, SR Policy, Prefix Segment, Adjacency Segment, Anycast Segment, Active Segment, and Distributed/Centralized/Hybrid Control Plane defined in <xref target="RFC8402"/>.</t>
          </li>
          <li>
            <t>SR Source Node, Transit Node, and SR Segment Endpoint Node defined in <xref target="RFC8754"/>.</t>
          </li>
          <li>
            <t>SRv6 Endpoint Behavior defined in <xref target="RFC8986"/>.</t>
          </li>
          <li>
            <t>SFC, SFC Proxy, and Service Classification Function defined in <xref target="RFC7665"/>.</t>
          </li>
          <li>
            <t>Service Segment, SR-Aware Service, SR-Unaware Service, End.AS, End.AD and End.AM defined in <xref target="I-D.draft-ietf-spring-sr-service-programming"/>.</t>
          </li>
          <li>
            <t>Headend, Color, and Endpoint defined in <xref target="RFC9256"/>.</t>
          </li>
          <li>
            <t>Quality of Service (QoS), Service Level Agreement (SLA), and Service Level Objective (SLO) defined in <xref target="RFC9522"/>.</t>
          </li>
          <li>
            <t>Forwarding Plane (FP), Control Plane (CP), Management Plane (MP), Application Plane (AP), Northbound Interface, Southbound Interface defined in <xref target="RFC7426"/>.</t>
          </li>
          <li>
            <t>Path Computation Client (PCC), Path Computation Element (PCE), and Traffic Engineering Database (TED) defined in <xref target="RFC5440"/>.</t>
          </li>
          <li>
            <t>BGP Flow Specification defined in <xref target="RFC8955"/></t>
          </li>
        </ul>
      </section>
      <section anchor="newly-defined-terminology">
        <name>Newly Defined Terminology</name>
        <t>The following terms are used in this document as defined below:</t>
        <ul spacing="normal">
          <li>
            <t>SRv6 Service Function Node: an SR segment endpoint node that provides SR-aware functions as service segments.</t>
          </li>
          <li>
            <t>Classification Rule Controller: applies sets of SR Policy and flows to SR source nodes.</t>
          </li>
          <li>
            <t>Service Function Controller: applies service segments to SRv6 service function nodes.</t>
          </li>
          <li>
            <t>SRv6 Controller: controls SRv6 services comprehensively, consisting of a Service Function Controller, a PCE, and a Classification Rule Controller.</t>
          </li>
          <li>
            <t>SRv6 Managers: manage SRv6 SFC infrastructure, consisting of a Virtualized Network Function (VNF) Manager, a Virtualized Infrastructure Manager (VIM), and a data collector of network metrics.</t>
          </li>
        </ul>
      </section>
      <section anchor="requirements-language">
        <name>Requirements Language</name>
        <t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they appear in all capitals, as shown here.</t>
      </section>
    </section>
    <section anchor="design-objectives-and-assumptions">
      <name>Design Objectives and Assumptions</name>
      <t>## Goals/Objectives
SRv6 SFC Architecture is designed with two main objectives:</t>
      <ul spacing="normal">
        <li>
          <t>Comprehensive management: a centralized controller for SFC, handling SR Policy, link-state, and network metrics.
When providing SRv6 services, meeting SLAs for each customer is required.
These SLAs consist of one or more SLOs such as availability, latency, and bandwidth.
In an SRv6 SFC network, service segment provisioning, link-state collection, and SR Policy calculation are required to meet SLOs, respectively.  </t>
          <t><xref target="RFC8402"/> outlines a hybrid control plane that merges a distributed control plane and a centralized control plane.
In this hybrid control plane, forwarding information like Node/Adjacency SIDs are advertised mutually by distributed SR nodes via IGPs such as ISIS and OSPF, while other information like SR Policies and service segments are provided by a centralized controller.  </t>
          <t>
Software-Defined Networking (SDN) <xref target="RFC7426"/> provides centralized management of a network by a controller and a manager.
Centralized management reduces operational costs through abstraction and automation.
The SDN framework allows users to manage an SR domain without considering the details of a forwarding plane like a topology and node state.
Operators can use a SRv6 controller to build SR Policies for SFC and QoS, manage the state of network functions, issue service segments automatically, and specify disaster recovery with protection.</t>
        </li>
        <li>
          <t>Simplicity: no SFC proxies, so that reduces nodes and address resource consumption.
Network complexity increases operating costs.
Generally, using a variety of protocols in a network raises operational costs, including designing, building, monitoring, and troubleshooting.  </t>
          <t>
Using an SFC proxy may increase forwarding overhead due to additional header manipulations.</t>
        </li>
      </ul>
      <section anchor="assumptions">
        <name>Assumptions</name>
        <t>To achieve these objectives, this architecture is based on two main assumptions:</t>
        <ul spacing="normal">
          <li>
            <t>Straightforward extension of the SRv6 network programming model  </t>
            <t>
The protocol used in this architecture is compatible with SRv6.
This streamlines the operation of services like traffic steering, including SFC, redundancy, and local protection.
Standardized protocols such as BGP, PCEP, IS-IS, OSPF, TI-LFA, and Anycast SID are used in this architecture.  </t>
            <t>
This architecture is SRv6 compliant, enabling support for SR-unaware functions, although SR-aware functions are expected to meet the objective.</t>
          </li>
          <li>
            <t>SDN framework compliance and comprehensive management of SRv6 SFC by controllers  </t>
            <t>
A controller is used to provide comprehensive management.
To simplify building and operating, the controller uses standardized protocols and abstracted service interfaces.
This also provides programmability by controlling policies that meet a user's intent including SFC and quality of service (QoS).</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="overview-of-architecture">
      <name>Overview of Architecture</name>
      <t>Figure 1 illustrates an overview of this architecture.</t>
      <figure anchor="overview">
        <name>Overview of SRv6 SFC Architecture with SR-aware Functions</name>
        <sourcecode type="drawing"><![CDATA[
 +------------------------------------------------+
 |               Application Plane                |
 +------------------------|-----------------------+
                          | Control Plane Northbound Interface
 +--- SRv6 Controller ----v-----------------------+
 | +--------------+ +-------------+ +-----------+ | +-----------+
 | |Classification| |    Path     | | Service   | | |  Service  |
 | |     Rule     | | Computation | | Function  | | |  Funtion  |
 | |  Controller  | |Element (PCE)| |Controller | | |  Managers |
 | +------|-------+ +-^---------|-+ +-----|-----+ | +-----|-----+
 +--------|-----------|---------|---------|-------+   Management
          |           |         |         |             Plane
         Control Plane Southbound Interfaces          Southbound
          |           |         |         |           Interface
 +--------|-----------|---------|---------|---------------|-------+
 | +------v-----------|---------v-+ +-----v---------------v-----+ |
 | |       SR Source Node /       | |       SRv6 Service        | |
 | |    Service Classification    |-|         Function          | |
 | |           Function           | |           Node            | |
 | +------------------------------+ +---------------------------+ |
 +--------------------------- SR domain --------------------------+
]]></sourcecode>
      </figure>
      <t>This architecture is based on SDN <xref target="RFC7426"/> separating the forwarding plane (FP), control plane (CP), management plane (MP), and application plane (AP).
Each plane has the following roles:</t>
      <ul spacing="normal">
        <li>
          <t>Forwarding plane: classifies packets and encapsulates SRH, forwards them, and applies SRv6 Endpoint Behavior.
          </t>
          <ul spacing="normal">
            <li>
              <t>Provides SR-aware function using End.AN.</t>
            </li>
            <li>
              <t>Classify flow and apply them to TE application with PBR.</t>
            </li>
            <li>
              <t>Ensures redundancy with Anycast.</t>
            </li>
            <li>
              <t>Ensure local protection with Fast Reroute (FRR).</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Control plane: makes decisions about packet forwarding and provides rules for a forwarding plane.
          </t>
          <ul spacing="normal">
            <li>
              <t>Collects link-state including SRv6 locator, prefix, behavior, and delay.</t>
            </li>
            <li>
              <t>Calculates and provisioning SR Policies.</t>
            </li>
            <li>
              <t>Applies SR Policies to each flow by provisioning flow classification rules.</t>
            </li>
            <li>
              <t>Manages the provisioning of service segments to SR-aware functions.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Management plane: monitors and maintenances of SRv6 devices and services
          </t>
          <ul spacing="normal">
            <li>
              <t>Monitors and deploys network functions.</t>
            </li>
            <li>
              <t>Manages hypervisor resources.</t>
            </li>
            <li>
              <t>Collects metrics of devices, network functions, and SFC services.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Application plane: provides APIs for users to use a control and management plane.
          </t>
          <ul spacing="normal">
            <li>
              <t>Provide an interface to operators or customers.</t>
            </li>
            <li>
              <t>Applying intents defined in <xref target="RFC9315"/>, including Operational, Rule, Service, and Flow intents.</t>
            </li>
          </ul>
        </li>
      </ul>
      <t>Each component communicates using standardized protocols.
These are designed to be loosely coupled and cooperate by using an abstraction layer.</t>
      <t>This document suggests handling a control plane by application plane, but a detailed design of an application plane is out of the scope of this document.
This is because application plane components and abstraction layers should be designed based on individual network utilization and operator intent.
In the following sections, details of a forwarding plane, control plane, and management plane are explained.</t>
    </section>
    <section anchor="forwarding-plane">
      <name>Forwarding Plane</name>
      <t>A forwarding plane is responsible for providing SFC through packet classification, SRv6 encapsulation, and forwarding.
In this architecture, all forwarding plane components are located within the SR domain.</t>
      <figure anchor="fp">
        <name>Forwarding Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +----------------------------------------------------------------+
 | +--------------+             +--------+             +--------+ |
 | |  SR Source   | SRv6 Packet |  SRv6  | SRv6 Packet |  SRv6  | |
 | |     Node     |(S2,S1; SL:1)|Service |(S2,S1; SL:1)|Service | |
-->|  / Service   |------------>|Function|------------>|Function|-->
 | |Classification|             |  Node  |             |  Node  | |
 | |   Function   |             |  (S1)  |             |  (S2)  | |
 | +--------------+             +--------+             +--------+ |
 +-------------------------- SR domain ---------------------------+
]]></sourcecode>
      </figure>
      <t>Figure 2 shows an example of SFC with two network functions.
Firstly, the SR source node classifies the flow and encapsulates it with an SRH containing the segment list &lt;S1, S2&gt;.
Next, the SRv6 service function node (S1) receives the packet and applies a network function associated with an End.AN S1.
Finally, the SRv6 service function node (S2) receives the packet and also applies a network function associated End.AN S2, thus achieving SFC.</t>
      <section anchor="endan-based-service-segment-provisioning">
        <name>End.AN-based Service Segment Provisioning</name>
        <t>End.AN provides an SR-aware function.</t>
        <t>Functions with the same role MAY be assigned as the same service segment within the SR domain.
By using Anycast-SIDs, multiple nodes can be grouped as part of the same service segment.</t>
        <t>End.AN MAY have optional arguments.
This can provide additional programmability by embedding network function instructions in the segment list.</t>
        <t>By using virtualized spaces within routers or on generic servers, network functions can be provided at any node in an SR domain.
This allows for scaling and flexible redundancy of network functions.</t>
        <section anchor="when-a-network-function-goes-down">
          <name>When a Network Function Goes Down</name>
          <t>If a network function experiences a failure, the associated route MUST be promptly removed.
In the case of Anycast configuration, it MUST be gracefully rerouted to other nodes.
Additionally, if no alternative nodes are available, consider either dropping the packet and sending an ICMP Destination Unreachable message or forwarding it as a pass-through.</t>
        </section>
        <section anchor="anycast-segment">
          <name>Anycast Segment</name>
          <t>The concept of the Anycast segment is introduced in <xref target="RFC8402"/>.
In the SRv6 SFC, it realizes to provide the same network function segment as the same anycast segment.
In such cases, the state between network functions MUST be shared mutually.</t>
        </section>
        <section anchor="fast-reroute">
          <name>Fast Reroute</name>
          <t>The ordering of network functions in an SRv6 SFC is guaranteed by the segment list, even if an FRR occurs,
When an FRR occurs, if the Active segment is an Anycast SID, it MAY be forwarded to another SRv6 service function node.
In such a case, since state synchronization may not have been completed, the network function MUST have a mechanism to handle rerouted packets, such as buffering to wait for synchronization.</t>
        </section>
      </section>
      <section anchor="service-function-chains">
        <name>Service Function Chains</name>
        <t>In this architecture, each SFC is represented as an SR Policy.
The purpose or intent of each SR Policy can be identified using attributes such as color or name.</t>
        <t>In general, SFC is achieved by using loose source routing.
If both SFC and QoS are desired, they can be achieved by using strict source routing or loose source routing with Flex-Algo SIDs.</t>
      </section>
      <section anchor="per-flow-encapsulation">
        <name>Per-Flow Encapsulation</name>
        <t>In an SR source node, which serves as the Service Classification Function, packets are classified on a per-flow basis using PBR and encapsulated with SR Policy.
Therefore, the SR source node MUST be capable of identifying packets using at least a 5-tuple or even more detailed information.</t>
        <t>In this architecture, aiming for comprehensive management, the Service Classification Function has an API to communicate with the controller.</t>
      </section>
    </section>
    <section anchor="control-plane">
      <name>Control Plane</name>
      <t>A control plane is responsible for enabling comprehensive management of SRv6 SFC.
It enables SR-aware functions as service segments and specifies SR Policies including SFC for each flow.
A control plane has a Northbound API to receive user requests and a Southbound API to manipulate a forwarding plane.</t>
      <figure anchor="cp">
        <name>Control Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +---------------- SRv6 Controller ----------------+
 | +--------------+ +-------------+ +------------+ |
 | |Classification| |    Path     | |  Service   | |
 | |     Rule     | | Computation | |  Function  | |
 | |  Controller  | |Element (PCE)| | Controller | |
 | +------|-------+ +-^---------|-+ +------|-----+ |
 +--------|-----------|---------|----------|-------+
   Classification link-state SR Policy Enable/Disable
        Rule       (BGP-LS) (PCEP/BGP) a Service Segment
   (BGP Flowspec)     |         |     (End.AN SID:S1)
 +--------|-----------|---------|----------|----------------------+
 | +------v-----------|---------v-+ +------v--------------------+ |
 | |       SR Source Node /       | |       SRv6 Service        | |
 | |    Service Classification    |-|         Function          | |
 | |           Function           | |           Node            | |
 | +------------------------------+ +---------------------------+ |
 +--------------------------- SR domain --------------------------+
]]></sourcecode>
      </figure>
      <t>The SRv6 Controller consists of the following three components:</t>
      <ul spacing="normal">
        <li>
          <t>Service Function Controller: provides an SID for a network service and manages this state.</t>
        </li>
        <li>
          <t>PCE: provides SR Policies that fulfill SFC/QoS requirements from the headend to the tailend and sends them to the SR source node.</t>
        </li>
        <li>
          <t>Classification Rule Controller: provides an Encapsulation Policy that corresponds to a specific flow and SR Policy, and sends them to the SR source node.</t>
        </li>
      </ul>
      <section anchor="service-function-controller">
        <name>Service Function Controller</name>
        <t>Service Function Controller is responsible for enabling and disabling service segments of SRv6 service function nodes.
To manage service segments, it utilizes the extensions provided in a BGP-LS service segment, as outlined in <xref target="I-D.draft-ietf-idr-bgp-ls-sr-service-segments"/> and TODO: draft-watal-idr-bgp-ls-sr-service-segments-enabler, and defines the following parameters:</t>
        <ul spacing="normal">
          <li>
            <t>Behavior: End.AN</t>
          </li>
          <li>
            <t>SID: the SID of End.AN (in IPv6 Address format). Service segments that support slicing are specified here as Flex-Algo SIDs.</t>
          </li>
          <li>
            <t>Function Name: type of network function</t>
          </li>
          <li>
            <t>Action: enable</t>
          </li>
          <li>
            <t>TLV:
            </t>
            <ul spacing="normal">
              <li>
                <t>Specification of the Anycast Segment Group: when deploying multiple Network Functions within the same context, it MUST use the Anycast Group TLV to specify the same anycast segment group SID.</t>
              </li>
              <li>
                <t>Allows for the specification of unique parameters and context associated with a particular network function.</t>
              </li>
            </ul>
          </li>
        </ul>
      </section>
      <section anchor="path-computation-element-pce">
        <name>Path Computation Element (PCE)</name>
        <t>PCE is a controller that provides SR Policy.
As an Active Stateful PCE, it establishes sessions with all PEs in an SR domain and manages SFCs.
SR Policies MUST support both explicit and dynamic paths.
For dynamic path, Constrained Shortest Path First (CSPF) considers not only SFC but also QoS.</t>
        <t>It acquires the Traffic Engineering Database (TED) of the SR domain using BGP-LS and deploys SR Policies via PCEP <xref target="RFC5440"/> or BGP SR Policy <xref target="I-D.draft-ietf-idr-segment-routing-te-policy"/>.
The BGP-LS service segment is required to calculate dynamic paths based on the state of service segments and network functions.</t>
      </section>
      <section anchor="classification-rule-controller">
        <name>Classification Rule Controller</name>
        <t>A Classification Rule Controller determines flows to apply specific SFC.</t>
        <t>The classification results are advertised to each SR source node as a set of flow, endpoints, and color with an extended protocol based on BGP Flowspec defined in <xref target="I-D.draft-ietf-idr-ts-flowspec-srv6-policy"/>.</t>
      </section>
    </section>
    <section anchor="management-plane">
      <name>Management Plane</name>
      <t>A management plane is responsible for configuring network function instances, monitoring resources, and collecting network metrics.
The details of each manager are outside the scope of this document, as the southbound interface of the management plane may be different for each service and hardware architecture.</t>
      <figure anchor="mp">
        <name>Management Plane</name>
        <sourcecode type="drawing"><![CDATA[
 +----------------- SRv6 Manager ------------------+
 | +--------------+ +--------------+ +-----------+ |
 | | Virtualized  | |     VNF      | |  Network  | |
 | |Infrastructure| |   Manager    | |  Metric   | |
 | |   Manager    | |              | |  Manager  | |
 | +------^-------+ +------^-------+ +-----^-----+ |
 +--------|----------------|---------------|-------+
          |                |               |
        Management Plane Southbound Interfaces
          |                |               |
 +--------|----------------|---------------|-------+
 | +------|----------------v---------------|-----+ |
 | |                  SR Service                 | |
 | |                   Function                  | |
 | |                     Node                    | |
 | +---------------------------------------------+ |
 +------------------- SR domain -------------------+
]]></sourcecode>
      </figure>
      <t>Figure 4 shows examples of managers that MAY be added to a management plane:</t>
      <ul spacing="normal">
        <li>
          <t>VNF Manager: handles deployment and scaling of network functions.
          </t>
          <ul spacing="normal">
            <li>
              <t>It considers redundancy and link utilization optimization.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>VIM: monitors hypervisor resources on SRv6 service function nodes.
          </t>
          <ul spacing="normal">
            <li>
              <t>In SRv6 SFC, a hypervisor managed by a VIM MAY be located in virtualized spaces within routers or on generic servers.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>Network Metrics Manager: collects metrics for SR Policy calculation and evaluation.
          </t>
          <ul spacing="normal">
            <li>
              <t>Metrics are collected from multiple data sources, including IPFIX, TCP statistics, and SRv6 path tracing <xref target="I-D.draft-filsfils-spring-path-tracing"/>.</t>
            </li>
            <li>
              <t>Metrics can be used for PCE calculation parameters.</t>
            </li>
          </ul>
        </li>
      </ul>
    </section>
  </middle>
  <back>
    <references anchor="sec-normative-references">
      <name>Normative References</name>
      <reference anchor="RFC8986">
        <front>
          <title>Segment Routing over IPv6 (SRv6) Network Programming</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="P. Camarillo" initials="P." role="editor" surname="Camarillo"/>
          <author fullname="J. Leddy" initials="J." surname="Leddy"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
          <author fullname="Z. Li" initials="Z." surname="Li"/>
          <date month="February" year="2021"/>
          <abstract>
            <t>The Segment Routing over IPv6 (SRv6) Network Programming framework enables a network operator or an application to specify a packet processing program by encoding a sequence of instructions in the IPv6 packet header.</t>
            <t>Each instruction is implemented on one or several nodes in the network and identified by an SRv6 Segment Identifier in the packet.</t>
            <t>This document defines the SRv6 Network Programming concept and specifies the base set of SRv6 behaviors that enables the creation of interoperable overlays with underlay optimization.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8986"/>
        <seriesInfo name="DOI" value="10.17487/RFC8986"/>
      </reference>
      <reference anchor="RFC7665">
        <front>
          <title>Service Function Chaining (SFC) Architecture</title>
          <author fullname="J. Halpern" initials="J." role="editor" surname="Halpern"/>
          <author fullname="C. Pignataro" initials="C." role="editor" surname="Pignataro"/>
          <date month="October" year="2015"/>
          <abstract>
            <t>This document describes an architecture for the specification, creation, and ongoing maintenance of Service Function Chains (SFCs) in a network. It includes architectural concepts, principles, and components used in the construction of composite services through deployment of SFCs, with a focus on those to be standardized in the IETF. This document does not propose solutions, protocols, or extensions to existing protocols.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7665"/>
        <seriesInfo name="DOI" value="10.17487/RFC7665"/>
      </reference>
      <reference anchor="I-D.draft-ietf-spring-sr-service-programming">
        <front>
          <title>Service Programming with Segment Routing</title>
          <author fullname="Francois Clad" initials="F." surname="Clad">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Xiaohu Xu" initials="X." surname="Xu">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Daniel Bernier" initials="D." surname="Bernier">
            <organization>Bell Canada</organization>
          </author>
          <author fullname="Cheng Li" initials="C." surname="Li">
            <organization>Huawei</organization>
          </author>
          <author fullname="Bruno Decraene" initials="B." surname="Decraene">
            <organization>Orange</organization>
          </author>
          <author fullname="Shaowen Ma" initials="S." surname="Ma">
            <organization>Mellanox</organization>
          </author>
          <author fullname="Chaitanya Yadlapalli" initials="C." surname="Yadlapalli">
            <organization>AT&amp;T</organization>
          </author>
          <author fullname="Wim Henderickx" initials="W." surname="Henderickx">
            <organization>Nokia</organization>
          </author>
          <author fullname="Stefano Salsano" initials="S." surname="Salsano">
            <organization>Universita di Roma "Tor Vergata"</organization>
          </author>
          <date day="23" month="August" year="2024"/>
          <abstract>
            <t>   This document defines data plane functionality required to implement
   service segments and achieve service programming in SR-enabled MPLS
   and IPv6 networks, as described in the Segment Routing architecture.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-spring-sr-service-programming-10"/>
      </reference>
      <reference anchor="RFC8402">
        <front>
          <title>Segment Routing Architecture</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="S. Previdi" initials="S." role="editor" surname="Previdi"/>
          <author fullname="L. Ginsberg" initials="L." surname="Ginsberg"/>
          <author fullname="B. Decraene" initials="B." surname="Decraene"/>
          <author fullname="S. Litkowski" initials="S." surname="Litkowski"/>
          <author fullname="R. Shakir" initials="R." surname="Shakir"/>
          <date month="July" year="2018"/>
          <abstract>
            <t>Segment Routing (SR) leverages the source routing paradigm. A node steers a packet through an ordered list of instructions, called "segments". A segment can represent any instruction, topological or service based. A segment can have a semantic local to an SR node or global within an SR domain. SR provides a mechanism that allows a flow to be restricted to a specific topological path, while maintaining per-flow state only at the ingress node(s) to the SR domain.</t>
            <t>SR can be directly applied to the MPLS architecture with no change to the forwarding plane. A segment is encoded as an MPLS label. An ordered list of segments is encoded as a stack of labels. The segment to process is on the top of the stack. Upon completion of a segment, the related label is popped from the stack.</t>
            <t>SR can be applied to the IPv6 architecture, with a new type of routing header. A segment is encoded as an IPv6 address. An ordered list of segments is encoded as an ordered list of IPv6 addresses in the routing header. The active segment is indicated by the Destination Address (DA) of the packet. The next active segment is indicated by a pointer in the new routing header.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8402"/>
        <seriesInfo name="DOI" value="10.17487/RFC8402"/>
      </reference>
      <reference anchor="RFC8754">
        <front>
          <title>IPv6 Segment Routing Header (SRH)</title>
          <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
          <author fullname="D. Dukes" initials="D." role="editor" surname="Dukes"/>
          <author fullname="S. Previdi" initials="S." surname="Previdi"/>
          <author fullname="J. Leddy" initials="J." surname="Leddy"/>
          <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <date month="March" year="2020"/>
          <abstract>
            <t>Segment Routing can be applied to the IPv6 data plane using a new type of Routing Extension Header called the Segment Routing Header (SRH). This document describes the SRH and how it is used by nodes that are Segment Routing (SR) capable.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8754"/>
        <seriesInfo name="DOI" value="10.17487/RFC8754"/>
      </reference>
      <reference anchor="RFC9256">
        <front>
          <title>Segment Routing Policy Architecture</title>
          <author fullname="C. Filsfils" initials="C." surname="Filsfils"/>
          <author fullname="K. Talaulikar" initials="K." role="editor" surname="Talaulikar"/>
          <author fullname="D. Voyer" initials="D." surname="Voyer"/>
          <author fullname="A. Bogdanov" initials="A." surname="Bogdanov"/>
          <author fullname="P. Mattes" initials="P." surname="Mattes"/>
          <date month="July" year="2022"/>
          <abstract>
            <t>Segment Routing (SR) allows a node to steer a packet flow along any path. Intermediate per-path states are eliminated thanks to source routing. SR Policy is an ordered list of segments (i.e., instructions) that represent a source-routed policy. Packet flows are steered into an SR Policy on a node where it is instantiated called a headend node. The packets steered into an SR Policy carry an ordered list of segments associated with that SR Policy.</t>
            <t>This document updates RFC 8402 as it details the concepts of SR Policy and steering into an SR Policy.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9256"/>
        <seriesInfo name="DOI" value="10.17487/RFC9256"/>
      </reference>
      <reference anchor="RFC9522">
        <front>
          <title>Overview and Principles of Internet Traffic Engineering</title>
          <author fullname="A. Farrel" initials="A." role="editor" surname="Farrel"/>
          <date month="January" year="2024"/>
          <abstract>
            <t>This document describes the principles of traffic engineering (TE) in the Internet. The document is intended to promote better understanding of the issues surrounding traffic engineering in IP networks and the networks that support IP networking and to provide a common basis for the development of traffic-engineering capabilities for the Internet. The principles, architectures, and methodologies for performance evaluation and performance optimization of operational networks are also discussed.</t>
            <t>This work was first published as RFC 3272 in May 2002. This document obsoletes RFC 3272 by making a complete update to bring the text in line with best current practices for Internet traffic engineering and to include references to the latest relevant work in the IETF.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9522"/>
        <seriesInfo name="DOI" value="10.17487/RFC9522"/>
      </reference>
      <reference anchor="RFC7426">
        <front>
          <title>Software-Defined Networking (SDN): Layers and Architecture Terminology</title>
          <author fullname="E. Haleplidis" initials="E." role="editor" surname="Haleplidis"/>
          <author fullname="K. Pentikousis" initials="K." role="editor" surname="Pentikousis"/>
          <author fullname="S. Denazis" initials="S." surname="Denazis"/>
          <author fullname="J. Hadi Salim" initials="J." surname="Hadi Salim"/>
          <author fullname="D. Meyer" initials="D." surname="Meyer"/>
          <author fullname="O. Koufopavlou" initials="O." surname="Koufopavlou"/>
          <date month="January" year="2015"/>
          <abstract>
            <t>Software-Defined Networking (SDN) refers to a new approach for network programmability, that is, the capacity to initialize, control, change, and manage network behavior dynamically via open interfaces. SDN emphasizes the role of software in running networks through the introduction of an abstraction for the data forwarding plane and, by doing so, separates it from the control plane. This separation allows faster innovation cycles at both planes as experience has already shown. However, there is increasing confusion as to what exactly SDN is, what the layer structure is in an SDN architecture, and how layers interface with each other. This document, a product of the IRTF Software-Defined Networking Research Group (SDNRG), addresses these questions and provides a concise reference for the SDN research community based on relevant peer-reviewed literature, the RFC series, and relevant documents by other standards organizations.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="7426"/>
        <seriesInfo name="DOI" value="10.17487/RFC7426"/>
      </reference>
      <reference anchor="RFC5440">
        <front>
          <title>Path Computation Element (PCE) Communication Protocol (PCEP)</title>
          <author fullname="JP. Vasseur" initials="JP." role="editor" surname="Vasseur"/>
          <author fullname="JL. Le Roux" initials="JL." role="editor" surname="Le Roux"/>
          <date month="March" year="2009"/>
          <abstract>
            <t>This document specifies the Path Computation Element (PCE) Communication Protocol (PCEP) for communications between a Path Computation Client (PCC) and a PCE, or between two PCEs. Such interactions include path computation requests and path computation replies as well as notifications of specific states related to the use of a PCE in the context of Multiprotocol Label Switching (MPLS) and Generalized MPLS (GMPLS) Traffic Engineering. PCEP is designed to be flexible and extensible so as to easily allow for the addition of further messages and objects, should further requirements be expressed in the future. [STANDARDS-TRACK]</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="5440"/>
        <seriesInfo name="DOI" value="10.17487/RFC5440"/>
      </reference>
      <reference anchor="RFC8955">
        <front>
          <title>Dissemination of Flow Specification Rules</title>
          <author fullname="C. Loibl" initials="C." surname="Loibl"/>
          <author fullname="S. Hares" initials="S." surname="Hares"/>
          <author fullname="R. Raszuk" initials="R." surname="Raszuk"/>
          <author fullname="D. McPherson" initials="D." surname="McPherson"/>
          <author fullname="M. Bacher" initials="M." surname="Bacher"/>
          <date month="December" year="2020"/>
          <abstract>
            <t>This document defines a Border Gateway Protocol Network Layer Reachability Information (BGP NLRI) encoding format that can be used to distribute (intra-domain and inter-domain) traffic Flow Specifications for IPv4 unicast and IPv4 BGP/MPLS VPN services. This allows the routing system to propagate information regarding more specific components of the traffic aggregate defined by an IP destination prefix.</t>
            <t>It also specifies BGP Extended Community encoding formats, which can be used to propagate Traffic Filtering Actions along with the Flow Specification NLRI. Those Traffic Filtering Actions encode actions a routing system can take if the packet matches the Flow Specification.</t>
            <t>This document obsoletes both RFC 5575 and RFC 7674.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="8955"/>
        <seriesInfo name="DOI" value="10.17487/RFC8955"/>
      </reference>
      <reference anchor="RFC2119">
        <front>
          <title>Key words for use in RFCs to Indicate Requirement Levels</title>
          <author fullname="S. Bradner" initials="S." surname="Bradner"/>
          <date month="March" year="1997"/>
          <abstract>
            <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="2119"/>
        <seriesInfo name="DOI" value="10.17487/RFC2119"/>
      </reference>
      <reference anchor="RFC8174">
        <front>
          <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
          <author fullname="B. Leiba" initials="B." surname="Leiba"/>
          <date month="May" year="2017"/>
          <abstract>
            <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
          </abstract>
        </front>
        <seriesInfo name="BCP" value="14"/>
        <seriesInfo name="RFC" value="8174"/>
        <seriesInfo name="DOI" value="10.17487/RFC8174"/>
      </reference>
      <reference anchor="RFC9315">
        <front>
          <title>Intent-Based Networking - Concepts and Definitions</title>
          <author fullname="A. Clemm" initials="A." surname="Clemm"/>
          <author fullname="L. Ciavaglia" initials="L." surname="Ciavaglia"/>
          <author fullname="L. Z. Granville" initials="L. Z." surname="Granville"/>
          <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
          <date month="October" year="2022"/>
          <abstract>
            <t>Intent and Intent-Based Networking are taking the industry by storm. At the same time, terms related to Intent-Based Networking are often used loosely and inconsistently, in many cases overlapping and confused with other concepts such as "policy." This document clarifies the concept of "intent" and provides an overview of the functionality that is associated with it. The goal is to contribute towards a common and shared understanding of terms, concepts, and functionality that can be used as the foundation to guide further definition of associated research and engineering problems and their solutions.</t>
            <t>This document is a product of the IRTF Network Management Research Group (NMRG). It reflects the consensus of the research group, having received many detailed and positive reviews by research group participants. It is published for informational purposes.</t>
          </abstract>
        </front>
        <seriesInfo name="RFC" value="9315"/>
        <seriesInfo name="DOI" value="10.17487/RFC9315"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-bgp-ls-sr-service-segments">
        <front>
          <title>BGP-LS Advertisement of Segment Routing Service Segments</title>
          <author fullname="Gaurav Dawra" initials="G." surname="Dawra">
            <organization>LinkedIn</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Ketan Talaulikar" initials="K." surname="Talaulikar">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Francois Clad" initials="F." surname="Clad">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Daniel Bernier" initials="D." surname="Bernier">
            <organization>Bell Canada</organization>
          </author>
          <author fullname="Jim Uttaro" initials="J." surname="Uttaro">
            <organization>AT&amp;T</organization>
          </author>
          <author fullname="Bruno Decraene" initials="B." surname="Decraene">
            <organization>Orange</organization>
          </author>
          <author fullname="Hani Elmalky" initials="H." surname="Elmalky">
            <organization>Ericsson</organization>
          </author>
          <author fullname="Xiaohu Xu" initials="X." surname="Xu">
            <organization>Capitalonline</organization>
          </author>
          <author fullname="Jim Guichard" initials="J." surname="Guichard">
            <organization>Futurewei Technologies</organization>
          </author>
          <author fullname="Cheng Li" initials="C." surname="Li">
            <organization>Huawei Technologies</organization>
          </author>
          <date day="5" month="November" year="2022"/>
          <abstract>
            <t>   Service functions are deployed as, physical or virtualized elements
   along with network nodes or on servers in data centers.  Segment
   Routing (SR) brings in the concept of segments which can be
   topological or service instructions.  Service segments are SR
   segments that are associated with service functions.  SR Policies are
   used for the setup of paths for steering of traffic through service
   functions using their service segments.

   BGP Link-State (BGP-LS) enables distribution of topology information
   from the network to a controller or an application in general so it
   can learn the network topology.  This document specifies the
   extensions to BGP-LS for the advertisement of service functions along
   their associated service segments.  The BGP-LS advertisement of
   service function information along with the network nodes that they
   are attached to, or associated with, enables controllers compute and
   setup service paths in the network.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-bgp-ls-sr-service-segments-02"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-segment-routing-te-policy">
        <front>
          <title>Advertising Segment Routing Policies in BGP</title>
          <author fullname="Stefano Previdi" initials="S." surname="Previdi">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Ketan Talaulikar" initials="K." surname="Talaulikar">
            <organization>Cisco Systems</organization>
          </author>
          <author fullname="Paul Mattes" initials="P." surname="Mattes">
            <organization>Microsoft</organization>
          </author>
          <author fullname="Dhanendra Jain" initials="D." surname="Jain">
            <organization>Google</organization>
          </author>
          <date day="23" month="October" year="2023"/>
          <abstract>
            <t>   This document introduces a BGP SAFI with two NLRIs to advertise a
   candidate path of a Segment Routing (SR) Policy.  An SR Policy is an
   ordered list of segments (i.e., instructions) that represent a
   source-routed policy.  An SR Policy consists of one or more candidate
   paths, each consisting of one or more segment lists.  A headend may
   be provisioned with candidate paths for an SR Policy via several
   different mechanisms, e.g., CLI, NETCONF, PCEP, or BGP.  This
   document specifies how BGP may be used to distribute SR Policy
   candidate paths.  It defines sub-TLVs for the Tunnel Encapsulation
   Attribute for signaling information about these candidate paths.

   This documents updates RFC9012 with extensions to the Color Extended
   Community to support additional steering modes over SR Policy.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-segment-routing-te-policy-26"/>
      </reference>
      <reference anchor="I-D.draft-ietf-idr-ts-flowspec-srv6-policy">
        <front>
          <title>Traffic Steering using BGP FlowSpec with SR Policy</title>
          <author fullname="Jiang Wenying" initials="J." surname="Wenying">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Yisong Liu" initials="Y." surname="Liu">
            <organization>China Mobile</organization>
          </author>
          <author fullname="Shunwan Zhuang" initials="S." surname="Zhuang">
            <organization>Huawei Technologies</organization>
          </author>
          <author fullname="Gyan Mishra" initials="G. S." surname="Mishra">
            <organization>Verizon Communications Inc.</organization>
          </author>
          <author fullname="Shuanglong Chen" initials="S." surname="Chen">
            <organization>Huawei Technologies</organization>
          </author>
          <date day="15" month="August" year="2024"/>
          <abstract>
            <t>   BGP Flow Specification (FlowSpec) [RFC8955] and [RFC8956] has been
   proposed to distribute BGP [RFC4271] FlowSpec NLRI to FlowSpec
   clients to mitigate (distributed) denial-of-service attacks, and to
   provide traffic filtering in the context of a BGP/MPLS VPN service.
   Recently, traffic steering applications in the context of SR-MPLS and
   SRv6 using FlowSpec also attract attention.  This document introduces
   the usage of BGP FlowSpec to steer packets into an SR Policy.


            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-ietf-idr-ts-flowspec-srv6-policy-04"/>
      </reference>
      <reference anchor="I-D.draft-filsfils-spring-path-tracing">
        <front>
          <title>Path Tracing in SRv6 networks</title>
          <author fullname="Clarence Filsfils" initials="C." surname="Filsfils">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Ahmed Abdelsalam" initials="A." surname="Abdelsalam">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Pablo Camarillo" initials="P." surname="Camarillo">
            <organization>Cisco Systems, Inc.</organization>
          </author>
          <author fullname="Mark Yufit" initials="M." surname="Yufit">
            <organization>Broadcom</organization>
          </author>
          <author fullname="Thomas Graf" initials="T." surname="Graf">
            <organization>Swisscom</organization>
          </author>
          <author fullname="Yuanchao Su" initials="Y." surname="Su">
            <organization>Alibaba, Inc</organization>
          </author>
          <author fullname="Satoru Matsushima" initials="S." surname="Matsushima">
            <organization>SoftBank</organization>
          </author>
          <author fullname="Mike Valentine" initials="M." surname="Valentine">
            <organization>Goldman Sachs</organization>
          </author>
          <author fullname="Amit Dhamija" initials="" surname="Dhamija">
            <organization>Arrcus</organization>
          </author>
          <date day="23" month="October" year="2023"/>
          <abstract>
            <t>   Path Tracing provides a record of the packet path as a sequence of
   interface ids.  In addition, it provides a record of end-to-end
   delay, per-hop delay, and load on each egress interface along the
   packet delivery path.

   Path Tracing allows to trace 14 hops with only a 40-bytes IPv6 Hop-
   by-Hop extension header.

   Path Tracing supports fine grained timestamp.  It has been designed
   for linerate hardware implementation in the base pipeline.

            </t>
          </abstract>
        </front>
        <seriesInfo name="Internet-Draft" value="draft-filsfils-spring-path-tracing-05"/>
      </reference>
    </references>
    <?line 333?>

<section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors would like to acknowledge the review and inputs from Mitsuru Maruyama, Katsuhiro Sebayashi, Yuma Ito, and Taisei Tanabe.
We partially obtained the research results from NICT's commissioned research No. JPJ012368C03101.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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
rcsSI2TCkKIBveTkkF1QpwvIBQ13KFG2TTctSQVZa6EqY6ldMG4884EHmlX2
zbG5davCQ5Lyd0ra+iSAWknm5S+G1gYU1fiR4PitSnmYMOVBfrK4vMExdYuP
Q6+3d6oXyCkHQidJiScpOK2ZBS90sduff/6JFTCMvXvixeCJfy964k7U/9qp
j8bf3T373G3fZ+vfXSMx05Vj4S2bUbDApW/uO1oD0BeNgfr3F40XaIW7ehh8
x/iiFA0Df+dDav4Gz/3AXU/YFzh8dm+EyR387qNetwIM2O92heDQOFDLCCGQ
1WO7ggvLeYUXdfLguX8NiObwcNfAw53Dw4tq7mDQ/tz+9EKIILfWC6nd9bnr
E+EZOaJ6u84oXWk3U71bPf7C7Rvc96Tzt/ARUOGm4zmOOio0OfrGUaXiJtHI
fIt9D381IcipVU/9GlvS0zhrUGGh4syuNbZOakwgEOtPO6Sz+deU1ubT+xTR
gLSF8/rvWQUVaO+PI/GVV7TUuvDXZ6GmfloXw+deRxE4dNLQGtcCLqPW0rrA
XCNuxB+cv67Hv5y/Dqz1Oshfk0EMFPna57BtMZQHlrJZlIb1bXbltAHEkYgs
p/iqLBteiJDl2qA3SznY9z6yprVXATBbS6xonsVzLJ5syeTaKICqGRd2tmXc
DeVj/SYb2hT9kOuTGgqIWpO3V/btE4hPIFoJPEieYV292qyWW8lTT9ElvFIQ
LBRIoqurXcoth1TCpOhHhQmtiHItgLEZhp+2qh0QGuH3fkleJjY0bAej7vSc
pTFh5iZwRhDNCHWB1Zo1Ve0g4rHoZpKAVy83bjWb2bHhXJgbCqNVO3voiVnF
sYBwynYRMcCPqi1Bg1Fd0dAZ7YJsKZgXay8GTlQ9Wd7uu3ge1nIc8jmw40Oh
JgCfDd1e44U6VhxuhIVcC1P4bqzWSbYx7UC8cYDlZo2LmCyvisRNgtl0IoJg
d+93BfiUegOVU5WXn9d8M3tEzzPDydjYArrNf3AWwmkNRkEdQ3W5Q3fTu8y4
QOaTGrCsS2OGTLDh5FlBdGkX5L4+eI19AhVbXlaheZ88on5VvET4qCZl1wPf
ljQVhhFZiiBHvpFIGasQuuMBbMLBsBk5xKeSOVOeZJlRCbr55Zo6RSj+4YMq
5NvSxflh9gkEhTJp9fYDUy6A5nByn0yWDR0927S1MCYeMI7gjJOKLYSUeUo7
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

-->

</rfc>
