#include "stdinc.h"
#include "client.h" /* client struct */
-#include "irc_string.h"
+#include "match.h"
#include "send.h" /* sendto_one */
#include "numeric.h" /* ERR_xxx */
#include "ircd.h" /* me */
*
*
* mr_pass - PASS message handler
- * parv[0] = sender prefix
* parv[1] = password
* parv[2] = "TS" if this server supports TS.
* parv[3] = optional TS version field -- needed for TS6
static int
mr_pass(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
+ char *auth_user, *pass, *buf;
+ buf = LOCAL_COPY(parv[1]);
+
if(client_p->localClient->passwd)
{
memset(client_p->localClient->passwd, 0,
strlen(client_p->localClient->passwd));
- MyFree(client_p->localClient->passwd);
+ rb_free(client_p->localClient->passwd);
}
- DupNString(client_p->localClient->passwd, parv[1], PASSWDLEN);
+ client_p->localClient->passwd = rb_strndup(parv[1], PASSWDLEN);
+
+ if ((pass = strchr(buf, ':')) != NULL)
+ {
+ *pass++ = '\0';
+ auth_user = buf;
+ }
+ else
+ {
+ pass = buf;
+ auth_user = NULL;
+ }
+
+ client_p->localClient->passwd = *pass ? rb_strndup(pass, PASSWDLEN) : NULL;
+
+ if(auth_user && *auth_user)
+ client_p->localClient->auth_user = rb_strndup(auth_user, PASSWDLEN);
/* These are for servers only */
if(parc > 2 && client_p->user == NULL)
if(irccmp(parv[2], "TS") == 0 && client_p->tsinfo == 0)
client_p->tsinfo = TS_DOESTS;
- /* kludge, if we're not using ts6, dont ever mark a server
- * as TS6 capable, that way we'll never send them TS6 data.
- */
if(parc == 5 && atoi(parv[3]) >= 6)
{
/* only mark as TS6 if the SID is valid.. */