diff options
| author | Andre Heinecke <[email protected]> | 2016-02-22 17:28:08 +0000 | 
|---|---|---|
| committer | Andre Heinecke <[email protected]> | 2016-02-22 18:01:37 +0000 | 
| commit | 0855a1296a1908016f011eb5e6552854ac53e63a (patch) | |
| tree | ae662e7201a7d60d0e7733532ebded629cfacb94 /lang/cpp/src/callbacks.cpp | |
| parent | Fix possible _SC_OPEN_MAX max problem on AIX. (diff) | |
| download | gpgme-0855a1296a1908016f011eb5e6552854ac53e63a.tar.gz gpgme-0855a1296a1908016f011eb5e6552854ac53e63a.zip | |
Initial checkin of gpgmepp sources
Based on git.kde.org/pim/gpgmepp rev. 0e3ebc02
* lang/cpp/src/assuanresult.cpp,
 lang/cpp/src/assuanresult.h,
 lang/cpp/src/callbacks.cpp,
 lang/cpp/src/callbacks.h,
 lang/cpp/src/configuration.cpp,
 lang/cpp/src/configuration.h,
 lang/cpp/src/context.cpp,
 lang/cpp/src/context.h,
 lang/cpp/src/context_glib.cpp,
 lang/cpp/src/context_p.h,
 lang/cpp/src/context_qt.cpp,
 lang/cpp/src/context_vanilla.cpp,
 lang/cpp/src/data.cpp,
 lang/cpp/src/data.h,
 lang/cpp/src/data_p.h,
 lang/cpp/src/decryptionresult.cpp,
 lang/cpp/src/decryptionresult.h,
 lang/cpp/src/defaultassuantransaction.cpp,
 lang/cpp/src/defaultassuantransaction.h,
 lang/cpp/src/editinteractor.cpp,
 lang/cpp/src/editinteractor.h,
 lang/cpp/src/encryptionresult.cpp,
 lang/cpp/src/encryptionresult.h,
 lang/cpp/src/engineinfo.cpp,
 lang/cpp/src/engineinfo.h,
 lang/cpp/src/error.h,
 lang/cpp/src/eventloopinteractor.cpp,
 lang/cpp/src/eventloopinteractor.h,
 lang/cpp/src/exception.cpp,
 lang/cpp/src/exception.h,
 lang/cpp/src/global.h,
 lang/cpp/src/gpgadduserideditinteractor.cpp,
 lang/cpp/src/gpgadduserideditinteractor.h,
 lang/cpp/src/gpgagentgetinfoassuantransaction.cpp,
 lang/cpp/src/gpgagentgetinfoassuantransaction.h,
 lang/cpp/src/gpgmefw.h,
 lang/cpp/src/gpgmepp_export.h,
 lang/cpp/src/gpgsetexpirytimeeditinteractor.cpp,
 lang/cpp/src/gpgsetexpirytimeeditinteractor.h,
 lang/cpp/src/gpgsetownertrusteditinteractor.cpp,
 lang/cpp/src/gpgsetownertrusteditinteractor.h,
 lang/cpp/src/gpgsignkeyeditinteractor.cpp,
 lang/cpp/src/gpgsignkeyeditinteractor.h,
 lang/cpp/src/importresult.cpp,
 lang/cpp/src/importresult.h,
 lang/cpp/src/key.cpp,
 lang/cpp/src/key.h,
 lang/cpp/src/keygenerationresult.cpp,
 lang/cpp/src/keygenerationresult.h,
 lang/cpp/src/keylistresult.cpp,
 lang/cpp/src/keylistresult.h,
 lang/cpp/src/notation.h,
 lang/cpp/src/result.h,
 lang/cpp/src/result_p.h,
 lang/cpp/src/scdgetinfoassuantransaction.cpp,
 lang/cpp/src/scdgetinfoassuantransaction.h,
 lang/cpp/src/signingresult.cpp,
 lang/cpp/src/signingresult.h,
 lang/cpp/src/trustitem.cpp,
 lang/cpp/src/trustitem.h,
 lang/cpp/src/util.h,
 lang/cpp/src/verificationresult.cpp,
 lang/cpp/src/verificationresult.h,
 lang/cpp/src/vfsmountresult.cpp,
 lang/cpp/src/vfsmountresult.h,
 lang/cpp/src/interfaces/assuantransaction.h,
 lang/cpp/src/interfaces/dataprovider.h,
 lang/cpp/src/interfaces/passphraseprovider.h,
 lang/cpp/src/interfaces/progressprovider.h: New.
