diff options
| author | Werner Koch <[email protected]> | 2018-04-17 06:33:44 +0000 | 
|---|---|---|
| committer | Werner Koch <[email protected]> | 2018-04-17 06:45:00 +0000 | 
| commit | a1f76b3b54b75a150fe272b804d85ffd40a507a6 (patch) | |
| tree | 3f0dd57d543391fc300206bcfebb5e9eb9bb10fd /src/gpgme.h.in | |
| parent | core: Tweak STATUS_FAILURE handling. (diff) | |
| download | gpgme-a1f76b3b54b75a150fe272b804d85ffd40a507a6.tar.gz gpgme-a1f76b3b54b75a150fe272b804d85ffd40a507a6.zip | |
core: Add extended versions of the encrypt functions.
* src/gpgme.h.in (gpgme_op_encrypt_ext_start) New.
(gpgme_op_encrypt_ext): New.
(gpgme_op_encrypt_sign_ext_start): New.
(gpgme_op_encrypt_sign_ext): New.
* src/libgpgme.vers, tests/run-encrypt.c: Add them.
* src/encrypt.c (encrypt_start): Add arg recpstring.
(gpgme_op_encrypt): Factor code out to ...
(gpgme_op_encrypt_ext): new function with new arg recpstring.
(gpgme_op_encrypt_start): Factor code out to ...
(gpgme_op_encrypt_ext_start): new function with new arg recpstring.
* src/encrypt-sign.c (encrypt_sign_start): Add arg recpstring.
(gpgme_op_encrypt_sign): Factor code out to ...
(gpgme_op_encrypt_sign_ext): new function with new arg recpstring.
(gpgme_op_encrypt_sign_start): Factor code out to ...
(gpgme_op_encrypt_sign_ext_start): new function with new arg
recpstring.
* src/engine-backend.h (struct engine_ops): Change fields encrypt and
encrypt_sign.
* src/engine.c (_gpgme_engine_op_encrypt): Add arg recpstring and pass
to engine.
(_gpgme_engine_op_encrypt_sign): Ditto.
* src/engine-gpg.c (append_args_from_recipients_string): New.
(gpg_encrypt): Add arg recpstring and call new function as needed.
(gpg_encrypt_sign): Ditto.
* src/engine-gpgsm.c (set_recipients_from_string): New.
(gpgsm_encrypt): Add arg recpstring and call new function as needed.
* src/engine-uiserver.c (set_recipients_from_string): New.
(uiserver_encrypt): Add arg recpstring and call new function as
needed.
* tests/run-encrypt.c (xstrdup): New.
(main): Add option --keystring.
* src/gpgme-json.c (get_keys): Simplify.
(op_encrypt): Modify to make use of the extended encrypt function.
--
This new feature can be used to avoid the need for a key lookup and
thus several extra calls to the backend.
Note that run-test uses a semicolon as delimiter because that make
testing the feature on the command line much easier.
Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'src/gpgme.h.in')
| -rw-r--r-- | src/gpgme.h.in | 30 | 
1 files changed, 27 insertions, 3 deletions
| diff --git a/src/gpgme.h.in b/src/gpgme.h.in index e3198798..8aba5baa 100644 --- a/src/gpgme.h.in +++ b/src/gpgme.h.in @@ -1274,10 +1274,22 @@ gpgme_encrypt_flags_t;     store the resulting ciphertext in CIPHER.  */  gpgme_error_t gpgme_op_encrypt_start (gpgme_ctx_t ctx, gpgme_key_t recp[],  				      gpgme_encrypt_flags_t flags, -				      gpgme_data_t plain, gpgme_data_t cipher); +				      gpgme_data_t plain, +                                      gpgme_data_t cipher);  gpgme_error_t gpgme_op_encrypt (gpgme_ctx_t ctx, gpgme_key_t recp[],  				gpgme_encrypt_flags_t flags, -				gpgme_data_t plain, gpgme_data_t cipher); +				gpgme_data_t plain, +                                gpgme_data_t cipher); +gpgme_error_t gpgme_op_encrypt_ext_start (gpgme_ctx_t ctx, gpgme_key_t recp[], +                                          const char *recpstring, +                                          gpgme_encrypt_flags_t flags, +                                          gpgme_data_t plain, +                                          gpgme_data_t cipher); +gpgme_error_t gpgme_op_encrypt_ext (gpgme_ctx_t ctx, gpgme_key_t recp[], +                                    const char *recpstring, +                                    gpgme_encrypt_flags_t flags, +                                    gpgme_data_t plain, +                                    gpgme_data_t cipher);  /* Encrypt plaintext PLAIN within CTX for the recipients RECP and     store the resulting ciphertext in CIPHER.  Also sign the ciphertext @@ -1289,7 +1301,19 @@ gpgme_error_t gpgme_op_encrypt_sign_start (gpgme_ctx_t ctx,  					   gpgme_data_t cipher);  gpgme_error_t gpgme_op_encrypt_sign (gpgme_ctx_t ctx, gpgme_key_t recp[],  				     gpgme_encrypt_flags_t flags, -				     gpgme_data_t plain, gpgme_data_t cipher); +				     gpgme_data_t plain, +                                     gpgme_data_t cipher); +gpgme_error_t gpgme_op_encrypt_sign_ext_start (gpgme_ctx_t ctx, +                                               gpgme_key_t recp[], +                                               const char *recpstring, +                                               gpgme_encrypt_flags_t flags, +                                               gpgme_data_t plain, +                                               gpgme_data_t cipher); +gpgme_error_t gpgme_op_encrypt_sign_ext (gpgme_ctx_t ctx, gpgme_key_t recp[], +                                         const char *recpstring, +                                         gpgme_encrypt_flags_t flags, +                                         gpgme_data_t plain, +                                         gpgme_data_t cipher);  /* | 
