From b31cb56a81bd49b793f255e1d919507c2aac8c2c Mon Sep 17 00:00:00 2001 From: Peter Saint-Andre Date: Wed, 30 Jan 2008 21:25:52 +0000 Subject: [PATCH] initial published version git-svn-id: file:///home/ksmith/gitmigration/svn/xmpp/trunk@1625 4b5297f7-1745-476d-ba37-a9c6900126ab --- xep-0233.xml | 109 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 109 insertions(+) create mode 100644 xep-0233.xml diff --git a/xep-0233.xml b/xep-0233.xml new file mode 100644 index 00000000..5ccb93bd --- /dev/null +++ b/xep-0233.xml @@ -0,0 +1,109 @@ + + +%ents; +]> + + +
+ Use of Domain-Based Service Names in XMPP SASL Negotiation + This specification defines a method by which a connection manager associated with an XMPP server can inform a connecting client about its domain-based service name. + &LEGALNOTICE; + 0233 + Experimental + Standards Track + Standards + Council + + XMPP Core + draft-ietf-kitten-gssapi-domain-based-names + draft-ietf-kitten-krb5-gssapi-domain-based-names + + + + NOT YET ASSIGNED + &linuxwolf; + &stpeter; + &hildjj; + + 0.1 + 2008-01-30 + psa +

Initial published version.

+
+ + 0.0.2 + 2007-12-11 + mm/psa +

Corrected syntax.

+
+ + 0.0.1 + 2007-12-05 + mm/psa +

First draft.

+
+
+ + +

In certain kinds of XMPP deployments, multiple connection managers associated with the XMPP server may be used to handle requests from connecting clients. When such an architecture is used in environments that make use of Kerberos V and negotiation of Simple Authentication and Security Layer (SASL) over XMPP, the connection manager may need to give the client additional information about its principal so that the client can obtain a proper ticket for authentication.

+

This scenario was not addressed in &rfc3920;. However, the problem can now be solved using the concept of domain-based service names as described in &kittenspn;. In particular, because XMPP servers typically use the Kerberos V5 ("GSSAPI") SASL mechanism as described in &rfc4752;, they can communicate domain-based names as Kerberos V service principal names as described in &kittenspnkrb5;.

+

Therefore this document defines a method for communication of Kerberos V domain-based service names in the context of SASL negotiation by XMPP entities.

+
+ + +

When a connection manager associated with an XMPP server needs to communicate additional information about its service principal name to a connecting client, it can do so by including a child element of the <mechanisms/> element during SASL negotation, as specified in &rfc3920bis;. In the case of the Kerberos V SASL mechanism, the child element is a <hostname/> element qualified by the 'urn:xmpp:tmp:domain-based-name' namespace &NSNOTE;. The <hostname/> element MUST include a 'mechanism' attribute, where the value MUST be "GSSAPI". The XML character data of the <hostname/> element shall specify the fully-qualified name of the connection manager (known as the hostname). The client then generates a domain-based service name from the provided hostname, following the format specified in draft-ietf-kitten-krb5-gssapi-domain-based-names (i.e., "protocol/hostname/domainname@REALM"):

+
    +
  • The protocol string MUST be "xmpp"
  • +
  • The hostname string MUST be the XML character data of the <hostname/> element
  • +
  • The domainname string MUST be the canonical name of the service
  • +
  • The REALM string SHOULD be determined according to the network policies in effect (usually the domain name, in an uppercase mapping)
  • +
+

Consider the example of an XMPP service whose canonical name is "example.com". A user may in fact connect to the physical machine "cm7.us.example.com". The hostname would be communicated as follows.

+ + GSSAPI + DIGEST-MD5 + + cm7.us.example.com + + ]]> +

The client would then attempt to obtain a ticket for the domain-based principal "xmpp/cm7.us.example.com/example.com@EXAMPLE.COM".

+
+ + +

The communication of hostnames during SASL negotiation is not known to introduce new security vulnerabilities. Communication of hostnames SHOULD NOT occur until after the underlying channel has been secured using Transport Layer Security (TLS; &rfc4346;) as described for XMPP in RFC 3920 and rfc3920bis. For additional security considerations, refer to draft-ietf-kitten-gssapi-domain-based-names and draft-ietf-kitten-krb5-gssapi-domain-based-names.

+
+ + +

This document requires no interaction with &IANA;.

+
+ + + +

Until this specification advances to a status of Draft, its associated namespace shall be "urn:xmpp:tmp:domain-based-name"; upon advancement of this specification, the ®ISTRAR; shall issue a permanent namespace in accordance with the process defined in Section 4 of &xep0053;.

+
+
+ + + + + + + + + + ]]> + + + +

Thanks to Alexey Melnikov for his comments.

+
+ +