Skip to content
This repository has been archived by the owner on Aug 21, 2024. It is now read-only.

Latest commit

 

History

History
54 lines (34 loc) · 3.85 KB

File metadata and controls

54 lines (34 loc) · 3.85 KB

apache-directory-index-replacement

Custom front end modifications for directory index pages generated by Apache mod_autoindex.

This project's intended use is for WebDAV servers that don't use Apache's Alias directive to direct visitors to the WebDAV share.

Introduction

Apache's default directory index pages, which are generated by mod_autoindex, are boring and outdated. This is for good reason — no reliance on third-party libraries means fewer dependencies to keep track of — but there's something to be said about a responsive design for frequently-used pages in the modern era.

After applying a few configuration options (i.e., IndexOptions, HeaderName, ReadmeName, etc.) in the Apache virtual host configuration responsible for a WebDAV share and pasting the custom theme files into the root of the share, the directory listings look something like this:

The resulting HTML page is pretty, fully responsive, and mobile-ready, and it includes functional breadcrumb navigation.

Some of the file/directory details that are normally provided by mod_autoindex are disabled in the configuration for the sake of simplicity, but the table (re-)building logic should be able to handle re-enabling the description row. Sorting functionality via queries is still supported.

Configuration

To use the custom theme, a few changes must be made to an existing Apache virtual host configuration. A sample config file is provided in this repository, and it can be used as a replacement config file after following DigitalOcean's Apache WebDAV tutorial.

Assuming WebDAV is setup and enabled in an existing virtual host config, add the following within the <Directory> block that controls the WebDAV share:

# DIRECTORY CUSTOMIZATION
<IfModule mod_autoindex.c>

	# SET INDEX OPTIONS
	IndexOptions IgnoreCase FancyIndexing FoldersFirst NameWidth=* SuppressDescription HTMLTable

	# SET DISPLAY ORDER
	IndexOrderDefault Ascending Name

	# IGNORE CUSTOM FILES
	IndexIgnore header.html footer.html favicon.ico .htaccess .ftpquota .DS_Store icons *.log *,v *,t .??* *~ *#

	# SPECIFY HEADER FILE
	HeaderName /.theme/header.html
	# SPECIFY FOOTER FILE
	ReadmeName /.theme/footer.html

</IfModule>

Then, simply copy the .theme directory into the root of your WebDAV share and restart apache2. The various configuration options can be changed as required and reloaded by restarting apache2.

Important note: Apache resolves absolute locations for theme files supplied in the HeaderName and ReadmeName directives based on your DocumentRoot, meaning either the DocumentRoot must match the directory being used for WebDAV or the theme files must be stored in the separate DocumentRoot directory. If the latter configuration is used, the Alias directive may be used as shown in the DigitalOcean tutorial references above. The sample virtual host config provided in this repository sets the DocumentRoot to the same directory as the WebDAV share, and does not use Alias.

Credits

Thanks to a number of folks on StackOverflow for tidbits of information regarding mod_autoindex behavior, but most importantly to Jeff Star for his incredible write-up on directory listing customizations.

Additionally, becoming familiar with the mod_autoindex configuration options is a must for modifying this project.

Finally, thanks to Pico CSS for a minimal, easy-to-use front end framework. I would have abandoned this idea if I had to use Bootstrap.