Blame tests/run-sign.c

Packit d7e8d0
/* run-sign.c  - Helper to perform a sign operation
Packit d7e8d0
   Copyright (C) 2009 g10 Code 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-sign"
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
  printf ("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_sign_result_t result, gpgme_sig_mode_t type)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_invalid_key_t invkey;
Packit d7e8d0
  gpgme_new_signature_t sig;
Packit d7e8d0
Packit d7e8d0
  (void)type;
Packit d7e8d0
Packit d7e8d0
  for (invkey = result->invalid_signers; invkey; invkey = invkey->next)
Packit d7e8d0
    printf ("Signing key `%s' not used: %s <%s>\n",
Packit d7e8d0
            nonnull (invkey->fpr),
Packit d7e8d0
            gpg_strerror (invkey->reason), gpg_strsource (invkey->reason));
Packit d7e8d0
Packit d7e8d0
  for (sig = result->signatures; sig; sig = sig->next)
Packit d7e8d0
    {
Packit d7e8d0
      printf ("Key fingerprint: %s\n", nonnull (sig->fpr));
Packit d7e8d0
      printf ("Signature type : %d\n", sig->type);
Packit d7e8d0
      printf ("Public key algo: %d\n", sig->pubkey_algo);
Packit d7e8d0
      printf ("Hash algo .....: %d\n", sig->hash_algo);
Packit d7e8d0
      printf ("Creation time .: %ld\n", sig->timestamp);
Packit d7e8d0
      printf ("Sig class .....: 0x%u\n", sig->sig_class);
Packit d7e8d0
    }
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
         "  --uiserver       use the UI server\n"
Packit d7e8d0
         "  --loopback       use a loopback pinentry\n"
Packit d7e8d0
         "  --key NAME       use key NAME for signing\n"
Packit d7e8d0
         "  --sender MBOX    use MBOX as sender address\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
  const char *key_string = NULL;
Packit d7e8d0
  gpgme_protocol_t protocol = GPGME_PROTOCOL_OpenPGP;
Packit d7e8d0
  gpgme_sig_mode_t sigmode = GPGME_SIG_MODE_NORMAL;
Packit d7e8d0
  gpgme_data_t in, out;
Packit d7e8d0
  gpgme_sign_result_t result;
Packit d7e8d0
  int print_status = 0;
Packit d7e8d0
  int use_loopback = 0;
Packit d7e8d0
  const char *sender = NULL;
Packit d7e8d0
  const char *s;
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, "--uiserver"))
Packit d7e8d0
        {
Packit d7e8d0
          protocol = GPGME_PROTOCOL_UISERVER;
Packit d7e8d0
          argc--; argv++;
Packit d7e8d0
        }
Packit d7e8d0
      else if (!strcmp (*argv, "--key"))
Packit d7e8d0
        {
Packit d7e8d0
          argc--; argv++;
Packit d7e8d0
          if (!argc)
Packit d7e8d0
            show_usage (1);
Packit d7e8d0
          key_string = *argv;
Packit d7e8d0
          argc--; argv++;
Packit d7e8d0
        }
Packit d7e8d0
      else if (!strcmp (*argv, "--sender"))
Packit d7e8d0
        {
Packit d7e8d0
          argc--; argv++;
Packit d7e8d0
          if (!argc)
Packit d7e8d0
            show_usage (1);
Packit d7e8d0
          sender = *argv;
Packit d7e8d0
          argc--; argv++;
Packit d7e8d0
        }
Packit d7e8d0
      else if (!strcmp (*argv, "--loopback"))
Packit d7e8d0
        {
Packit d7e8d0
          use_loopback = 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)
Packit d7e8d0
    show_usage (1);
Packit d7e8d0
Packit d7e8d0
  if (key_string && protocol == GPGME_PROTOCOL_UISERVER)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, PGM ": ignoring --key in UI-server mode\n");
Packit d7e8d0
      key_string = NULL;
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
  gpgme_set_armor (ctx, 1);
Packit d7e8d0
  if (print_status)
Packit d7e8d0
    gpgme_set_status_cb (ctx, status_cb, NULL);
Packit d7e8d0
  if (use_loopback)
Packit d7e8d0
    gpgme_set_pinentry_mode (ctx, GPGME_PINENTRY_MODE_LOOPBACK);
Packit d7e8d0
Packit d7e8d0
  if (key_string)
Packit d7e8d0
    {
Packit d7e8d0
      gpgme_key_t akey;
Packit d7e8d0
Packit d7e8d0
      err = gpgme_get_key (ctx, key_string, &akey, 1);
Packit d7e8d0
      if (err)
Packit d7e8d0
        {
Packit d7e8d0
          exit (1);
Packit d7e8d0
        }
Packit d7e8d0
      err = gpgme_signers_add (ctx, akey);
Packit d7e8d0
      fail_if_err (err);
Packit d7e8d0
      gpgme_key_unref (akey);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  if (sender)
Packit d7e8d0
    {
Packit d7e8d0
      err = gpgme_set_sender (ctx, sender);
Packit d7e8d0
      fail_if_err (err);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  err = gpgme_data_new_from_file (&in, *argv, 1);
Packit d7e8d0
  if (err)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, PGM ": error reading `%s': %s\n",
Packit d7e8d0
               *argv, gpg_strerror (err));
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  err = gpgme_data_new (&out;;
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  err = gpgme_op_sign (ctx, in, out, sigmode);
Packit d7e8d0
  result = gpgme_op_sign_result (ctx);
Packit d7e8d0
  if (result)
Packit d7e8d0
    print_result (result, sigmode);
Packit d7e8d0
  if (err)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, PGM ": signing failed: %s\n", gpg_strerror (err));
Packit d7e8d0
      exit (1);
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  if ((s = gpgme_get_ctx_flag (ctx, "redraw")) && *s)
Packit d7e8d0
    fputs ("Screen redraw suggested\n", stdout);
Packit d7e8d0
Packit d7e8d0
  fputs ("Begin Output:\n", stdout);
Packit d7e8d0
  print_data (out);
Packit d7e8d0
  fputs ("End Output.\n", stdout);
Packit d7e8d0
  gpgme_data_release (out);
Packit d7e8d0
Packit d7e8d0
  gpgme_data_release (in);
Packit d7e8d0
Packit d7e8d0
  gpgme_release (ctx);
Packit d7e8d0
  return 0;
Packit d7e8d0
}