diff options
author | psychon <psychon@e03df62e-2008-0410-955e-edbf42e46eb7> | 2009-10-10 12:15:06 +0000 |
---|---|---|
committer | psychon <psychon@e03df62e-2008-0410-955e-edbf42e46eb7> | 2009-10-10 12:15:06 +0000 |
commit | 027668741c47f894a914e8d40b2b74b15b824456 (patch) | |
tree | abe490a43e0451f1395f973788627d6988026ac2 /src | |
parent | 57e908f8ce297c38e31843057226b737aa9fc6d2 (diff) |
m_cloaking: Error out on "wrong" cloaking keys
Cloaking keys above 0x80000000 result in different hashes on 64-bit and 32-bit
boxes due to different integer overflow behavior. This means it should make
sense to catch those key and error out on them.
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11817 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src')
-rw-r--r-- | src/modules/m_cloaking.cpp | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/src/modules/m_cloaking.cpp b/src/modules/m_cloaking.cpp index ddea8737c..8f650d7a2 100644 --- a/src/modules/m_cloaking.cpp +++ b/src/modules/m_cloaking.cpp @@ -200,7 +200,11 @@ class CloakUser : public ModeHandler * that will limit the valid values to only the positive values in a * signed int. Instead, accept any value that fits into an int and * cast it to an unsigned int. That will, a bit oddly, give us the full - * spectrum of an unsigned integer. - Special */ + * spectrum of an unsigned integer. - Special + * + * We must limit the keys or else we get different results on + * amd64/x86 boxes. - psychon */ + const unsigned int limit = 0x80000000; key1 = key2 = key3 = key4 = 0; key1 = (unsigned int) Conf.ReadInteger("cloak","key1",0,false); key2 = (unsigned int) Conf.ReadInteger("cloak","key2",0,false); @@ -228,16 +232,16 @@ class CloakUser : public ModeHandler if (prefix.empty()) prefix = ServerInstance->Config->Network; - if (!key1 || !key2 || !key3 || !key4) + if (!key1 || !key2 || !key3 || !key4 || key1 >= limit || key2 >= limit || key3 >= limit || key4 >= limit) { std::string detail; - if (!key1) + if (!key1 || key1 >= limit) detail = "<cloak:key1> is not valid, it may be set to a too high/low value, or it may not exist."; - else if (!key2) + else if (!key2 || key2 >= limit) detail = "<cloak:key2> is not valid, it may be set to a too high/low value, or it may not exist."; - else if (!key3) + else if (!key3 || key3 >= limit) detail = "<cloak:key3> is not valid, it may be set to a too high/low value, or it may not exist."; - else if (!key4) + else if (!key4 || key4 >= limit) detail = "<cloak:key4> is not valid, it may be set to a too high/low value, or it may not exist."; throw ModuleException("You have not defined cloak keys for m_cloaking!!! THIS IS INSECURE AND SHOULD BE CHECKED! - " + detail); |