summaryrefslogtreecommitdiffstats
path: root/kwallet/backend/tests/testbf.cpp
blob: 12dc746304f7263bd5701e6a0fa9238e5ca01dbe (plain)
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "blowfish.h"
#include "cbc.h"


int main() {
BlockCipher *bf;
char data[] = "This is a test.";
char expect[] = "\x22\x30\x7e\x2f\x42\x28\x44\x01\xda\xdf\x5a\x81\xd7\xe5\x7c\xd0";
char key[] = "testkey";
unsigned long et[] = {0x11223344};

  printf("%d:  0x11 == %d and 0x44 == %d\n", ((unsigned char *)et)[0],
                                             0x11, 0x44);
  bf = new BlowFish();
//  bf = new CipherBlockChain(new BlowFish());

  bf->setKey((void *)key, 7*8);

  if (!bf->readyToGo()) {
     printf("Error: not ready to go!\n");
     return -1;
  }

  printf("About to encrypt...\n"); fflush(stdout);
  if (-1 == bf->encrypt((void *)data, 8)) {
     printf("Error: encrypt failed!\n");
     return -1;
  }
  printf("About to encrypt part 2...\n"); fflush(stdout);
  bf->encrypt((void *)(data+8), 8);

  printf("Encryption done.  data[] is now: ");
  for (int i = 0; i < 16; i++) {
     printf("0x%x ", data[i]&0xff);
     if ((data[i]&0xff) != (expect[i]&0xff)) {
        printf("Error.  This byte failed the comparison.  It should have been 0x%x.\n", expect[i]&0xff);
        return -1;
     }
  }
  printf("\n");

  delete bf;
  bf = new BlowFish();
//  bf = new CipherBlockChain(new BlowFish());
  bf->setKey((void *)key, 7*8);

  printf("About to decrypt...\n"); fflush(stdout);
  if (-1 == bf->decrypt((void *)data, 16)) {
     printf("Error: decrypt failed!\n");
     return -1;
  }
  //bf->decrypt((void *)(data+8), 8);

  printf("All done!  Result...  data[] = \"%s\"\n", data);
  if (strcmp(data, "This is a test.")) {
      printf("ERROR. Decryption failed.\n");
      return -1;
  }

  delete bf;
}