Blame tests/run-decrypt.c

Packit Service 672cf4
/* run-decrypt.c  - Helper to perform a verify operation
Packit Service 6c01f9
   Copyright (C) 2009 g10 Code GmbH
Packit Service 6c01f9
                 2016 by Bundesamt für Sicherheit in der Informationstechnik
Packit Service 6c01f9
                 Software engineering by Intevation GmbH
Packit Service 6c01f9
Packit Service 6c01f9
   This file is part of GPGME.
Packit Service 6c01f9
Packit Service 6c01f9
   GPGME is free software; you can redistribute it and/or modify it
Packit Service 6c01f9
   under the terms of the GNU Lesser General Public License as
Packit Service 6c01f9
   published by the Free Software Foundation; either version 2.1 of
Packit Service 6c01f9
   the License, or (at your option) any later version.
Packit Service 6c01f9
Packit Service 6c01f9
   GPGME is distributed in the hope that it will be useful, but
Packit Service 6c01f9
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 6c01f9
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 6c01f9
   Lesser General Public License for more details.
Packit Service 6c01f9
Packit Service 6c01f9
   You should have received a copy of the GNU Lesser General Public
Packit Service 6c01f9
   License along with this program; if not, see <https://www.gnu.org/licenses/>.
Packit Service 6c01f9
*/
Packit Service 672cf4
Packit Service 672cf4
/* We need to include config.h so that we know whether we are building
Packit Service 672cf4
   with large file system (LFS) support. */
