Blame tests/run-decrypt.c

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