File: blowfish.h

package info (click to toggle)
portabase 2.0%2Bgit20110117-1
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 6,692 kB
  • sloc: cpp: 32,047; sh: 2,675; ansic: 2,320; makefile: 343; xml: 20; python: 16; asm: 10
file content (85 lines) | stat: -rw-r--r-- 2,765 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
 * blowfish.h
 *
 * Adapted from BeeCrypt: http://sourceforge.net/projects/beecrypt
 *
 * (c) 2008-2010 by Jeremy Bowman <jmbowman@alum.mit.edu>
 * (c) 1999, 2000, 2002 Beeyond Software Holding BV
 *
 * 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */

/** @file blowfish.h
 * Blowfish block cipher header file.
 *
 * For more information on this blockcipher, see:
 * "Applied Cryptography", second edition,
 *  Bruce Schneier,
 *  Wiley & Sons.
 *
 * Also see http://www.counterpane.com/blowfish.html
 */

#ifndef _BLOWFISH_H
#define _BLOWFISH_H

#include <QByteArray>

#define BLOWFISHROUNDS	16
#define BLOWFISHPSIZE	(BLOWFISHROUNDS+2)

/**
 * Holds all the parameters necessary for the %Blowfish cipher.
 */
struct blowfishParam
{
	quint32 p[BLOWFISHPSIZE]; /**< Holds the key expansion. */
	quint32 s[1024]; /**< Holds the s-boxes. */
	quint32 fdback[2]; /**< Buffer to be used by block chaining or feedback modes. */
};

/**
 * Implementation of the %Blowfish block cipher using CBC mode.  Derived
 * from the implementation in BeeCrypt, refactored to include only the
 * parts needed by %PortaBase and to take advantage of C++ code organization
 * features.
 */
class Blowfish
{
public:
    Blowfish();
    
    int setup(const QByteArray &key);
    QByteArray encrypt(const QByteArray &data, const QByteArray &iv);
    QByteArray decrypt(const QByteArray &data, const QByteArray &iv);

public:
    static size_t blockSize; /** The size of one block of data, in bytes. */

private:
    int setup(blowfishParam *bp, const quint8 *key, size_t keybits);
    int setIV(blowfishParam *bp, const quint8 *iv);
    int encrypt(blowfishParam *bp, quint32 *dst, const quint32 *src);
    int decrypt (blowfishParam *bp, quint32 *dst, const quint32 *src);
    int blockEncryptCBC(quint32 *dst, const quint32 *src, unsigned int nblocks);
    int blockDecryptCBC(quint32 *dst, const quint32 *src, unsigned int nblocks);

private:
    blowfishParam encryptParam; /**< Encryption parameters struct */
    blowfishParam decryptParam; /**< Decryption parameters struct */
};

#endif