]> jfr.im git - solanum.git/blobdiff - modules/m_signon.c
Combine stats A output parameters (#35)
[solanum.git] / modules / m_signon.c
index 9175c35797a1dfb4e9de01cf9032f8fdee145c12..0714b47ab1a2263d64452ed146f7a19a59926970 100644 (file)
@@ -221,23 +221,23 @@ me_svslogin(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *sou
                struct User *user_p = make_user(target_p);
 
                if(valid & NICK_VALID)
-                       strcpy(target_p->preClient->spoofnick, nick);
+                       rb_strlcpy(target_p->preClient->spoofnick, nick, sizeof(target_p->preClient->spoofnick));
 
                if(valid & USER_VALID)
-                       strcpy(target_p->preClient->spoofuser, user);
+                       rb_strlcpy(target_p->preClient->spoofuser, user, sizeof(target_p->preClient->spoofuser));
 
                if(valid & HOST_VALID)
-                       strcpy(target_p->preClient->spoofhost, host);
+                       rb_strlcpy(target_p->preClient->spoofhost, host, sizeof(target_p->preClient->spoofhost));
 
                rb_strlcpy(user_p->suser, login, NICKLEN + 1);
        }
        else
        {
-               char note[NICKLEN + 10];
+               char note[NAMELEN + 10];
 
                send_signon(NULL, target_p, nick, user, host, rb_current_time(), login);
 
-               snprintf(note, NICKLEN + 10, "Nick: %s", target_p->name);
+               snprintf(note, sizeof(note), "Nick: %s", target_p->name);
                rb_note(target_p->localClient->F, note);
        }
 }
@@ -410,7 +410,7 @@ send_signon(struct Client *client_p, struct Client *target_p,
                        use_id(target_p), nick, user, host,
                        (long) target_p->tsinfo, *login ? login : "0");
 
-       strcpy(target_p->user->suser, login);
+       rb_strlcpy(target_p->user->suser, login, sizeof(target_p->user->suser));
 
        change_nick_user_host(target_p, nick, user, host, newts, "Signing %s (%s)", *login ?  "in" : "out", nick);
 }