1998-12-21 10:52:47 +00:00
|
|
|
/* NOCW */
|
|
|
|
/*
|
|
|
|
Please read the README file for condition of use, before
|
|
|
|
using this software.
|
|
|
|
|
|
|
|
Maurice Gittens <mgittens@gits.nl> January 1997
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
1999-05-27 23:52:31 +00:00
|
|
|
#include <unistd.h>
|
1998-12-21 10:52:47 +00:00
|
|
|
#include <fcntl.h>
|
|
|
|
#include <sys/stat.h>
|
1999-05-27 23:52:31 +00:00
|
|
|
#include <openssl/evp.h>
|
1998-12-21 10:52:47 +00:00
|
|
|
|
|
|
|
#define STDIN 0
|
|
|
|
#define STDOUT 1
|
|
|
|
#define BUFLEN 512
|
|
|
|
#define INIT_VECTOR "12345678"
|
|
|
|
#define ENCRYPT 1
|
|
|
|
#define DECRYPT 0
|
|
|
|
#define ALG EVP_des_ede3_cbc()
|
|
|
|
|
|
|
|
static const char *usage = "Usage: example3 [-d] password\n";
|
|
|
|
|
|
|
|
void do_cipher(char *,int);
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
if ((argc == 2))
|
|
|
|
{
|
|
|
|
do_cipher(argv[1],ENCRYPT);
|
|
|
|
}
|
|
|
|
else if ((argc == 3) && !strcmp(argv[1],"-d"))
|
|
|
|
{
|
|
|
|
do_cipher(argv[2],DECRYPT);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
fprintf(stderr,"%s", usage);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void do_cipher(char *pw, int operation)
|
|
|
|
{
|
|
|
|
char buf[BUFLEN];
|
|
|
|
char ebuf[BUFLEN + 8];
|
1999-05-27 23:52:31 +00:00
|
|
|
unsigned int ebuflen; /* rc; */
|
1998-12-21 10:52:47 +00:00
|
|
|
unsigned char iv[EVP_MAX_IV_LENGTH], key[EVP_MAX_KEY_LENGTH];
|
1999-05-27 23:52:31 +00:00
|
|
|
/* unsigned int ekeylen, net_ekeylen; */
|
1998-12-21 10:52:47 +00:00
|
|
|
EVP_CIPHER_CTX ectx;
|
|
|
|
|
|
|
|
memcpy(iv, INIT_VECTOR, sizeof(iv));
|
|
|
|
|
|
|
|
EVP_BytesToKey(ALG, EVP_md5(), "salu", pw, strlen(pw), 1, key, iv);
|
|
|
|
|
|
|
|
EVP_CipherInit(&ectx, ALG, key, iv, operation);
|
|
|
|
|
|
|
|
while(1)
|
|
|
|
{
|
|
|
|
int readlen = read(STDIN, buf, sizeof(buf));
|
|
|
|
|
|
|
|
if (readlen <= 0)
|
|
|
|
{
|
|
|
|
if (!readlen)
|
|
|
|
break;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
perror("read");
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
EVP_CipherUpdate(&ectx, ebuf, &ebuflen, buf, readlen);
|
|
|
|
|
|
|
|
write(STDOUT, ebuf, ebuflen);
|
|
|
|
}
|
|
|
|
|
|
|
|
EVP_CipherFinal(&ectx, ebuf, &ebuflen);
|
|
|
|
|
|
|
|
write(STDOUT, ebuf, ebuflen);
|
|
|
|
}
|