Blame ext/mod_var_remote_addr_port.c

Packit Service 384592
/*
Packit Service 384592
* ModSecurity for Apache 2.x, http://www.modsecurity.org/
Packit Service 384592
* Copyright (c) 2004-2013 Trustwave Holdings, Inc. (http://www.trustwave.com/)
Packit Service 384592
*
Packit Service 384592
* You may not use this file except in compliance with
Packit Service 384592
* the License.  You may obtain a copy of the License at
Packit Service 384592
*
Packit Service 384592
*     http://www.apache.org/licenses/LICENSE-2.0
Packit Service 384592
*
Packit Service 384592
* If any of the files related to licensing are missing or if you have any
Packit Service 384592
* other questions related to licensing please contact Trustwave Holdings, Inc.
Packit Service 384592
* directly using the email address security@modsecurity.org.
Packit Service 384592
*/
Packit Service 384592
Packit Service 384592
#include "httpd.h"
Packit Service 384592
#include "http_core.h"
Packit Service 384592
#include "http_config.h"
Packit Service 384592
#include "http_log.h"
Packit Service 384592
#include "http_protocol.h"
Packit Service 384592
#include "ap_config.h"
Packit Service 384592
#include "apr_optional.h"
Packit Service 384592
Packit Service 384592
#include "modsecurity.h"
Packit Service 384592
Packit Service 384592
/* -- Generic generators/validators from re_variables.c -- */
Packit Service 384592
Packit Service 384592
/**
Packit Service 384592
 * Generates a variable from a string and a length.
Packit Service 384592
 */
Packit Service 384592
static int var_simple_generate_ex(msre_var *var, apr_table_t *vartab, apr_pool_t *mptmp,
Packit Service 384592
    const char *value, int value_len)
Packit Service 384592
{
Packit Service 384592
    msre_var *rvar = NULL;
Packit Service 384592
Packit Service 384592
    if (value == NULL) return 0;
Packit Service 384592
Packit Service 384592
    rvar = apr_pmemdup(mptmp, var, sizeof(msre_var));
Packit Service 384592
    rvar->value = value;
Packit Service 384592
    rvar->value_len = value_len;
Packit Service 384592
    apr_table_addn(vartab, rvar->name, (void *)rvar);
Packit Service 384592
Packit Service 384592
    return 1;
Packit Service 384592
}
Packit Service 384592
Packit Service 384592
/**
Packit Service 384592
 * Generates a variable from a NULL-terminated string.
Packit Service 384592
 */
Packit Service 384592
static int var_simple_generate(msre_var *var, apr_table_t *vartab, apr_pool_t *mptmp,
Packit Service 384592
    const char *value)
Packit Service 384592
{
Packit Service 384592
    if (value == NULL) return 0;
Packit Service 384592
    return var_simple_generate_ex(var, vartab, mptmp, value, strlen(value));
Packit Service 384592
}
Packit Service 384592
Packit Service 384592
Packit Service 384592
/* -- Module specific code -- */
Packit Service 384592
Packit Service 384592
/**
Packit Service 384592
 * Create a silly variable with value = a.b.c.d:port
Packit Service 384592
 */
Packit Service 384592
static int var_remote_addr_port_generate(modsec_rec *msr, msre_var *var, msre_rule *rule,
Packit Service 384592
    apr_table_t *vartab, apr_pool_t *mptmp)
Packit Service 384592
{
Packit Service 384592
    const char *value = apr_psprintf(mptmp, "%s:%d", msr->remote_addr, msr->remote_port);
Packit Service 384592
Packit Service 384592
    return var_simple_generate(var, vartab, mptmp, value);
Packit Service 384592
}
Packit Service 384592
Packit Service 384592
static int hook_pre_config(apr_pool_t *mp, apr_pool_t *mp_log, apr_pool_t *mp_temp) {
Packit Service 384592
    void (*register_fn)(const char *name, unsigned int type,
Packit Service 384592
                        unsigned int argc_min, unsigned int argc_max,
Packit Service 384592
                        void *fn_validate, void *fn_generate,
Packit Service 384592
                        unsigned int is_cacheable, unsigned int availability);
Packit Service 384592
Packit Service 384592
    /* Look for the registration function
Packit Service 384592
     * exported by ModSecurity.
Packit Service 384592
     */
Packit Service 384592
    register_fn = APR_RETRIEVE_OPTIONAL_FN(modsec_register_variable);
Packit Service 384592
    if (register_fn) {
Packit Service 384592
        /* Use it to register our new
Packit Service 384592
         * variable under the
Packit Service 384592
         * name "REMOTE_ADDR_PORT".
Packit Service 384592
         */
Packit Service 384592
        register_fn(
Packit Service 384592
            "REMOTE_ADDR_PORT",
Packit Service 384592
            VAR_SIMPLE,
Packit Service 384592
            0, 0,
Packit Service 384592
            NULL,
Packit Service 384592
            var_remote_addr_port_generate,
Packit Service 384592
            VAR_DONT_CACHE,
Packit Service 384592
            PHASE_REQUEST_HEADERS
Packit Service 384592
        );
Packit Service 384592
    }  else {
Packit Service 384592
        ap_log_error(APLOG_MARK, APLOG_ERR | APLOG_NOERRNO, 0, NULL,
Packit Service 384592
            "mod_var_remote_addr_port: Unable to find modsec_register_variable.");
Packit Service 384592
    }
Packit Service 384592
Packit Service 384592
    return OK;
Packit Service 384592
}
Packit Service 384592
Packit Service 384592
static void register_hooks(apr_pool_t *p) {
Packit Service 384592
    ap_hook_pre_config(hook_pre_config, NULL, NULL, APR_HOOK_LAST);
Packit Service 384592
}
Packit Service 384592
Packit Service 384592
/* Dispatch list for API hooks */
Packit Service 384592
module AP_MODULE_DECLARE_DATA var_remote_addr_port_module = {
Packit Service 384592
    STANDARD20_MODULE_STUFF, 
Packit Service 384592
    NULL,                  /* create per-dir    config structures */
Packit Service 384592
    NULL,                  /* merge  per-dir    config structures */
Packit Service 384592
    NULL,                  /* create per-server config structures */
Packit Service 384592
    NULL,                  /* merge  per-server config structures */
Packit Service 384592
    NULL,                  /* table of config file commands       */
Packit Service 384592
    register_hooks         /* register hooks                      */
Packit Service 384592
};
Packit Service 384592