Diffstat (limited to '')
| -rw-r--r-- | lang/cpp/src/callbacks.cpp | 187 | 
1 files changed, 187 insertions, 0 deletions
| diff --git a/lang/cpp/src/callbacks.cpp b/lang/cpp/src/callbacks.cpp new file mode 100644 index 00000000..091975d7 --- /dev/null +++ b/lang/cpp/src/callbacks.cpp @@ -0,0 +1,187 @@ +/* +  callbacks.cpp - callback targets for internal use: +  Copyright (C) 2003,2004 Klarälvdalens Datakonsult AB + +  This file is part of GPGME++. + +  GPGME++ is free software; you can redistribute it and/or +  modify it under the terms of the GNU Library General Public +  License as published by the Free Software Foundation; either +  version 2 of the License, or (at your option) any later version. + +  GPGME++ is distributed in the hope that it will be useful, +  but WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +  GNU Library General Public License for more details. + +  You should have received a copy of the GNU Library General Public License +  along with GPGME++; see the file COPYING.LIB.  If not, write to the +  Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, +  Boston, MA 02110-1301, USA. +*/ + +#include <config-gpgme++.h> + +#include "callbacks.h" +#include "util.h" + +#include <interfaces/progressprovider.h> +#include <interfaces/passphraseprovider.h> +#include <interfaces/dataprovider.h> +#include <error.h> + +#include <gpgme.h> +#include <gpg-error.h> + +#include <cassert> +#include <cerrno> +#include <cstring> +#include <unistd.h> +#include <stdlib.h> + +#ifndef HAVE_GPGME_SSIZE_T +# define gpgme_ssize_t ssize_t +#endif + +#ifndef HAVE_GPGME_OFF_T +# define gpgme_off_t off_t +#endif + +static inline gpgme_error_t make_err_from_syserror() +{ +#ifdef HAVE_GPGME_GPG_ERROR_WRAPPERS +    return gpgme_error_from_syserror(); +#else +    return gpg_error_from_syserror(); +#endif +} + +using GpgME::ProgressProvider; +using GpgME::PassphraseProvider; +using GpgME::DataProvider; + +void progress_callback(void *opaque, const char *what, +                       int type, int current, int total) +{ +    ProgressProvider *provider = static_cast<ProgressProvider *>(opaque); +    if (provider) { +        provider->showProgress(what, type, current, total); +    } +} + +/* To avoid that a compiler optimizes certain memset calls away, these +   macros may be used instead. */ +#define wipememory2(_ptr,_set,_len) do { \ +        volatile char *_vptr=(volatile char *)(_ptr); \ +        size_t _vlen=(_len); \ +        while(_vlen) { *_vptr=(_set); _vptr++; _vlen--; } \ +    } while(0) +#define wipememory(_ptr,_len) wipememory2(_ptr,0,_len) + +gpgme_error_t passphrase_callback(void *opaque, const char *uid_hint, const char *desc, +                                  int prev_was_bad, int fd) +{ +    PassphraseProvider *provider = static_cast<PassphraseProvider *>(opaque); +    bool canceled = false; +    gpgme_error_t err = GPG_ERR_NO_ERROR; +    char *passphrase = provider ? provider->getPassphrase(uid_hint, desc, prev_was_bad, canceled) : 0 ; +    if (canceled) { +        err = make_error(GPG_ERR_CANCELED); +    } else { +        if (passphrase && *passphrase) { +            size_t passphrase_length = std::strlen(passphrase); +            size_t written = 0; +            do { +#ifdef HAVE_GPGME_IO_READWRITE +                ssize_t now_written = gpgme_io_write(fd, passphrase + written, passphrase_length - written); +#else +                ssize_t now_written = write(fd, passphrase + written, passphrase_length - written); +#endif +                if (now_written < 0) { +                    err = make_err_from_syserror(); +                    break; +                } +                written += now_written; +            } while (written < passphrase_length); +        } +    } + +    if (passphrase && *passphrase) { +        wipememory(passphrase, std::strlen(passphrase)); +    } +    free(passphrase); +#ifdef HAVE_GPGME_IO_READWRITE +    gpgme_io_write(fd, "\n", 1); +#else +    write(fd, "\n", 1); +#endif +    return err; +} + +static gpgme_ssize_t +data_read_callback(void *opaque, void *buf, size_t buflen) +{ +    DataProvider *provider = static_cast<DataProvider *>(opaque); +    if (!provider) { +#ifdef HAVE_GPGME_GPG_ERROR_WRAPPERS +        gpgme_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#else +        gpg_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#endif +        return -1; +    } +    return (gpgme_ssize_t)provider->read(buf, buflen); +} + +static gpgme_ssize_t +data_write_callback(void *opaque, const void *buf, size_t buflen) +{ +    DataProvider *provider = static_cast<DataProvider *>(opaque); +    if (!provider) { +#ifdef HAVE_GPGME_GPG_ERROR_WRAPPERS +        gpgme_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#else +        gpg_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#endif +        return -1; +    } +    return (gpgme_ssize_t)provider->write(buf, buflen); +} + +static gpgme_off_t +data_seek_callback(void *opaque, gpgme_off_t offset, int whence) +{ +    DataProvider *provider = static_cast<DataProvider *>(opaque); +    if (!provider) { +#ifdef HAVE_GPGME_GPG_ERROR_WRAPPERS +        gpgme_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#else +        gpg_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#endif +        return -1; +    } +    if (whence != SEEK_SET && whence != SEEK_CUR && whence != SEEK_END) { +#ifdef HAVE_GPGME_GPG_ERROR_WRAPPERS +        gpgme_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#else +        gpg_err_set_errno(gpgme_err_code_to_errno(GPG_ERR_EINVAL)); +#endif +        return -1; +    } +    return provider->seek((off_t)offset, whence); +} + +static void data_release_callback(void *opaque) +{ +    DataProvider *provider = static_cast<DataProvider *>(opaque); +    if (provider) { +        provider->release(); +    } +} + +const gpgme_data_cbs GpgME::data_provider_callbacks = { +    &data_read_callback, +    &data_write_callback, +    &data_seek_callback, +    &data_release_callback +}; | 
