dino/vapi/gpgme.vapi
2017-03-02 15:37:32 +01:00

1224 lines
31 KiB
Vala

/* libgpgme.vapi
*
* Copyright (C) 2009 Sebastian Reichel <sre@ring0.de>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*
*/
/**
* GPGME is an API wrapper around GnuPG, which parses the output of GnuPG.
*/
[CCode (lower_case_cprefix = "gpgme_", cheader_filename = "gpgme.h")]
namespace GPG {
/**
* EngineInfo as List
*/
[CCode (cname = "struct _gpgme_engine_info")]
public struct EngineInfo {
/**
* Next entry in the list
*/
EngineInfo* next;
/**
* The protocol ID
*/
Protocol protocol;
/**
* filename of the engine binary
*/
string file_name;
/**
* version string of the installed binary
*/
string version;
/**
* minimum version required for gpgme
*/
string req_version;
/**
* home directory to be used or null for default
*/
string? home_dir;
}
/**
* A Key from the Keyring
*/
[CCode (cname = "struct _gpgme_key", ref_function = "gpgme_key_ref", ref_function_void = true, unref_function = "gpgme_key_unref", free_function = "gpgme_key_release")]
public class Key {
public bool revoked;
public bool expired;
public bool disabled;
public bool invalid;
public bool can_encrypt;
public bool can_sign;
public bool can_certify;
public bool secret;
public bool can_authenticate;
public bool is_qualified;
public Protocol protocol;
/**
* If protocol is CMS, this string contains the issuer's serial
*/
public string issuer_serial;
/**
* If protocol is CMS, this string contains the issuer's name
*/
public string issuer_name;
/**
* If protocol is CMS, this string contains the issuer's ID
*/
public string issuer_id;
/**
* If protocol is OpenPGP, this field contains the owner trust level
*/
public Validity owner_trust;
/**
* The key's subkeys
*/
[CCode(array_null_terminated = true)]
public SubKey[] subkeys;
/**
* The key's user ids
*/
[CCode(array_null_terminated = true)]
public UserID[] uids;
public KeylistMode keylist_mode;
}
/**
* A signature notation
*/
[CCode (cname = "struct _gpgme_sig_notation")]
public struct SigNotation {
/**
* The next SigNotation from the list
*/
SigNotation* next;
/**
* If name is a null pointer value contains a policy url rather than a notation
*/
string? name;
/**
* The value of the notation data
*/
string value;
/**
* The length of the name of the notation data
*/
int name_len;
/**
* The length of the value of the notation data
*/
int value_len;
/**
* The accumulated flags
*/
SigNotationFlags flags;
/**
* notation data is human readable
*/
bool human_readable;
/**
* notation data is critical
*/
bool critical;
}
/**
* A subkey from a Key
*/
[CCode (cname = "struct _gpgme_subkey")]
public struct SubKey {
SubKey* next;
bool revoked;
bool expired;
bool disabled;
bool invalid;
bool can_encrypt;
bool can_sign;
bool can_certify;
bool secret;
bool can_authenticate;
bool is_qualified;
bool is_cardkey;
PublicKeyAlgorithm algo;
uint length;
string keyid;
/**
* Fingerprint of the key in hex form
*/
string fpr;
/**
* The creation timestamp.
* -1 = invalid,
* 0 = not available
*/
long timestamp;
/**
* The expiration timestamp.
* 0 = key does not expire
*/
long expires;
/**
* The serial number of the smartcard holding this key or null
*/
string? cardnumber;
}
/**
* A signature on a UserID
*/
[CCode (cname = "struct _gpgme_key_sig")]
public struct KeySig {
/**
* The next signature from the list
*/
KeySig* next;
bool invoked;
bool expired;
bool invalid;
bool exportable;
PublicKeyAlgorithm algo;
string keyid;
/**
* The creation timestamp.
* -1 = invalid,
* 0 = not available
*/
long timestamp;
/**
* The expiration timestamp.
* 0 = key does not expire
*/
long expires;
GPGError.ErrorCode status;
string uid;
string name;
string email;
string comment;
/**
* Crypto backend specific signature class
*/
uint sig_class;
SigNotation notations;
}
/**
* A UserID from a Key
*/
[CCode (cname = "struct _gpgme_user_id")]
public struct UserID {
/**
* The next UserID from the list
*/
UserID* next;
bool revoked;
bool invalid;
Validity validity;
string uid;
string name;
string email;
string comment;
KeySig signatures;
}
/**
* verify result of OP
*/
[CCode (cname = "struct _gpgme_op_verify_result")]
public struct VerifyResult {
Signature* signatures;
/**
* The original file name of the plaintext message, if available
*/
string? file_name;
}
/**
* sign result of OP
*/
[CCode (cname = "struct _gpgme_op_sign_result")]
public struct SignResult {
InvalidKey invalid_signers;
Signature* signatures;
}
/**
* encrypt result of OP
*/
[CCode (cname = "struct _gpgme_op_encrypt_result")]
public struct EncryptResult {
/**
* The list of invalid repipients
*/
InvalidKey invalid_signers;
}
/**
* decrypt result of OP
*/
[CCode (cname = "struct _gpgme_op_decrypt_result")]
public struct DecryptResult {
string unsupported_algorithm;
bool wrong_key_usage;
Recipient recipients;
string filename;
}
/**
* An receipient
*/
[CCode (cname = "struct _gpgme_recipient")]
public struct Recipient {
Recipient *next;
string keyid;
PublicKeyAlgorithm pubkey_algo;
GPGError.ErrorCode status;
}
/**
* list of invalid keys
*/
[CCode (cname = "struct _gpgme_invalid_key")]
public struct InvalidKey {
InvalidKey *next;
string fpr;
GPGError.ErrorCode reason;
}
/**
* A Signature
*/
[CCode (cname = "struct _gpgme_signature")]
public struct Signature {
/**
* The next signature in the list
*/
Signature *next;
/**
* A summary of the signature status
*/
Sigsum summary;
/**
* Fingerprint or key ID of the signature
*/
string fpr;
/**
* The Error status of the signature
*/
GPGError.ErrorCode status;
/**
* Notation data and policy URLs
*/
SigNotation notations;
/**
* Signature creation time
*/
ulong timestamp;
/**
* Signature expiration time or 0
*/
ulong exp_timestamp;
/**
* Key should not have been used for signing
*/
bool wrong_key_usage;
/**
* PKA status
*/
PKAStatus pka_trust;
/**
* Validity has been verified using the chain model
*/
bool chain_model;
/**
* Validity
*/
Validity validity;
/**
* Validity reason
*/
GPGError.ErrorCode validity_reason;
/**
* public key algorithm used to create the signature
*/
PublicKeyAlgorithm pubkey_algo;
/**
* The hash algorithm used to create the signature
*/
HashAlgorithm hash_algo;
/**
* The mailbox from the PKA information or null
*/
string? pka_adress;
}
/**
* PKA Status
*/
public enum PKAStatus {
NOT_AVAILABLE,
BAD,
OKAY,
RFU
}
/**
* Flags used for the summary field in a Signature
*/
[CCode (cname = "gpgme_sigsum_t", cprefix = "GPGME_SIGSUM_")]
public enum Sigsum {
/**
* The signature is fully valid
*/
VALID,
/**
* The signature is good
*/
GREEN,
/**
* The signature is bad
*/
RED,
/**
* One key has been revoked
*/
KEY_REVOKED,
/**
* One key has expired
*/
KEY_EXPIRED,
/**
* The signature has expired
*/
SIG_EXPIRED,
/**
* Can't verfiy - missing key
*/
KEY_MISSING,
/**
* CRL not available
*/
CRL_MISSING,
/**
* Available CRL is too old
*/
CRL_TOO_OLD,
/**
* A policy was not met
*/
BAD_POLICY,
/**
* A system error occured
*/
SYS_ERROR
}
/**
* Encoding modes of Data objects
*/
[CCode (cname = "gpgme_data_encoding_t", cprefix = "GPGME_DATA_ENCODING_")]
public enum DataEncoding {
/**
* Not specified
*/
NONE,
/**
* Binary encoded
*/
BINARY,
/**
* Base64 encoded
*/
BASE64,
/**
* Either PEM or OpenPGP Armor
*/
ARMOR,
/**
* LF delimited URL list
*/
URL,
/**
* LF percent escaped, delimited URL list
*/
URLESC,
/**
* Nul determined URL list
*/
URL0
}
/**
* Public Key Algorithms from libgcrypt
*/
[CCode (cname = "gpgme_pubkey_algo_t", cprefix = "GPGME_PK_")]
public enum PublicKeyAlgorithm {
RSA,
RSA_E,
RSA_S,
ELG_E,
DSA,
ELG
}
/**
* Hash Algorithms from libgcrypt
*/
[CCode (cname = "gpgme_hash_algo_t", cprefix = "GPGME_MD_")]
public enum HashAlgorithm {
NONE,
MD5,
SHA1,
RMD160,
MD2,
TIGER,
HAVAL,
SHA256,
SHA384,
SHA512,
MD4,
MD_CRC32,
MD_CRC32_RFC1510,
MD_CRC24_RFC2440
}
/**
* Signature modes
*/
[CCode (cname = "gpgme_sig_mode_t", cprefix = "GPGME_SIG_MODE_")]
public enum SigMode {
NORMAL,
DETACH,
CLEAR
}
/**
* Validities for a trust item or key
*/
[CCode (cname = "gpgme_validity_t", cprefix = "GPGME_VALIDITY_")]
public enum Validity {
UNKNOWN,
UNDEFINED,
NEVER,
MARGINAL,
FULL,
ULTIMATE
}
/**
* Protocols
*/
[CCode (cname = "gpgme_protocol_t", cprefix = "GPGME_PROTOCOL_")]
public enum Protocol {
/**
* Default Mode
*/
OpenPGP,
/**
* Cryptographic Message Syntax
*/
CMS,
/**
* Special code for gpgconf
*/
GPGCONF,
/**
* Low-level access to an Assuan server
*/
ASSUAN,
UNKNOWN
}
/**
* Keylist modes used by Context
*/
[CCode (cname = "gpgme_keylist_mode_t", cprefix = "GPGME_KEYLIST_MODE_")]
public enum KeylistMode {
LOCAL,
EXTERN,
SIGS,
SIG_NOTATIONS,
EPHEMERAL,
VALIDATE
}
/**
* Export modes used by Context
*/
[CCode (cname = "gpgme_export_mode_t", cprefix = "GPGME_EXPORT_MODE_")]
public enum ExportMode {
EXTERN
}
/**
* Audit log function flags
*/
[CCode (cprefix = "GPGME_AUDITLOG_")]
public enum AuditLogFlag {
HTML,
WITH_HELP
}
/**
* Signature notation flags
*/
[CCode (cname = "gpgme_sig_notation_flags_t", cprefix = "GPGME_SIG_NOTATION_")]
public enum SigNotationFlags {
HUMAN_READABLE,
CRITICAL
}
/**
* Encryption Flags
*/
[CCode (cname = "gpgme_encrypt_flags_t", cprefix = "GPGME_ENCRYPT_")]
public enum EncryptFlags {
ALWAYS_TRUST,
NO_ENCRYPT_TO
}
/**
* Edit Operation Stati
*/
[CCode (cname = "gpgme_status_code_t", cprefix = "GPGME_STATUS_")]
public enum StatusCode {
EOF,
ENTER,
LEAVE,
ABORT,
GOODSIG,
BADSIG,
ERRSIG,
BADARMOR,
RSA_OR_IDEA,
KEYEXPIRED,
KEYREVOKED,
TRUST_UNDEFINED,
TRUST_NEVER,
TRUST_MARGINAL,
TRUST_FULLY,
TRUST_ULTIMATE,
SHM_INFO,
SHM_GET,
SHM_GET_BOOL,
SHM_GET_HIDDEN,
NEED_PASSPHRASE,
VALIDSIG,
SIG_ID,
SIG_TO,
ENC_TO,
NODATA,
BAD_PASSPHRASE,
NO_PUBKEY,
NO_SECKEY,
NEED_PASSPHRASE_SYM,
DECRYPTION_FAILED,
DECRYPTION_OKAY,
MISSING_PASSPHRASE,
GOOD_PASSPHRASE,
GOODMDC,
BADMDC,
ERRMDC,
IMPORTED,
IMPORT_OK,
IMPORT_PROBLEM,
IMPORT_RES,
FILE_START,
FILE_DONE,
FILE_ERROR,
BEGIN_DECRYPTION,
END_DECRYPTION,
BEGIN_ENCRYPTION,
END_ENCRYPTION,
DELETE_PROBLEM,
GET_BOOL,
GET_LINE,
GET_HIDDEN,
GOT_IT,
PROGRESS,
SIG_CREATED,
SESSION_KEY,
NOTATION_NAME,
NOTATION_DATA,
POLICY_URL,
BEGIN_STREAM,
END_STREAM,
KEY_CREATED,
USERID_HINT,
UNEXPECTED,
INV_RECP,
NO_RECP,
ALREADY_SIGNED,
SIGEXPIRED,
EXPSIG,
EXPKEYSIG,
TRUNCATED,
ERROR,
NEWSIG,
REVKEYSIG,
SIG_SUBPACKET,
NEED_PASSPHRASE_PIN,
SC_OP_FAILURE,
SC_OP_SUCCESS,
CARDCTRL,
BACKUP_KEY_CREATED,
PKA_TRUST_BAD,
PKA_TRUST_GOOD,
PLAINTEXT
}
/**
* The Context object represents a GPG instance
*/
[Compact]
[CCode (cname = "struct gpgme_context", free_function = "gpgme_release", cprefix = "gpgme_")]
public class Context {
/**
* Create a new context, returns Error Status Code
*/
[CCode (cname = "gpgme_new")]
public static GPGError.ErrorCode Context(out Context ctx);
public GPGError.ErrorCode set_protocol(Protocol p);
public Protocol get_protocol();
public void set_armor(bool yes);
public bool get_armor();
public void set_textmode(bool yes);
public bool get_textmode();
public GPGError.ErrorCode set_keylist_mode(KeylistMode mode);
public KeylistMode get_keylist_mode();
/**
* Include up to nr_of_certs certificates in an S/MIME message,
* Use "-256" to use the backend's default.
*/
public void set_include_certs(int nr_of_certs = -256);
/**
* Return the number of certs to include in an S/MIME message
*/
public int get_include_certs();
/**
* Set callback function for requesting passphrase. hook_value will be
* passed as first argument.
*/
public void set_passphrase_cb(passphrase_callback cb, void* hook_value = null);
/**
* Get callback function and hook_value
*/
public void get_passphrase_cb(out passphrase_callback cb, out void* hook_value);
public GPGError.ErrorCode set_locale(int category, string val);
/**
* Get information about the configured engines. The returned data is valid
* until the next set_engine_info() call.
*/
[CCode (cname = "gpgme_ctx_get_engine_info")]
public EngineInfo* get_engine_info();
/**
* Set information about the configured engines. The string parameters may not
* be free'd after this calls, because they are not copied.
*/
[CCode (cname = "gpgme_ctx_set_engine_info")]
public GPGError.ErrorCode set_engine_info(Protocol proto, string file_name, string home_dir);
/**
* Delete all signers
*/
public void signers_clear();
/**
* Add key to list of signers
*/
public GPGError.ErrorCode signers_add(Key key);
/**
* Get the n-th signer's key
*/
public Key* signers_enum(int n);
/**
* Clear all notation data
*/
public void sig_notation_clear();
/**
* Add human readable notation data. If name is null,
* then value val should be a policy URL. The HUMAN_READABLE
* flag is forced to be true for notation data and false
* for policy URLs.
*/
public GPGError.ErrorCode sig_notation_add(string name, string val, SigNotationFlags flags);
/**
* Get sig notations
*/
public SigNotation* sig_notation_get();
/**
* Get key with the fingerprint FPR from the crypto backend.
* If SECRET is true, get the secret key.
*/
public GPGError.ErrorCode get_key(string fpr, out Key key, bool secret);
/**
* process the pending operation and, if hang is true, wait for
* the pending operation to finish.
*/
public Context* wait(out GPGError.ErrorCode status, bool hang);
/**
* Retrieve a pointer to the results of the signing operation
*/
public SignResult* op_sign_result();
/**
* Sign the plaintext PLAIN and store the signature in SIG.
*/
public GPGError.ErrorCode op_sign(Data plain, Data sig, SigMode mode);
/**
* Retrieve a pointer to the result of the verify operation
*/
public VerifyResult* op_verify_result();
/**
* Verify that SIG is a valid signature for SIGNED_TEXT.
*/
public GPGError.ErrorCode op_verify(Data sig, Data signed_text, Data? plaintext);
/**
* Retrieve a pointer to the result of the encrypt operation
*/
public EncryptResult* op_encrypt_result();
/**
* Encrypt plaintext PLAIN for the recipients RECP and store the
* resulting ciphertext in CIPHER.
*/
public GPGError.ErrorCode op_encrypt([CCode (array_length = false)] Key[] recp, EncryptFlags flags, Data plain, Data cipher);
/**
* Retrieve a pointer to the result of the decrypt operation
*/
public DecryptResult* op_decrypt_result();
/**
* Decrypt ciphertext CIPHER and store the resulting plaintext
* in PLAIN.
*/
public GPGError.ErrorCode op_decrypt(Data cipher, Data plain);
/**
* Export the keys found by PATTERN into KEYDATA. If PATTERN is
* NULL all keys will be exported.
*/
public GPGError.ErrorCode op_export(string? pattern, ExportMode mode, Data keydata);
/**
* Import the keys in KEYDATA.
*/
public GPGError.ErrorCode op_import(Data keydata);
/**
* Get result of last op_import.
*/
public unowned ImportResult op_import_result();
/**
* Initiates a key listing operation. It sets everything up, so that
* subsequent invocations of op_keylist_next() return the keys in the list.
*
* If pattern is NULL, all available keys are returned. Otherwise, pattern
* contains an engine specific expression that is used to limit the list to
* all keys matching the pattern.
*
* If secret_only is not 0, the list is restricted to secret keys only.
*
* The context will be busy until either all keys are received (and
* op_keylist_next() returns GPG_ERR_EOF), or gpgme_op_keylist_end is called
* to finish the operation.
*
* The function returns the error code GPG_ERR_INV_VALUE if ctx is not a valid
* pointer, and passes through any errors that are reported by the crypto engine
* support routines.
*/
public GPGError.ErrorCode op_keylist_start(string? pattern = null, int secret_only = 0);
/**
* returns the next key in the list created by a previous op_keylist_start()
* operation in the context ctx. The key will have one reference for the user.
*
* If the last key in the list has already been returned, op_keylist_next()
* returns GPG_ERR_EOF.
*
* The function returns the error code GPG_ERR_INV_VALUE if ctx or r_key is
* not a valid pointer, and GPG_ERR_ENOMEM if there is not enough memory for
* the operation.
*/
public GPGError.ErrorCode op_keylist_next(out Key key);
/**
* ends a pending key list operation in the context.
*
* After the operation completed successfully, the result of the key listing
* operation can be retrieved with op_keylist_result().
*
* The function returns the error code GPG_ERR_INV_VALUE if ctx is not a valid
* pointer, and GPG_ERR_ENOMEM if at some time during the operation there was
* not enough memory available.
*/
public GPGError.ErrorCode op_keylist_end();
/**
* The function op_keylist_result() returns a KeylistResult holding the result of
* a op_keylist_*() operation. The returned KeylistResult is only valid if the last
* operation on the context was a key listing operation, and if this operation
* finished successfully. The returned KeylistResult is only valid until the next
* operation is started on the context.
*/
public KeylistResult op_keylist_result();
}
[Flags]
[CCode (cname="unsigned int")]
public enum ImportStatusFlags {
/**
* The key was new.
*/
[CCode (cname = "GPGME_IMPORT_NEW")]
NEW,
/**
* The key contained new user IDs.
*/
[CCode (cname = "GPGME_IMPORT_UID")]
UID,
/**
* The key contained new signatures.
*/
[CCode (cname = "GPGME_IMPORT_SIG")]
SIG,
/**
* The key contained new sub keys.
*/
[CCode (cname = "GPGME_IMPORT_SUBKEY")]
SUBKEY,
/**
* The key contained a secret key.
*/
[CCode (cname = "GPGME_IMPORT_SECRET")]
SECRET
}
[Compact]
[CCode (cname = "struct _gpgme_import_status")]
public class ImportStatus {
/**
* This is a pointer to the next status structure in the linked list, or null
* if this is the last element.
*/
public ImportStatus? next;
/**
* fingerprint of the key that was considered.
*/
public string fpr;
/**
* If the import was not successful, this is the error value that caused the
* import to fail. Otherwise the error code is GPG_ERR_NO_ERROR.
*/
public GPGError.ErrorCode result;
/**
* Flags what parts of the key have been imported. May be 0, if the key has
* already been known.
*/
public ImportStatusFlags status;
}
[Compact]
[CCode (cname = "struct _gpgme_op_import_result")]
public class ImportResult {
/**
* The total number of considered keys.
*/
public int considered;
/**
* The number of keys without user ID.
*/
public int no_user_id;
/**
* The total number of imported keys.
*/
public int imported;
/**
* The number of imported RSA keys.
*/
public int imported_rsa;
/**
* The number of unchanged keys.
*/
public int unchanged;
/**
* The number of new user IDs.
*/
public int new_user_ids;
/**
* The number of new sub keys.
*/
public int new_sub_keys;
/**
* The number of new signatures.
*/
public int new_signatures;
/**
* The number of new revocations.
*/
public int new_revocations;
/**
* The total number of secret keys read.
*/
public int secret_read;
/**
* The number of imported secret keys.
*/
public int secret_imported;
/**
* The number of unchanged secret keys.
*/
public int secret_unchanged;
/**
* The number of keys not imported.
*/
public int not_imported;
/*
* A linked list of ImportStatus objects which
* contains more information about the keys for
* which an import was attempted.
*/
public ImportStatus imports;
}
[Compact]
[CCode (cname = "struct _gpgme_op_keylist_result")]
public class KeylistResult {
uint truncated;
}
/**
* Data Object, contains encrypted and/or unencrypted data
*/
[Compact]
[CCode (cname = "struct gpgme_data", free_function = "gpgme_data_release", cprefix = "gpgme_data_")]
public class Data {
/**
* Create a new data buffer, returns Error Status Code.
*/
[CCode (cname = "gpgme_data_new")]
public static GPGError.ErrorCode create(out Data d);
/**
* Create a new data buffer filled with SIZE bytes starting
* from BUFFER. If COPY is false, COPYING is delayed until
* necessary and the data is taken from the original location
* when needed. Returns Error Status Code.
*/
[CCode (cname = "gpgme_data_new_from_mem")]
public static GPGError.ErrorCode create_from_memory(out Data d, uint8[] buffer, bool copy);
/**
* Create a new data buffer filled with the content of the file.
* COPY must be non-zero. For delayed read, please use
* create_from_fd or create_from stream instead.
*/
[CCode (cname = "gpgme_data_new_from_file")]
public static GPGError.ErrorCode create_from_file(out Data d, string filename, int copy = 1);
/**
* Destroy the object and return a pointer to its content.
* It's size is returned in R_LEN.
*/
[CCode (cname = "gpgme_data_release_and_get_mem")]
public string release_and_get_mem(out size_t len);
/**
* Read up to SIZE bytes into buffer BUFFER from the data object.
* Return the number of characters read, 0 on EOF and -1 on error.
* If an error occurs, errno is set.
*/
public ssize_t read(uint8[] buf);
/**
* Write up to SIZE bytes from buffer BUFFER to the data object.
* Return the number of characters written, or -1 on error.
* If an error occurs, errno is set.
*/
public ssize_t write(uint8[] buf);
/**
* Set the current position from where the next read or write
* starts in the data object to OFFSET, relativ to WHENCE.
*/
public long seek(long offset, int whence=0);
/**
* Get the encoding attribute of the buffer
*/
public DataEncoding *get_encoding();
/**
* Set the encoding attribute of the buffer to ENC
*/
public GPGError.ErrorCode set_encoding(DataEncoding enc);
}
[CCode (cname = "gpgme_get_protocol_name")]
public unowned string get_protocol_name(Protocol p);
[CCode (cname = "gpgme_pubkey_algo_name")]
public unowned string get_public_key_algorithm_name(PublicKeyAlgorithm algo);
[CCode (cname = "gpgme_hash_algo_name")]
public unowned string get_hash_algorithm_name(HashAlgorithm algo);
[CCode (cname = "gpgme_passphrase_cb_t", has_target = false)]
public delegate GPGError.ErrorCode passphrase_callback(void* hook, string uid_hint, string passphrase_info, bool prev_was_bad, int fd);
/**
* Get version of libgpgme
* Always call this function before using gpgme, it initializes some stuff
*/
[CCode (cname = "gpgme_check_version")]
public unowned string check_version(string? required_version = null);
/**
* Verify that the engine implementing proto is installed and
* available.
*/
[CCode (cname = "gpgme_engine_check_version")]
public GPGError.ErrorCode engine_check_version(Protocol proto);
/**
* Get information about the configured engines. The returned data is valid
* until the next set_engine_info() call.
*/
[CCode (cname = "gpgme_get_engine_information")]
public GPGError.ErrorCode get_engine_information(out EngineInfo engine_info);
/**
* Return the error string for ERR in the user-supplied buffer BUF
* of size BUFLEN. This function is thread-safe, if a thread-safe
* strerror_r() function is provided by the system. If the function
* succeeds, 0 is returned and BUF contains the string describing
* the error. If the buffer was not large enough, ERANGE is returned
* and BUF contains as much of the beginning of the error string as
* fits into the buffer. Returns Error Status Code.
*/
[CCode (cname = "gpgme_strerror_r")]
public int strerror_r(GPGError.ErrorCode err, uint8[] buf);
/**
* Like strerror_r, but returns a pointer to the string. This method
* is not thread safe!
*/
[CCode (cname = "gpgme_strerror")]
public unowned string strerror(GPGError.ErrorCode err);
}