Packit Service 672cf4
#ifdef HAVE_CONFIG_H
Packit Service 672cf4
#include <config.h>
Packit Service 672cf4
#endif
Packit Service 672cf4
Packit Service 672cf4
#include <stdlib.h>
Packit Service 672cf4
#include <stdio.h>
Packit Service 672cf4
#include <string.h>
Packit Service 672cf4
Packit Service 672cf4
#include <gpgme.h>
Packit Service 672cf4
Packit Service 672cf4
#define PGM "run-decrypt"
Packit Service 672cf4
Packit Service 672cf4
#include "run-support.h"
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
static int verbose;
Packit Service 672cf4
Packit Service 672cf4
static gpg_error_t
Packit Service 672cf4
status_cb (void *opaque, const char *keyword, const char *value)
Packit Service 672cf4
{
Packit Service 672cf4
  (void)opaque;
Packit Service 672cf4
  fprintf (stderr, "status_cb: %s %s\n", keyword, value);
Packit Service 672cf4
  return 0;
Packit Service 672cf4
}
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
static void
Packit Service 672cf4
print_result (gpgme_decrypt_result_t result)
Packit Service 672cf4
{
Packit Service 672cf4
  gpgme_recipient_t recp;
Packit Service 672cf4
  int count = 0;
Packit Service 672cf4
Packit Service 6c01f9
  printf ("Original file name: %s\n", nonnull(result->file_name));
Packit Service 6c01f9
  printf ("Wrong key usage: %i\n", result->wrong_key_usage);
Packit Service 6c01f9
  printf ("Unsupported algorithm: %s\n",
Packit Service 6c01f9
          nonnull(result->unsupported_algorithm));
Packit Service 6c01f9
  if (result->session_key)
Packit Service 6c01f9
    printf ("Session key: %s\n", result->session_key);
Packit Service 672cf4
Packit Service 6c01f9
  for (recp = result->recipients; recp->next; recp = recp->next)
Packit Service 672cf4
    {
Packit Service 6c01f9
      printf ("recipient %d\n", count++);
Packit Service 672cf4
      printf ("  status ....: %s\n", gpgme_strerror (recp->status));
Packit Service 6c01f9
      printf ("  keyid: %s\n", nonnull (recp->keyid));
Packit Service 6c01f9
      printf ("  algo ...: %s\n", gpgme_pubkey_algo_name (recp->pubkey_algo));
Packit Service 672cf4
    }
Packit Service 672cf4
}
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
static int
Packit Service 672cf4
show_usage (int ex)
Packit Service 672cf4
{
Packit Service 672cf4
  fputs ("usage: " PGM " [options] FILE\n\n"
Packit Service 672cf4
         "Options:\n"
Packit Service 672cf4
         "  --verbose        run in verbose mode\n"
Packit Service 672cf4
         "  --status         print status lines from the backend\n"
Packit Service 672cf4
         "  --openpgp        use the OpenPGP protocol (default)\n"
Packit Service 672cf4
         "  --cms            use the CMS protocol\n"
Packit Service 672cf4
         "  --export-session-key            show the session key\n"
Packit Service 672cf4
         "  --override-session-key STRING   use STRING as session key\n"
Packit Service 672cf4
         "  --unwrap         remove only the encryption layer\n"
Packit Service 672cf4
         , stderr);
Packit Service 672cf4
  exit (ex);
Packit Service 672cf4
}
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
int
Packit Service 672cf4
main (int argc, char **argv)
Packit Service 672cf4
{
Packit Service 672cf4
  int last_argc = -1;
Packit Service 672cf4
  gpgme_error_t err;
Packit Service 672cf4
  gpgme_ctx_t ctx;
Packit Service 672cf4
  gpgme_protocol_t protocol = GPGME_PROTOCOL_OpenPGP;
Packit Service 672cf4
  gpgme_decrypt_flags_t flags = 0;
Packit Service 672cf4
  FILE *fp_in = NULL;
Packit Service 672cf4
  gpgme_data_t in = NULL;
Packit Service 672cf4
  gpgme_data_t out = NULL;
Packit Service 672cf4
  gpgme_decrypt_result_t result;
Packit Service 672cf4
  int print_status = 0;
Packit Service 672cf4
  int export_session_key = 0;
Packit Service 672cf4
  const char *override_session_key = NULL;
Packit Service 672cf4
  int raw_output = 0;
Packit Service 672cf4
Packit Service 672cf4
  if (argc)
Packit Service 672cf4
    { argc--; argv++; }
Packit Service 672cf4
Packit Service 672cf4
  while (argc && last_argc != argc )
Packit Service 672cf4
    {
Packit Service 672cf4
      last_argc = argc;
Packit Service 672cf4
      if (!strcmp (*argv, "--"))
Packit Service 672cf4
        {
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
          break;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--help"))
Packit Service 672cf4
        show_usage (0);
Packit Service 672cf4
      else if (!strcmp (*argv, "--verbose"))
Packit Service 672cf4
        {
Packit Service 672cf4
          verbose = 1;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--status"))
Packit Service 672cf4
        {
Packit Service 672cf4
          print_status = 1;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--openpgp"))
Packit Service 672cf4
        {
Packit Service 672cf4
          protocol = GPGME_PROTOCOL_OpenPGP;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--cms"))
Packit Service 672cf4
        {
Packit Service 672cf4
          protocol = GPGME_PROTOCOL_CMS;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--export-session-key"))
Packit Service 672cf4
        {
Packit Service 672cf4
          export_session_key = 1;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--override-session-key"))
Packit Service 672cf4
        {
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
          if (!argc)
Packit Service 672cf4
            show_usage (1);
Packit Service 672cf4
          override_session_key = *argv;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strcmp (*argv, "--unwrap"))
Packit Service 672cf4
        {
Packit Service 672cf4
          flags |= GPGME_DECRYPT_UNWRAP;
Packit Service 672cf4
          raw_output = 1;
Packit Service 672cf4
          argc--; argv++;
Packit Service 672cf4
        }
Packit Service 672cf4
      else if (!strncmp (*argv, "--", 2))
Packit Service 672cf4
        show_usage (1);
Packit Service 672cf4
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  if (argc < 1 || argc > 2)
Packit Service 672cf4
    show_usage (1);
Packit Service 672cf4
Packit Service 672cf4
  fp_in = fopen (argv[0], "rb");
Packit Service 672cf4
  if (!fp_in)
Packit Service 672cf4
    {
Packit Service 672cf4
      err = gpgme_error_from_syserror ();
Packit Service 672cf4
      fprintf (stderr, PGM ": can't open `%s': %s\n",
Packit Service 672cf4
               argv[0], gpgme_strerror (err));
Packit Service 672cf4
      exit (1);
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  init_gpgme (protocol);
Packit Service 672cf4
Packit Service 672cf4
  err = gpgme_new (&ctx;;
Packit Service 672cf4
  fail_if_err (err);
Packit Service 672cf4
  gpgme_set_protocol (ctx, protocol);
Packit Service 672cf4
  if (print_status)
Packit Service 672cf4
    {
Packit Service 672cf4
      gpgme_set_status_cb (ctx, status_cb, NULL);
Packit Service 672cf4
      gpgme_set_ctx_flag (ctx, "full-status", "1");
Packit Service 672cf4
    }
Packit Service 672cf4
  if (export_session_key)
Packit Service 672cf4
    {
Packit Service 672cf4
      err = gpgme_set_ctx_flag (ctx, "export-session-key", "1");
Packit Service 672cf4
      if (err)
Packit Service 672cf4
        {
Packit Service 672cf4
          fprintf (stderr, PGM ": error requesting exported session key: %s\n",
Packit Service 672cf4
                   gpgme_strerror (err));
Packit Service 672cf4
          exit (1);
Packit Service 672cf4
        }
Packit Service 672cf4
    }
Packit Service 672cf4
  if (override_session_key)
Packit Service 672cf4
    {
Packit Service 672cf4
      err = gpgme_set_ctx_flag (ctx, "override-session-key",
Packit Service 672cf4
                                override_session_key);
Packit Service 672cf4
      if (err)
Packit Service 672cf4
        {
Packit Service 6c01f9
          fprintf (stderr, PGM ": error overriding session key: %s\n",
Packit Service 672cf4
                   gpgme_strerror (err));
Packit Service 672cf4
          exit (1);
Packit Service 672cf4
        }
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  err = gpgme_data_new_from_stream (&in, fp_in);
Packit Service 672cf4
  if (err)
Packit Service 672cf4
    {
Packit Service 672cf4
      fprintf (stderr, PGM ": error allocating data object: %s\n",
Packit Service 672cf4
               gpgme_strerror (err));
Packit Service 672cf4
      exit (1);
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  err = gpgme_data_new (&out;;
Packit Service 672cf4
  if (err)
Packit Service 672cf4
    {
Packit Service 672cf4
      fprintf (stderr, PGM ": error allocating data object: %s\n",
Packit Service 672cf4
               gpgme_strerror (err));
Packit Service 672cf4
      exit (1);
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  err = gpgme_op_decrypt_ext (ctx, flags, in, out);
Packit Service 672cf4
  result = gpgme_op_decrypt_result (ctx);
Packit Service 672cf4
  if (err)
Packit Service 672cf4
    {
Packit Service 672cf4
      fprintf (stderr, PGM ": decrypt failed: %s\n", gpgme_strerror (err));
Packit Service 672cf4
      exit (1);
Packit Service 672cf4
    }
Packit Service 672cf4
  if (result)
Packit Service 672cf4
    {
Packit Service 672cf4
      if (!raw_output)
Packit Service 672cf4
        print_result (result);
Packit Service 672cf4
      if (!raw_output)
Packit Service 672cf4
        fputs ("Begin Output:\n", stdout);
Packit Service 672cf4
      print_data (out);
Packit Service 672cf4
      if (!raw_output)
Packit Service 672cf4
        fputs ("End Output.\n", stdout);
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  gpgme_data_release (out);
Packit Service 672cf4
  gpgme_data_release (in);
Packit Service 672cf4
Packit Service 672cf4
  gpgme_release (ctx);
Packit Service 672cf4
  return 0;
Packit Service 672cf4
}