diff options
Diffstat (limited to 'pigeonhole/src/lib-sieve/plugins/vnd.dovecot/debug/ext-debug.c')
-rw-r--r-- | pigeonhole/src/lib-sieve/plugins/vnd.dovecot/debug/ext-debug.c | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/pigeonhole/src/lib-sieve/plugins/vnd.dovecot/debug/ext-debug.c b/pigeonhole/src/lib-sieve/plugins/vnd.dovecot/debug/ext-debug.c new file mode 100644 index 0000000..2781e83 --- /dev/null +++ b/pigeonhole/src/lib-sieve/plugins/vnd.dovecot/debug/ext-debug.c @@ -0,0 +1,70 @@ +/* Copyright (c) 2002-2018 Pigeonhole authors, see the included COPYING file + */ + +/* Extension debug + * --------------- + * + * Authors: Stephan Bosch + * Specification: vendor-defined; spec-bosch-sieve-debug + * Implementation: full + * Status: experimental + * + */ + +#include "lib.h" +#include "array.h" + +#include "sieve-extensions.h" +#include "sieve-commands.h" +#include "sieve-comparators.h" +#include "sieve-match-types.h" +#include "sieve-address-parts.h" + +#include "sieve-validator.h" +#include "sieve-generator.h" +#include "sieve-binary.h" +#include "sieve-interpreter.h" +#include "sieve-dump.h" + +#include "ext-debug-common.h" + +/* + * Extension + */ + +static bool ext_debug_validator_load + (const struct sieve_extension *ext, struct sieve_validator *validator); +static bool ext_debug_interpreter_load + (const struct sieve_extension *ext ATTR_UNUSED, + const struct sieve_runtime_env *renv, sieve_size_t *address ATTR_UNUSED); + + +const struct sieve_extension_def vnd_debug_extension = { + .name = "vnd.dovecot.debug", + .validator_load = ext_debug_validator_load, + .interpreter_load = ext_debug_interpreter_load, + SIEVE_EXT_DEFINE_OPERATION(debug_log_operation), +}; + +static bool ext_debug_validator_load +(const struct sieve_extension *ext, struct sieve_validator *validator) +{ + /* Register new test */ + sieve_validator_register_command(validator, ext, &debug_log_command); + + return TRUE; +} + +static bool ext_debug_interpreter_load +(const struct sieve_extension *ext ATTR_UNUSED, + const struct sieve_runtime_env *renv, sieve_size_t *address ATTR_UNUSED) +{ + if ( renv->ehandler != NULL ) { + sieve_error_handler_accept_infolog(renv->ehandler, TRUE); + } + + return TRUE; +} + + + |