TOC |
|
This document defines how PANA client (PaC) can perform PANA authentication prior to configuring an IP address.
This Internet-Draft is submitted to IETF 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 http://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 March 31, 2011.
Copyright (c) 2010 IETF Trust and the persons identified as the document authors. All rights reserved.
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (http://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 Simplified BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Simplified BSD License.
1.
Introduction
1.1.
Specification of Requirements
2.
Details
3.
PaC Behavior
4.
PAA Behavior
5.
AVP Definition
5.1.
Token AVP
6.
Message Size Considerations
7.
Security Considerations
8.
IANA Considerations
9.
Acknowledgments
10.
References
10.1.
Normative References
10.2.
Informative References
§
Authors' Addresses
TOC |
PANA (Protocol for carrying Authentication for Network Access) [RFC5191] (Forsberg, D., Ohba, Y., Patil, B., Tschofenig, H., and A. Yegin, “Protocol for Carrying Authentication for Network Access (PANA),” May 2008.) as a UDP-based protocol operates with the assumption that the PANA client (PaC) is already configured with an IP address. Private IPv4, globally-routable IPv4 [RFC1918] (Rekhter, Y., Moskowitz, R., Karrenberg, D., Groot, G., and E. Lear, “Address Allocation for Private Internets,” February 1996.) or IPv6, IPv4 or IPv6 link-local are the types of addresses that can be configured by PaCs prior to running PANA [RFC5193] (Jayaraman, P., Lopez, R., Ohba, Y., Parthasarathy, M., and A. Yegin, “Protocol for Carrying Authentication for Network Access (PANA) Framework,” May 2008.).
In case the PaC and the PANA Authentication Agent (PAA) are on the same IP subnet where all hosts in the subnet can be reached in one routing hop, the PaC can run PANA with the PAA prior to configuring an IP address.
This document defines an extension of PANA to allow the PaC to use IPv4 unspecified address (0.0.0.0) until it gets authenticated/authorized; and configures an IP address afterwards (possibly using DHCP). Such a feature is already available in Mobile IPv4 [RFC3344] (Perkins, C., “IP Mobility Support for IPv4,” August 2002.) where MN can use unspecified IPv4 address with Mobile IP protocol until it is assigned a home address, and also DHCP [RFC2131] (Droms, R., “Dynamic Host Configuration Protocol,” March 1997.).
This extension is defined only as a solution for use cases in which PANA authentication is required prior to any kind of IP address allocation or configuration. It is not intended to become the default mode of operation for PANA.
TOC |
In this document, several words are used to signify the requirements of the specification. These words are often capitalized. 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] (Bradner, S., “Key words for use in RFCs to Indicate Requirement Levels,” March 1997.).
TOC |
Figure 1 (Example Call Flow for PANA with IPv4 Unspecified Address) is an example call flow that illustrates use of unspecified IPv4 address with the PaC during PANA authentication. Note that there can be other ways for combining DHCP and PANA call flows.
PaC PAA AAA | | | | | | | | | |--1. PANA Client initiation(Token)->| | | | | |<-2. PANA Auth Req(Token)-----------| | | | | |--3. PANA Auth Ans ---------------->| | | | | | |-4. RADIUS Access ->| | | Request (EAP) | | | | | |<-5. RADIUS Access--| | | (EAP Success) | |<-6. PANA Auth Req -----------------| | | | | |--7. PANA Auth Ans ---------------->| | | | | |--8. DHCP Discover----------------->| | | | | |<-9. DHCP Offer---------------------| | | | | |--10. DHCP Request----------------->| | | | | |<-11. DHCP Ack----------------------| | | | | |<-12. IP session data traffic----------------> | | | |
Figure 1: Example Call Flow for PANA with IPv4 Unspecified Address |
Step 1: The PaC initiates PANA by sending a broadcasted PCI carrying a Token AVP that contains a random value generated by the PaC.
The source IPv4 address of the PCI is set to 0.0.0.0. The destination IPv4 address is set to 255.255.255.255.
Step 2: The PAA responds with a PAR message that includes the token generated by the PaC. The PAR message has its source IPv4 address set to the PAA's IP address, and the destination IPv4 address is set to 255.255.255.255. If the PAA is capable of retrieving the PaC's L2 address from incoming PCI, then the PAR is L2-unicast using that L2 address. Otherwise, the PAR message will be L2-broadcast.
The PaC discovers the PAA's IPv4 address when it receives the PAR message.
Step 3: The PaC sends the PAN message to the PAA's newly discovered IPv4 address.
Steps 4-7: PANA and RADIUS carrying out the selected EAP method.
Steps 8-11: Now that the PaC is authenticated, it proceeds to configuring service IP address using DHCPv4. As soon as the new IPv4 address is confirmed by the DHCPACK, the PaC can stop using the unspecified address.
Step 12: The PaC can transmit and receive IP data packets using its IP address.
A PAA implementation may not be capable of retrieving the PaC's L2 address from L2 header of the incoming PANA messages, or be able to send a L2-unicast even if it could retrieve the address. In such a case, the PAA sends PANA messages as L2-broadcast. In order to prevent other PaCs from processing the messages destined for a specific PaC, each PaC is required to supply a randomly generated token as a payload AVP to PCI and expect it to be echoed back by the PAA in the initial PAR. Token AVP is defined for this purpose.
Note that any message beyond Step 2 would include the PAA-assigned and PaC-acknowledged PANA Session Id, hence use of Token AVP is not needed for those messages.
TOC |
A PaC SHALL use unspecified address as its source IP address until it configures another IP address. The PaC SHALL send a PCI carrying a Token AVP. The PaC SHOULD NOT include a Token AVP in any other message.
The PaC SHALL silently drop any PAR that carries a Token AVP whose token value does not match the one contained in the PCI sent by the PaC.
The PaC, before it sends the first PAN to the PAA, SHALL silently drop any PAR that is L2-broadcast and without carrying a Token AVP.
Any legacy PaC that does not implement this specification will automatically drop the incoming PAR that carries the Token AVP as this is an unrecognized AVP. This is the standard behavior defined in [RFC5191] (Forsberg, D., Ohba, Y., Patil, B., Tschofenig, H., and A. Yegin, “Protocol for Carrying Authentication for Network Access (PANA),” May 2008.).
TOC |
If a PAA receives a PCI whose source IP address is unspecified but that does not carry a Token AVP, then it SHALL drop the PCI. The PAA SHALL ignore a Token AVP if it is contained in any message other than PCI.
When the PAA needs to send a packet to a PaC that is using an unspecified IP address, then the PAA shall set the destination IP address to 255.255.255.255. The PAA SHOULD set the destination L2 address to the source L2 address retrieved from the incoming PaC packet, when possible; otherwise set to L2 broadcast address. If this is the very first PAR message sent to L2 broadcast address in response to a PCI message containing a Token AVP, then the PAA SHALL include a Token AVP copied from the PCI. The PAA SHOULD NOT include a Token AVP in any other PANA message, as an already-assigned PANA Session Id serves the need.
The PAA SHALL set the 'I' (IP Reconfiguration) bit of PAR messages in authentication and authorization phase so that the PaC proceeds to IP address configuration.
Any legacy PAA that does not implement this specification would automatically drop the incoming PCI that carries the Token AVP as this is an unrecognized AVP. This is the standard behavior defined in [RFC5191] (Forsberg, D., Ohba, Y., Patil, B., Tschofenig, H., and A. Yegin, “Protocol for Carrying Authentication for Network Access (PANA),” May 2008.).
TOC |
This document defines one new AVP as described below.
TOC |
The Token AVP (AVP Code TBD) is of type Unsigned64 containing a random value generated by the PaC.
TOC |
Since IP fragmentation for IP packets using unspecified address is prohibited, link-layer MTU needs to be no less than the IP packet size carrying the largest PANA message in the case where EAP message size is the same as the minimum EAP MTU size (i.e., 1020 octets [RFC3748] (Aboba, B., Blunk, L., Vollbrecht, J., Carlson, J., and H. Levkowetz, “Extensible Authentication Protocol (EAP),” June 2004.)). Such a PANA message is the very first PANA-Auth-Request message in Authentication and Authorization phase carrying the following AVPs.
In this case, the PANA message size including PANA header (16 octets), UDP header (8 octets) and IPv4 header (20 octets) is 1028 + 264 + 12 + 12 + 16 + 16 + 8 + 20 = 1376 octets. Therefore, the link-layer MTU size for IP packets MUST be no less than 1376 octets when unspecified IPv4 address is used for PANA. Note that Ethernet (MTU = 1500 octets) meets this requirement.
PANA as an EAP lower-layer reports the EAP MTU to the EAP layer, so that EAP methods can perform appropriate fragmentation [RFC3748] (Aboba, B., Blunk, L., Vollbrecht, J., Carlson, J., and H. Levkowetz, “Extensible Authentication Protocol (EAP),” June 2004.). The EAP MTU is calculated as follows:
EAP_MTU = L2_MTU - 356
In the above formula, the value of 356 is the PANA overhead (IP, UDP and PANA headers, and PANA AVPs except for the EAP-Payload AVP payload).
TOC |
When the PAA is not capable of L2-unicasting PANA messages to the target PaC, other nodes on the same subnet can receive those messages. This may pose a risk if there is any confidential data exposed in the messages. Typically no such exposure exists as PANA, EAP, an EAP methods are defined in a way they can also be used in wireless networks where snooping is always a possibility.
TOC |
As described in Section 5.1 (Token AVP) and following the new IANA allocation policy on PANA message [RFC5872] (Arkko, J. and A. Yegin, “IANA Rules for the Protocol for Carrying Authentication for Network Access (PANA),” May 2010.), a new AVP Code for Token AVP needs to be assigned by IANA.
TOC |
TBD.
TOC |
TOC |
[RFC5191] | Forsberg, D., Ohba, Y., Patil, B., Tschofenig, H., and A. Yegin, “Protocol for Carrying Authentication for Network Access (PANA),” RFC 5191, May 2008 (TXT). |
[RFC5193] | Jayaraman, P., Lopez, R., Ohba, Y., Parthasarathy, M., and A. Yegin, “Protocol for Carrying Authentication for Network Access (PANA) Framework,” RFC 5193, May 2008 (TXT). |
[RFC3748] | Aboba, B., Blunk, L., Vollbrecht, J., Carlson, J., and H. Levkowetz, “Extensible Authentication Protocol (EAP),” RFC 3748, June 2004 (TXT). |
[RFC5872] | Arkko, J. and A. Yegin, “IANA Rules for the Protocol for Carrying Authentication for Network Access (PANA),” RFC 5872, May 2010 (TXT). |
TOC |
[RFC1918] | Rekhter, Y., Moskowitz, R., Karrenberg, D., Groot, G., and E. Lear, “Address Allocation for Private Internets,” BCP 5, RFC 1918, February 1996 (TXT). |
[RFC2119] | Bradner, S., “Key words for use in RFCs to Indicate Requirement Levels,” BCP 14, RFC 2119, March 1997 (TXT, HTML, XML). |
[RFC2131] | Droms, R., “Dynamic Host Configuration Protocol,” RFC 2131, March 1997 (TXT, HTML, XML). |
[RFC2464] | Crawford, M., “Transmission of IPv6 Packets over Ethernet Networks,” RFC 2464, December 1998 (TXT, HTML, XML). |
[RFC3344] | Perkins, C., “IP Mobility Support for IPv4,” RFC 3344, August 2002 (TXT). |
TOC |
Alper Yegin | |
Samsung | |
Istanbul | |
Turkey | |
Email: | alper.yegin@yegin.org |
Yoshihiro Ohba | |
Toshiba Corporate Research and Development Center | |
1 Komukai-Toshiba-cho | |
Saiwai-ku, Kawasaki, Kanagawa 212-8582 | |
Japan | |
Phone: | +81 44 549 2230 |
Email: | yoshihiro.ohba@toshiba.co.jp |
Lionel Morand | |
Orange Labs | |
Phone: | +33 1 4529 62 57 |
Email: | Lionel.morand@orange-ftgroup.com |
John Kaippallimalil | |
Huawei USA | |
1700 Alma Dr., Suite 500 | |
Plano, TX 75082 | |
USA | |
Phone: | +1 214 606 2005 |
Email: | jkaippal@huawei.com |