summaryrefslogtreecommitdiff
path: root/src/modules/m_setident.cpp
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-10-06 09:09:27 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-10-06 09:09:27 +0000
commit82243d9beb827fca5708efe9e047ff2fec4bfe8c (patch)
tree8013da43263aa2d175e906d454d37fe6680b5220 /src/modules/m_setident.cpp
parentf7fa509637447df624cb0a0332ac2c07d091674c (diff)
Tidy up strlens which are not required
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@5428 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules/m_setident.cpp')
-rw-r--r--src/modules/m_setident.cpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/modules/m_setident.cpp b/src/modules/m_setident.cpp
index 2bcdceeb1..d1f67bb14 100644
--- a/src/modules/m_setident.cpp
+++ b/src/modules/m_setident.cpp
@@ -15,14 +15,20 @@ class cmd_setident : public command_t
CmdResult Handle(const char** parameters, int pcnt, userrec *user)
{
- for(unsigned int x = 0; x < strlen(parameters[0]); x++)
+ size_t len = 0;
+ for(const char* x = parameters[0]; *x; x++, len++)
{
- if(((parameters[0][x] >= 'A') && (parameters[0][x] <= '}')) || strchr(".-0123456789", parameters[0][x]))
+ if(((*x >= 'A') && (*x <= '}')) || strchr(".-0123456789", *x))
continue;
-
+
user->WriteServ("NOTICE %s :*** Invalid characters in ident", user->nick);
return CMD_FAILURE;
}
+ if (len > IDENTMAX)
+ {
+ user->WriteServ("NOTICE %s :*** Ident is too long", user->nick);
+ return CMD_FAILURE;
+ }
user->ChangeIdent(parameters[0]);
ServerInstance->WriteOpers("%s used SETIDENT to change their ident to '%s'", user->nick, user->ident);