2020-09-29 11:08:10 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
2020-10-02 15:03:48 +02:00
|
|
|
# TODO Find .htaccess from DocumentRoot
|
2020-10-02 14:46:40 +02:00
|
|
|
# TODO find piece of apache conf in /etc
|
|
|
|
# TODO Handle /sur/share/scripts/vhost...
|
2020-10-02 15:03:48 +02:00
|
|
|
# TODO total by host: vhost, htaccess, conf, cgi
|
2020-09-24 17:21:30 +02:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
apache_dir=/etc/apache2
|
|
|
|
apache_conf=$apache_dir/apache2.conf
|
|
|
|
|
2020-09-29 11:40:55 +02:00
|
|
|
tmp_dir=/tmp/apache-require
|
2020-10-02 14:53:35 +02:00
|
|
|
confs=$tmp_dir/confs
|
2020-10-02 15:03:48 +02:00
|
|
|
confs_vhost=$tmp_dir/confs_vhost
|
|
|
|
confs_system=$tmp_dir/confs_system
|
|
|
|
confs_htaccess=$tmp_dir/confs_htaccess
|
2020-10-02 15:02:31 +02:00
|
|
|
result=$tmp_dir/result
|
2020-09-29 11:40:55 +02:00
|
|
|
mkdir -p "$tmp_dir"
|
2020-09-24 17:21:30 +02:00
|
|
|
|
|
|
|
module_loaded() {
|
|
|
|
apache2ctl -D DUMP_MODULES | grep -q access_compat_module
|
|
|
|
}
|
|
|
|
|
|
|
|
# Get all config files included the
|
2020-10-02 14:53:35 +02:00
|
|
|
get_confs() {
|
2020-09-24 17:21:30 +02:00
|
|
|
# Initialize le the list of configuration files with the default conf
|
2020-10-02 14:53:35 +02:00
|
|
|
test ! -e "$confs" && printf "%s\\n" $apache_conf > "$confs"
|
2020-09-24 17:21:30 +02:00
|
|
|
|
2020-09-29 11:08:10 +02:00
|
|
|
cd "$apache_dir"
|
|
|
|
# TODO: Refactor this mess
|
2020-10-02 14:53:35 +02:00
|
|
|
confs_size=0
|
|
|
|
while [ "$confs_size" -lt "$(stat -c %s "$confs")" ]; do
|
|
|
|
confs_size=$(stat -c %s "$confs")
|
|
|
|
for conf_file in $(cat "$confs"); do
|
2020-09-24 17:21:30 +02:00
|
|
|
# XXX: Expand the filenames
|
|
|
|
for glob in $(awk '/^[[:space:]]*Include/ {print $2}' "$conf_file"); do
|
2020-10-02 14:53:35 +02:00
|
|
|
realpath $glob >> "$confs"
|
2020-09-24 17:21:30 +02:00
|
|
|
done
|
|
|
|
done
|
2020-10-02 14:53:35 +02:00
|
|
|
sort "$confs" | uniq > "$confs"_tmp && mv "$confs"_tmp "$confs"
|
2020-09-24 17:21:30 +02:00
|
|
|
done
|
2020-09-29 11:08:10 +02:00
|
|
|
cd - 1>/dev/null
|
2020-09-24 17:21:30 +02:00
|
|
|
}
|
|
|
|
|
2020-10-02 15:03:48 +02:00
|
|
|
get_htaccess() {
|
|
|
|
mv -b "$confs_htaccess" "$confs_htaccess".bak || true
|
|
|
|
|
|
|
|
for file in $(cat "$confs"); do
|
|
|
|
awk 'sub("^[[:space:]]*DocumentRoot[[:space:]]*", "") {print $0}' "$file" >> "$confs_htaccess"
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2020-09-24 17:21:30 +02:00
|
|
|
count_directives() {
|
|
|
|
directives="Allow Order Deny Satisfy"
|
|
|
|
|
|
|
|
for directive in $directives; do
|
|
|
|
export "$directive"="$(grep -Ec "^[[:blank:]]*$directive\\s" "$1")"
|
|
|
|
done
|
2020-09-29 11:41:30 +02:00
|
|
|
|
2020-09-24 17:21:30 +02:00
|
|
|
# shellcheck disable=SC2154
|
2020-09-29 11:41:30 +02:00
|
|
|
if [ "$Allow" -ne 0 ] || [ "$Order" -ne 0 ] || \
|
|
|
|
[ "$Deny" -ne 0 ] || [ "$Satisfy" -ne 0 ]; then
|
|
|
|
printf "%s %d %d %d %d\\n" "$1" "$Allow" "$Order" "$Deny" "$Satisfy"
|
|
|
|
fi
|
2020-09-24 17:21:30 +02:00
|
|
|
}
|
|
|
|
|
2020-09-29 11:08:10 +02:00
|
|
|
display_results() {
|
2020-10-02 15:02:31 +02:00
|
|
|
mv -b "$result" "$result".bak || true
|
2020-09-29 11:43:05 +02:00
|
|
|
|
|
|
|
printf 'File\tAllow\tOrder\tDeny\tSatsify\n' >&2
|
2020-09-29 11:41:30 +02:00
|
|
|
# TODO make shellcheck happy
|
2020-10-02 14:53:35 +02:00
|
|
|
for file in $(cat $confs); do
|
2020-10-02 15:02:31 +02:00
|
|
|
count_directives "$file" | tee -a "$result"
|
2020-09-29 11:08:10 +02:00
|
|
|
done
|
|
|
|
}
|
2020-09-24 17:21:30 +02:00
|
|
|
|
2020-10-02 14:53:35 +02:00
|
|
|
get_confs
|
2020-09-29 11:08:10 +02:00
|
|
|
display_results
|