diff options
author | LemonBoy <thatlemon@gmail.com> | 2015-09-11 22:09:47 +0200 |
---|---|---|
committer | LemonBoy <thatlemon@gmail.com> | 2015-09-11 22:09:47 +0200 |
commit | 6645d0d38dc4627a9553235a98df4f4717a1fc6f (patch) | |
tree | 62e336b20ad7b1457e923b28ce931080d5c98361 | |
parent | 171b67441d64a85a23daf5018159f167eb7fe583 (diff) | |
download | irssi-6645d0d38dc4627a9553235a98df4f4717a1fc6f.zip |
Explicitly set the authorization id during the PLAIN handshake
On error show the user the message sent by the server.
-rw-r--r-- | src/irc/core/sasl.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/src/irc/core/sasl.c b/src/irc/core/sasl.c index 0e343299..4d52e3c0 100644 --- a/src/irc/core/sasl.c +++ b/src/irc/core/sasl.c @@ -47,8 +47,7 @@ static void sasl_fail (IRC_SERVER_REC *server, const char *data, const char *fro server->sasl_timeout = -1; } - g_critical("Authentication failed, make sure your credentials are correct and that the mechanism " - "you have selected is supported by this server."); + g_critical("Authentication failed with reason \"%s\"", data); /* Terminate the negotiation */ cap_finish_negotiation(server); @@ -93,15 +92,15 @@ static void sasl_step (IRC_SERVER_REC *server, const char *data, const char *fro switch (conn->sasl_mechanism) { case SASL_MECHANISM_PLAIN: - /* At this point we assume that conn->{username, password} are non-NULL. + /* At this point we assume that conn->sasl_{username, password} are non-NULL. * The PLAIN mechanism expects a NULL-separated string composed by the authorization identity, the * authentication identity and the password. - * The authorization identity field is optional and can be omitted, the server will derive the - * identity by looking at the credentials provided. + * The authorization identity field is explicitly set to the user provided username. * The whole request is then encoded in base64. */ req = g_string_new(NULL); + g_string_append(req, conn->sasl_username); g_string_append_c(req, '\0'); g_string_append(req, conn->sasl_username); g_string_append_c(req, '\0'); |