123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- /* NOCW */
- /*
- Please read the README file for condition of use, before
- using this software.
- Maurice Gittens <mgittens@gits.nl> January 1997
- */
- #include <stdio.h>
- #include <unistd.h>
- #include <fcntl.h>
- #include <sys/stat.h>
- #include <openssl/evp.h>
- #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];
- unsigned int ebuflen; /* rc; */
- unsigned char iv[EVP_MAX_IV_LENGTH], key[EVP_MAX_KEY_LENGTH];
- /* unsigned int ekeylen, net_ekeylen; */
- EVP_CIPHER_CTX ectx;
-
- memcpy(iv, INIT_VECTOR, sizeof(iv));
- EVP_BytesToKey(ALG, EVP_md5(), "salu", pw, strlen(pw), 1, key, iv);
- EVP_CIPHER_CTX_init(&ectx);
- EVP_CipherInit_ex(&ectx, ALG, NULL, 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_ex(&ectx, ebuf, &ebuflen);
- EVP_CIPHER_CTX_cleanup(&ectx);
- write(STDOUT, ebuf, ebuflen);
- }
|