mod_alias.c revision c7ab5a433d38d5eae5fc0bb76be80ffab6e4f71d
/* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* http_alias.c: Stuff for dealing with directory aliases
*
* Original by Rob McCool, rewritten in succession by David Robinson
* and rst.
*
*/
#include "apr_strings.h"
#include "apr_lib.h"
#define APR_WANT_STRFUNC
#include "apr_want.h"
#include "ap_config.h"
#include "httpd.h"
#include "http_core.h"
#include "http_config.h"
#include "http_request.h"
#include "http_log.h"
typedef struct {
const char *real;
const char *fake;
char *handler;
int redir_status; /* 301, 302, 303, 410, etc */
} alias_entry;
typedef struct {
typedef struct {
{
alias_server_conf *a =
return a;
}
static void *create_alias_dir_config(apr_pool_t *p, char *d)
{
alias_dir_conf *a =
return a;
}
{
alias_server_conf *a =
return a;
}
{
alias_dir_conf *a =
return a;
}
/* need prototype for overlap check */
const char *f, const char *r,
int use_regex)
{
&alias_module);
int i;
/* XX r can NOT be relative to DocumentRoot here... compat bug. */
if (use_regex) {
return "Regular expression could not be compiled.";
}
else {
/* XXX This may be optimized, but we must know that new->real
* exists. If so, we can dir merge later, trusing new->real
* and just canonicalizing the remainder. Not till I finish
* cleaning out the old ap_canonical stuff first.
*/
}
/* check for overlapping (Script)Alias directives
* and throw a warning if found one
*/
if (!use_regex) {
alias_entry *p = &entries[i];
"The %s directive in %s at line %d will probably "
"never match because it overlaps an earlier "
"%sAlias%s.",
break; /* one warning per alias should be sufficient */
}
}
}
return NULL;
}
const char *r)
{
}
const char *r)
{
}
{
&alias_module);
ap_regex_t *r = NULL;
const char *f = arg2;
else if (apr_isdigit(*arg1))
else {
f = arg1;
}
if (use_regex) {
if (r == NULL)
return "Regular expression could not be compiled.";
}
if (ap_is_HTTP_REDIRECT(status)) {
if (!url)
return "URL to redirect to is missing";
/* PR#35314: we can allow path components here;
* they get correctly resolved to full URLs.
*/
return "Redirect to non-URL";
}
else {
if (url)
return "Redirect URL not valid for this status";
}
else
return NULL;
}
const char *arg3)
{
}
{
}
const char *arg3)
{
}
static const command_rec alias_cmds[] =
{
"a fakename and a realname"),
"a fakename and a realname"),
"an optional status, then document to be redirected and "
"destination URL"),
"a regular expression and a filename"),
"a regular expression and a filename"),
(void *) HTTP_MOVED_TEMPORARILY, OR_FILEINFO,
"an optional status, then a regular expression and "
"destination URL"),
(void *) HTTP_MOVED_TEMPORARILY, OR_FILEINFO,
"a document to be redirected, then the destination URL"),
(void *) HTTP_MOVED_PERMANENTLY, OR_FILEINFO,
"a document to be redirected, then the destination URL"),
{NULL}
};
{
while (*aliasp) {
if (*aliasp == '/') {
/* any number of '/' in the alias matches any number in
* the supplied URI, but there must be at least one...
*/
if (*urip != '/')
return 0;
do {
++aliasp;
} while (*aliasp == '/');
do {
++urip;
} while (*urip == '/');
}
else {
/* Other characters are compared literally */
return 0;
}
}
/* Check last alias path component matched all the way */
return 0;
/* Return number of characters from URI which matched (may be
* greater than length of alias, since we may have matched
* doubled slashes)
*/
}
{
int i;
alias_entry *p = &entries[i];
int l;
if (p->regexp) {
if (p->real) {
/* Do not escape the query string or fragment. */
}
}
}
}
else {
/* need something non-null */
}
}
}
else {
if (l > 0) {
if (doesc) {
char *escurl;
}
else
}
}
if (found) {
if (p->handler) { /* Set handler, and leave a note for mod_cgi */
}
/* XXX This is as SLOW as can be, next step, we optimize
* and merge to whatever part of the found path was already
* canonicalized. After I finish eliminating os canonical.
* Better fail test for ap_server_root_relative needed here.
*/
if (!doesc) {
}
if (found) {
*status = p->redir_status;
}
return found;
}
}
return NULL;
}
static int translate_alias_redir(request_rec *r)
{
char *ret;
int status;
return DECLINED;
}
if (ap_is_HTTP_REDIRECT(status)) {
/* include QUERY_STRING if any */
if (r->args) {
}
}
return status;
}
return OK;
}
return DECLINED;
}
static int fixup_redir(request_rec *r)
{
void *dconf = r->per_dir_config;
char *ret;
int status;
/* It may have changed since last time, so try again */
if (ap_is_HTTP_REDIRECT(status)) {
if (ret[0] == '/') {
char *orig_target = ret;
"incomplete redirection target of '%s' for "
"URI '%s' modified to '%s'",
}
"cannot redirect '%s' to '%s'; "
"target is not a valid absoluteURI or abs_path",
}
else {
/* append requested query only, if the config didn't
* supply its own.
*/
}
}
}
return status;
}
return DECLINED;
}
static void register_hooks(apr_pool_t *p)
{
static const char * const aszSucc[]={ "mod_userdir.c",
"mod_vhost_alias.c",NULL };
}
{
create_alias_dir_config, /* dir config creater */
merge_alias_dir_config, /* dir merger --- default is to override */
create_alias_config, /* server config */
merge_alias_config, /* merge server configs */
alias_cmds, /* command apr_table_t */
register_hooks /* register hooks */
};