diff options
author | Slávek Banko <[email protected]> | 2019-12-11 01:41:26 +0100 |
---|---|---|
committer | Slávek Banko <[email protected]> | 2019-12-11 02:23:35 +0100 |
commit | 73f00336178a9f312bac2992649120d462e0ac2d (patch) | |
tree | 8672519cb50cb0e642af0817188ad28f810338ee /kopete/protocols/msn/sha1.h | |
parent | 914254104c50dec222fb31ce7a25a21870e90f16 (diff) | |
download | tdenetwork-73f00336178a9f312bac2992649120d462e0ac2d.tar.gz tdenetwork-73f00336178a9f312bac2992649120d462e0ac2d.zip |
kopete: Restore the MSN protocol because a replacement MSN server was created.
This reverts commits 0486034738 - 2d5f9c55da and f6fd4ab6c0.
Signed-off-by: Slávek Banko <[email protected]>
Diffstat (limited to 'kopete/protocols/msn/sha1.h')
-rw-r--r-- | kopete/protocols/msn/sha1.h | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/kopete/protocols/msn/sha1.h b/kopete/protocols/msn/sha1.h new file mode 100644 index 00000000..9138fd32 --- /dev/null +++ b/kopete/protocols/msn/sha1.h @@ -0,0 +1,59 @@ +/* + * sha1.h - Secure Hash Algorithm 1 + * Copyright (C) 2003 Justin Karneges + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * + */ + +#ifndef CS_SHA1_H +#define CS_SHA1_H + +#include <tqstring.h> + +class SHA1 +{ +public: + static TQByteArray hash(const TQByteArray &); + static TQByteArray hashString(const TQCString &); + static TQString digest(const TQString &); + +private: + SHA1(); + + struct SHA1_CONTEXT + { + TQ_UINT32 state[5]; + TQ_UINT32 count[2]; + unsigned char buffer[64]; + }; + + typedef union { + unsigned char c[64]; + TQ_UINT32 l[16]; + } CHAR64LONG16; + + void transform(TQ_UINT32 state[5], unsigned char buffer[64]); + void init(SHA1_CONTEXT* context); + void update(SHA1_CONTEXT* context, unsigned char* data, TQ_UINT32 len); + void final(unsigned char digest[20], SHA1_CONTEXT* context); + + unsigned long blk0(TQ_UINT32 i); + bool bigEndian; + + CHAR64LONG16* block; +}; + +#endif |