On Wed, 19 Mar 2025 at 15:53, Andrzej Telezynski
<andrzej.telezynski@erlang-solutions.com> wrote:
>
> Hello,
>
> I am confused about those two elements: `authorization-identity` and `authorization-identifier`.
> Are they equivalent? They seem to be used in the same context.
Ha, lots of fun. I think the correct one is
<authorization-identifier/>. It's in XEP-0388 which is the official
definition of the urn:xmpp:sasl:2 namespace. I confirmed it's also
what Prosody is using, and lots of client implementations were
developed against Prosody.
The SASL RFC (https://www.rfc-editor.org/rfc/rfc4422 ) uses the term
"authorization identity" (the term "authorization identifier" does not
appear), so I guess that's how the "wrong" term slipped in by mistake,
and probably got copied into the later XEPs.
Whoops. Sorry.
> Grepping the XEPS repo shows both are used:
>
> $ grep -rl authorization-identity
> ./xep-0484.xml
> ./inbox/xep-fast.xml
> ./inbox/sasl2.xml
> ./xep-0386.xml
>
> $ grep -rl authorization-identifier
> ./xep-0480.xml
> ./inbox/xep-downgrade-prevention.xml
> ./inbox/xep-scram-upgrade.xml
> ./inbox/sasl2.xml
> ./xep-0198.xml
> ./xep-0388.xml
> ./xep-0474.xml
>
> What confuses me is that they both are used in the same context, f. ex.:
>
> "XEP-0386: Bind 2" has `authorization-identity` in successful Bind response:
> https://xmpp.org/extensions/xep-0386.html#example-4
>
> <success xmlns='urn:xmpp:sasl:2'>
> <authorization-identity>user@example.com/AwesomeXMPP.4232f4d4</authorization-identity>
> <bound xmlns='urn:xmpp:bind:0'>
> <metadata xmlns='urn:xmpp:mam:2'>
> <start id='YWxwaGEg' timestamp='2008-08-22T21:09:04Z' />
> <end id='b21lZ2Eg' timestamp='2020-04-20T14:34:21Z' />
> </metadata>
> </bound>
> </success>
>
> But "XEP-0388: Extensible SASL Profile" uses `authorization-identifier`
> https://xmpp.org/extensions/xep-0388.html#example-7
>
> <success xmlns='urn:xmpp:sasl:2'>
> <!-- Base64 of: 'v=msVHs/BzIOHDqXeVH7EmmDu9id8=' -->
> <additional-data>
> dj1tc1ZIcy9CeklPSERxWGVWSDdFbW1EdTlpZDg9
> </additional-data>
> <authorization-identifier>user@example.org</authorization-identifier>
> </success>
>
> Is it valid to use `authorization-identifier` in all those cases?
>
> What about other XEPS that use `authorization-identity` f. ex.
> "XEP-0484: Fast Authentication Streamlining Tokens" ?
> https://xmpp.org/extensions/xep-0484.html#example-3
>
> It seems that clients need to expect both variants anyway.
It's a mistake in the XEPs, they shouldn't be contradicting each
other. XEP-0388 defines the urn:xmpp:sasl:2 namespace and it defines
only <authorization-identifier/>.
The only XEPs containing 'authorization-identity' are XEP-0386 and
XEP-0484, and I worked on both of those, so apologies! I'll make sure
they get fixed.
Maybe if we ever bump the sasl:2 namespace we can change the element
name to match the SASL RFC's original terminology though :)
Yeah, it's not ideal, but I think we're stuck with it.
Strictly speaking, I think I'm sort of right in as much as an identifier is a name, whereas the identity is something more abstract. RFC 4422 does use the term "authorization identity string", which is what "authorization-identifier" is. <authorization-identity-string/> is really getting a little too verbose - be glad it wasn't <authz-id-string/>, which would match the ABNF.
Regards,
Matthew
_______________________________________________
Standards mailing list -- standards@xmpp.org
To unsubscribe send an email to standards-leave@xmpp.org