Line data Source code
1 : /* t-encrypt-sym.c - Regression test.
2 : Copyright (C) 2000 Werner Koch (dd9jn)
3 : Copyright (C) 2001, 2003, 2004 g10 Code GmbH
4 :
5 : This file is part of GPGME.
6 :
7 : GPGME is free software; you can redistribute it and/or modify it
8 : under the terms of the GNU Lesser General Public License as
9 : published by the Free Software Foundation; either version 2.1 of
10 : the License, or (at your option) any later version.
11 :
12 : GPGME is distributed in the hope that it will be useful, but
13 : WITHOUT ANY WARRANTY; without even the implied warranty of
14 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 : Lesser General Public License for more details.
16 :
17 : You should have received a copy of the GNU Lesser General Public
18 : License along with this program; if not, write to the Free Software
19 : Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
20 : 02111-1307, USA. */
21 :
22 : /* We need to include config.h so that we know whether we are building
23 : with large file system (LFS) support. */
24 : #ifdef HAVE_CONFIG_H
25 : #include <config.h>
26 : #endif
27 :
28 : #include <stdio.h>
29 : #include <stdlib.h>
30 : #include <string.h>
31 : #include <assert.h>
32 : #include <unistd.h>
33 :
34 : #include <gpgme.h>
35 :
36 : #include "t-support.h"
37 :
38 :
39 : int
40 1 : main (int argc, char *argv[])
41 : {
42 : gpgme_ctx_t ctx;
43 : gpgme_error_t err;
44 : gpgme_data_t plain, cipher;
45 1 : const char *text = "Hallo Leute\n";
46 : char *text2;
47 : char *p;
48 : size_t len;
49 :
50 1 : init_gpgme (GPGME_PROTOCOL_OpenPGP);
51 :
52 1 : err = gpgme_new (&ctx);
53 1 : fail_if_err (err);
54 1 : gpgme_set_armor (ctx, 1);
55 :
56 1 : p = getenv("GPG_AGENT_INFO");
57 1 : if (!(p && strchr (p, ':')))
58 1 : gpgme_set_passphrase_cb (ctx, passphrase_cb, NULL);
59 :
60 1 : err = gpgme_data_new_from_mem (&plain, text, strlen (text), 0);
61 1 : fail_if_err (err);
62 :
63 1 : err = gpgme_data_new (&cipher);
64 1 : fail_if_err (err);
65 :
66 1 : err = gpgme_op_encrypt (ctx, 0, 0, plain, cipher);
67 1 : fail_if_err (err);
68 :
69 1 : fflush (NULL);
70 1 : fputs ("Begin Result Encryption:\n", stdout);
71 1 : print_data (cipher);
72 1 : fputs ("End Result.\n", stdout);
73 :
74 1 : gpgme_data_seek (cipher, 0, SEEK_SET);
75 :
76 1 : gpgme_data_release (plain);
77 1 : err = gpgme_data_new (&plain);
78 1 : fail_if_err (err);
79 :
80 1 : err = gpgme_op_decrypt (ctx, cipher, plain);
81 1 : fail_if_err (err);
82 :
83 1 : fputs ("Begin Result Decryption:\n", stdout);
84 1 : print_data (plain);
85 1 : fputs ("End Result.\n", stdout);
86 :
87 1 : text2 = gpgme_data_release_and_get_mem (plain, &len);
88 1 : if (strncmp (text, text2, len))
89 : {
90 0 : fprintf (stderr, "%s:%d: Wrong plaintext\n", __FILE__, __LINE__);
91 0 : exit (1);
92 : }
93 :
94 1 : gpgme_data_release (cipher);
95 1 : free (text2);
96 1 : gpgme_release (ctx);
97 :
98 1 : return 0;
99 : }
|