diff options
| author | Ben McGinnes <[email protected]> | 2018-03-24 22:44:51 +0000 | 
|---|---|---|
| committer | Ben McGinnes <[email protected]> | 2018-03-24 22:44:51 +0000 | 
| commit | d0bb4ec4ecdfae4dfd9dd84aef905afb490013d5 (patch) | |
| tree | e9d1a21501e4d09bd0442e9eee829046b25a922d /src/engine-gpgsm.c | |
| parent | doc: python bindings howto (diff) | |
| parent | core: Need to increase an array in the gpg engine. (diff) | |
| download | gpgme-d0bb4ec4ecdfae4dfd9dd84aef905afb490013d5.tar.gz gpgme-d0bb4ec4ecdfae4dfd9dd84aef905afb490013d5.zip | |
Merge branch 'master' of ssh+git://playfair.gnupg.org/git/gpgme
Diffstat (limited to 'src/engine-gpgsm.c')
| -rw-r--r-- | src/engine-gpgsm.c | 35 | 
1 files changed, 35 insertions, 0 deletions
| diff --git a/src/engine-gpgsm.c b/src/engine-gpgsm.c index e337fedd..b8e44e7c 100644 --- a/src/engine-gpgsm.c +++ b/src/engine-gpgsm.c @@ -107,6 +107,8 @@ struct engine_gpgsm    gpgme_data_t inline_data;  /* Used to collect D lines.  */ +  char request_origin[10]; +    struct gpgme_io_cbs io_cbs;  }; @@ -521,6 +523,24 @@ gpgsm_new (void **engine, const char *file_name, const char *home_dir,  } +/* Copy flags from CTX into the engine object.  */ +static void +gpgsm_set_engine_flags (void *engine, const gpgme_ctx_t ctx) +{ +  engine_gpgsm_t gpgsm = engine; + +  if (ctx->request_origin) +    { +      if (strlen (ctx->request_origin) + 1 > sizeof gpgsm->request_origin) +        strcpy (gpgsm->request_origin, "xxx"); /* Too long  - force error */ +      else +        strcpy (gpgsm->request_origin, ctx->request_origin); +    } +  else +    *gpgsm->request_origin = 0; +} + +  static gpgme_error_t  gpgsm_set_locale (void *engine, int category, const char *value)  { @@ -1058,6 +1078,20 @@ start (engine_gpgsm_t gpgsm, const char *command)    int nfds;    int i; +  if (*gpgsm->request_origin) +    { +      char *cmd; + +      cmd = _gpgme_strconcat ("OPTION request-origin=", +                              gpgsm->request_origin, NULL); +      if (!cmd) +        return gpg_error_from_syserror (); +      err = gpgsm_assuan_simple_command (gpgsm, cmd, NULL, NULL); +      free (cmd); +      if (err && gpg_err_code (err) != GPG_ERR_UNKNOWN_OPTION) +        return err; +    } +    /* We need to know the fd used by assuan for reads.  We do this by       using the assumption that the first returned fd from       assuan_get_active_fds() is always this one.  */ @@ -2102,6 +2136,7 @@ struct engine_ops _gpgme_engine_ops_gpgsm =      gpgsm_set_colon_line_handler,      gpgsm_set_locale,      NULL,		/* set_protocol */ +    gpgsm_set_engine_flags,      gpgsm_decrypt,      gpgsm_delete,	/* decrypt_verify */      NULL,		/* edit */ | 
