mirror of
https://github.com/php-gnupg/php-gnupg.git
synced 2024-11-22 14:27:09 +00:00
added seterrormode
fixed freeing of encryptkeys
This commit is contained in:
parent
6d0723bba0
commit
315ad0ecbf
2 changed files with 48 additions and 4 deletions
49
gnupg.c
49
gnupg.c
|
@ -54,7 +54,7 @@ static zend_object_handlers gnupg_object_handlers;
|
||||||
|
|
||||||
#define GNUPG_ERR(error) \
|
#define GNUPG_ERR(error) \
|
||||||
if(intern){ \
|
if(intern){ \
|
||||||
switch (intern->error_mode) { \
|
switch (intern->errormode) { \
|
||||||
case 1: \
|
case 1: \
|
||||||
php_error_docref(NULL TSRMLS_CC, E_WARNING, (char*)error); \
|
php_error_docref(NULL TSRMLS_CC, E_WARNING, (char*)error); \
|
||||||
break; \
|
break; \
|
||||||
|
@ -77,7 +77,7 @@ static void gnupg_free_encryptkeys(gnupg_object *intern TSRMLS_DC){
|
||||||
for(idx=0;idx<intern->encrypt_size;idx++){
|
for(idx=0;idx<intern->encrypt_size;idx++){
|
||||||
gpgme_key_unref (intern->encryptkeys[idx]);
|
gpgme_key_unref (intern->encryptkeys[idx]);
|
||||||
}
|
}
|
||||||
erealloc(intern->encryptkeys,0);
|
efree(erealloc(intern->encryptkeys,0));
|
||||||
intern->encryptkeys = NULL;
|
intern->encryptkeys = NULL;
|
||||||
intern->encrypt_size = 0;
|
intern->encrypt_size = 0;
|
||||||
}
|
}
|
||||||
|
@ -120,6 +120,7 @@ static void gnupg_res_init(gnupg_object *intern TSRMLS_DC){
|
||||||
intern->encrypt_size = 0;
|
intern->encrypt_size = 0;
|
||||||
intern->signmode = GPGME_SIG_MODE_CLEAR;
|
intern->signmode = GPGME_SIG_MODE_CLEAR;
|
||||||
intern->errortxt = NULL;
|
intern->errortxt = NULL;
|
||||||
|
intern->errormode = 3;
|
||||||
ALLOC_HASHTABLE (intern->signkeys);
|
ALLOC_HASHTABLE (intern->signkeys);
|
||||||
zend_hash_init (intern->signkeys, 0, NULL, NULL, 0);
|
zend_hash_init (intern->signkeys, 0, NULL, NULL, 0);
|
||||||
ALLOC_HASHTABLE (intern->decryptkeys);
|
ALLOC_HASHTABLE (intern->decryptkeys);
|
||||||
|
@ -192,6 +193,7 @@ static zend_function_entry gnupg_methods[] = {
|
||||||
ZEND_ME(gnupg, deletekey, NULL, ZEND_ACC_PUBLIC)
|
ZEND_ME(gnupg, deletekey, NULL, ZEND_ACC_PUBLIC)
|
||||||
ZEND_ME(gnupg, gettrustlist, NULL, ZEND_ACC_PUBLIC)
|
ZEND_ME(gnupg, gettrustlist, NULL, ZEND_ACC_PUBLIC)
|
||||||
ZEND_ME(gnupg, listsignatures, NULL, ZEND_ACC_PUBLIC)
|
ZEND_ME(gnupg, listsignatures, NULL, ZEND_ACC_PUBLIC)
|
||||||
|
ZEND_ME(gnupg, seterrormode, NULL, ZEND_ACC_PUBLIC)
|
||||||
{NULL, NULL, NULL}
|
{NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
#endif /* ZEND_ENGINE_2 */
|
#endif /* ZEND_ENGINE_2 */
|
||||||
|
@ -219,6 +221,7 @@ static zend_function_entry gnupg_functions[] = {
|
||||||
PHP_FE(gnupg_deletekey, NULL)
|
PHP_FE(gnupg_deletekey, NULL)
|
||||||
PHP_FE(gnupg_gettrustlist, NULL)
|
PHP_FE(gnupg_gettrustlist, NULL)
|
||||||
PHP_FE(gnupg_listsignatures, NULL)
|
PHP_FE(gnupg_listsignatures, NULL)
|
||||||
|
PHP_FE(gnupg_seterrormode, NULL)
|
||||||
{NULL, NULL, NULL}
|
{NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
@ -297,6 +300,9 @@ PHP_MINIT_FUNCTION(gnupg)
|
||||||
gnupg_declare_long_constant("SIGSUM_CRL_TOO_OLD", GPGME_SIGSUM_CRL_TOO_OLD TSRMLS_DC);
|
gnupg_declare_long_constant("SIGSUM_CRL_TOO_OLD", GPGME_SIGSUM_CRL_TOO_OLD TSRMLS_DC);
|
||||||
gnupg_declare_long_constant("SIGSUM_BAD_POLICY", GPGME_SIGSUM_BAD_POLICY TSRMLS_DC);
|
gnupg_declare_long_constant("SIGSUM_BAD_POLICY", GPGME_SIGSUM_BAD_POLICY TSRMLS_DC);
|
||||||
gnupg_declare_long_constant("SIGSUM_SYS_ERROR", GPGME_SIGSUM_SYS_ERROR TSRMLS_DC);
|
gnupg_declare_long_constant("SIGSUM_SYS_ERROR", GPGME_SIGSUM_SYS_ERROR TSRMLS_DC);
|
||||||
|
gnupg_declare_long_constant("ERROR_WARNING", 1);
|
||||||
|
gnupg_declare_long_constant("ERROR_EXCEPTION", 2);
|
||||||
|
gnupg_declare_long_constant("ERROR_SILENT", 3);
|
||||||
#endif
|
#endif
|
||||||
REGISTER_LONG_CONSTANT("GNUPG_SIG_MODE_NORMAL", GPGME_SIG_MODE_NORMAL, CONST_CS | CONST_PERSISTENT);
|
REGISTER_LONG_CONSTANT("GNUPG_SIG_MODE_NORMAL", GPGME_SIG_MODE_NORMAL, CONST_CS | CONST_PERSISTENT);
|
||||||
REGISTER_LONG_CONSTANT("GNUPG_SIG_MODE_DETACH", GPGME_SIG_MODE_DETACH, CONST_CS | CONST_PERSISTENT);
|
REGISTER_LONG_CONSTANT("GNUPG_SIG_MODE_DETACH", GPGME_SIG_MODE_DETACH, CONST_CS | CONST_PERSISTENT);
|
||||||
|
@ -320,6 +326,9 @@ PHP_MINIT_FUNCTION(gnupg)
|
||||||
REGISTER_LONG_CONSTANT("GNUPG_SIGSUM_CRL_TOO_OLD", GPGME_SIGSUM_CRL_TOO_OLD, CONST_CS | CONST_PERSISTENT);
|
REGISTER_LONG_CONSTANT("GNUPG_SIGSUM_CRL_TOO_OLD", GPGME_SIGSUM_CRL_TOO_OLD, CONST_CS | CONST_PERSISTENT);
|
||||||
REGISTER_LONG_CONSTANT("GNUPG_SIGSUM_BAD_POLICY", GPGME_SIGSUM_BAD_POLICY, CONST_CS | CONST_PERSISTENT);
|
REGISTER_LONG_CONSTANT("GNUPG_SIGSUM_BAD_POLICY", GPGME_SIGSUM_BAD_POLICY, CONST_CS | CONST_PERSISTENT);
|
||||||
REGISTER_LONG_CONSTANT("GNUPG_SIGSUM_SYS_ERROR", GPGME_SIGSUM_SYS_ERROR, CONST_CS | CONST_PERSISTENT);
|
REGISTER_LONG_CONSTANT("GNUPG_SIGSUM_SYS_ERROR", GPGME_SIGSUM_SYS_ERROR, CONST_CS | CONST_PERSISTENT);
|
||||||
|
REGISTER_LONG_CONSTANT("GNUPG_ERROR_WARNING", 1, CONST_CS | CONST_PERSISTENT);
|
||||||
|
REGISTER_LONG_CONSTANT("GNUPG_ERROR_EXCEPTION", 2, CONST_CS | CONST_PERSISTENT);
|
||||||
|
REGISTER_LONG_CONSTANT("GNUPG_ERROR_SILENT", 3, CONST_CS | CONST_PERSISTENT);
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
@ -461,6 +470,39 @@ PHP_FUNCTION(gnupg_setarmor){
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
|
/* {{{ proto bool gnupg_seterrormode(int errormde) */
|
||||||
|
PHP_FUNCTION(gnupg_seterrormode){
|
||||||
|
int errormode;
|
||||||
|
|
||||||
|
GNUPG_GETOBJ();
|
||||||
|
|
||||||
|
if(this){
|
||||||
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &errormode) == FAILURE){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "rl", &res, &errormode) == FAILURE){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ZEND_FETCH_RESOURCE(intern,gnupg_object *, &res, -1, "ctx", le_gnupg);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(errormode){
|
||||||
|
case 1: /* warning */
|
||||||
|
case 3: /* silent */
|
||||||
|
intern->errormode = errormode;
|
||||||
|
break;
|
||||||
|
#ifdef ZEND_ENGINE_2
|
||||||
|
case 2: /* exception */
|
||||||
|
intern->errormode = errormode;
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
GNUPG_ERROR("invalid errormode");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* }}} */
|
||||||
|
|
||||||
/* {{{ proto bool gnupg_setsignmode(int signmode)
|
/* {{{ proto bool gnupg_setsignmode(int signmode)
|
||||||
* sets the mode for signing operations
|
* sets the mode for signing operations
|
||||||
*/
|
*/
|
||||||
|
@ -484,10 +526,11 @@ PHP_FUNCTION(gnupg_setsignmode){
|
||||||
case GPGME_SIG_MODE_DETACH:
|
case GPGME_SIG_MODE_DETACH:
|
||||||
case GPGME_SIG_MODE_CLEAR:
|
case GPGME_SIG_MODE_CLEAR:
|
||||||
intern->signmode = signmode;
|
intern->signmode = signmode;
|
||||||
RETURN_TRUE;
|
RETVAL_TRUE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
GNUPG_ERR("invalid signmode");
|
GNUPG_ERR("invalid signmode");
|
||||||
|
RETVAL_FALSE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,7 +40,7 @@ typedef struct gnupg_object{
|
||||||
zend_object zo;
|
zend_object zo;
|
||||||
gpgme_ctx_t ctx;
|
gpgme_ctx_t ctx;
|
||||||
gpgme_error_t err;
|
gpgme_error_t err;
|
||||||
int error_mode;
|
int errormode;
|
||||||
char* errortxt;
|
char* errortxt;
|
||||||
int signmode;
|
int signmode;
|
||||||
gpgme_key_t *encryptkeys;
|
gpgme_key_t *encryptkeys;
|
||||||
|
@ -79,6 +79,7 @@ PHP_FUNCTION(gnupg_adddecryptkey);
|
||||||
PHP_FUNCTION(gnupg_deletekey);
|
PHP_FUNCTION(gnupg_deletekey);
|
||||||
PHP_FUNCTION(gnupg_gettrustlist);
|
PHP_FUNCTION(gnupg_gettrustlist);
|
||||||
PHP_FUNCTION(gnupg_listsignatures);
|
PHP_FUNCTION(gnupg_listsignatures);
|
||||||
|
PHP_FUNCTION(gnupg_seterrormode);
|
||||||
|
|
||||||
#ifdef ZTS
|
#ifdef ZTS
|
||||||
#define GNUPG_G(v) TSRMG(gnupg_globals_id, zend_gnupg_globals *, v)
|
#define GNUPG_G(v) TSRMG(gnupg_globals_id, zend_gnupg_globals *, v)
|
||||||
|
|
Loading…
Reference in a new issue