Configuration Reference

Bootstrap Configuration

These configuration options are special configuration options only configurable through environment variables (e.g. through the .env file).

There are no corresponding configuration options for these values in the app/config definitions because they are applied before the application container (and configuration) is loaded.

FILES_PATH

A path (relative or absolute) to the directory in which you would like to list. This may even be a path outside of the application directory. When left unset, the root application directory (i.e. the folder where index.php is located) will be listed.

An absolute or relative file path (string)

COMPILE_CONTAINER

Whether or not the application container will be compiled. When set to false the container will not be compiled and cached. If left unset the container will be compiled and cached on first run and the cached container will be reused on subsequent requests. Disabling this comes with a (likely negligible) performance hit. Generally this should not be changed but might be necessary to modify when running Directory Lister on a read-only filesystem.

false or <unset>

Runtime Configuration

General application runtime configuration can be controlled through environment variables. This can be accomplished via an .env file located in the root of your application. An example file is provided as .env.example.

Advanced configuration can be accomplished via the app config located at app/config/app.php. However, changes to this fill will need to be manually re-applied between upgrades. It is highly recommended to stick to environment variables for controlling app configuration unless absolutely necessary.

ANALYTICS_FILE

File containing analytics scripts that will be included in the HTML output of your directory listing.

A (string) file name

APP_DEBUG

Enable application debugging and display error messages.

true or false

APP_LANGUAGE

The application's interface language.

See the app/translations folder for available translations.

DATE_FORMAT

The format used for rendering dates in the application views.

See the PHP date format documentation for possible values.

Comma separated list of file matching patterns to be directly linked. Directly linked files will not be served by Directory Lister but handled by the web server directly.

DISPLAY_READMES

Parse and render README files on the page.

true or false

Example

To directly link all .htm, .html and .php files in all folders and sub-folders.

DIRECT_LINKS=**/index.{htm,html},**/*.php

A comma separated list of file matching patterns.

GOOGLE_ANALYTICS_ID

Your Google analytics tracking ID.

A string in the format of UA-123456789-0 or false to disable

HIDDEN_FILES_LIST

File containing hidden file definitions. Will be merged with definitions from the 'hidden_files' configuration option.

See the Hiding Files page for additional info on hiding files.

A path (string) to a file

HIDE_APP_FILES

Hide application specific files/directories (i.e. index.php and the app folder).

true or false

HIDE_DOT_FILES

Hide dot files/directories from the listing.

true or false

HIDE_VCS_FILES

Hide the files Version Control Systems (i.e. Git and Mercurial) use to store their metadata.

true or false

HOME_TEXT

Text of the home link in the navigation breadcrumbs. If undefined or null will use the translated form of "home" from your selected language.

Any string

MATOMO_ANALYTICS_SITE_ID

Your Matomo analytics site ID.

A Matomo analytics site ID (string)

MATOMO_ANALYTICS_URL

Your Matomo analytics URL.

A Matomo analytics URL (string)

MAX_HASH_SIZE

The maximum file size (in bytes) that can be hashed. This helps to prevent timeouts for excessively large files.

Any positive integer 0 - 9223372036854775807 (PHP_INT_MAX)

META_DESCRIPTION

Meta tag description (i.e. <meta name="description">) text.

Any string

READMES_FIRST

Show READMEs before the file listing.

true or false

REVERSE_SORT

When enabled, reverses the order of files (after sorting is applied).

true or false

SITE_TITLE

The title of your directory listing. This will be displayed in the browser tab/title bar along with the current path.

Any string

SORT_ORDER

Sorting order of files and folders. Can be one of several predefined values. Advanced sorting configuration can be achieved by using an anonymous function. See the sort_order configuration option documentation for more information.

type, natural, name, accessed, changed, modified, <anonymous function>

TIMEZONE

Time zone used for date formatting.

For a list of supported time zones see: https://www.php.net/manual/en/timezones.php.

ZIP_DOWNLOADS

Enable downloading of directories as a zip archive.

true or false

ZIP_COMPRESS

Compress Zip using Deflate. Enabling this option prevents file size estimation and it may prevent zip download resuming when paused.

true or false

Cache Configuration

Application cache configuration is also controlled through environment variables. This can be accomplished via an .env file located in the root of your application. An example file is provided as .env.example.

Advanced configuration can be accomplished via the cache config located at app/config/cache.php. However, changes to this fill will need to be manually re-applied between upgrades. It is highly recommended to stick to environment variables for controlling cache configuration unless absolutely necessary.

CACHE_DRIVER

The application cache driver. Setting this value to array will disable the cache across requests. Additional driver-specific options may be required with certain values.

apcu, array, file, memcached, redis, php-file, valkey

CACHE_LIFETIME

The app cache lifetime (in seconds). Setting this value to 0 will cache indefinitely.

Any positive integer

CACHE_LOTTERY

Some cache drivers require manually pruning the cache periodically to remove expired items. This is the percentage chance (out of 100) of a request "winning" the lottery causing the cache to be pruned.

Any integer betweeen 1 and 100

MEMCACHED_HOST

The Memcached server hostname or IP address.

Any string

Advanced Memcached configuration is possible via the memcached_config option in app/config/cache.php

MEMCACHED_PORT

The Memcached server port.

Any valid port as an integer (0 to 65353)

Advanced Memcached configuration is possible via the memcached_config option in app/config/cache.php

REDIS_HOST

The Redis server hostname or IP address.

Any string

Advanced Reds configuration is possible via the redis_config option in app/config/cache.php

REDIS_PORT

The Redis server port.

Any valid port as an integer (0 to 65353)

Advanced Reds configuration is possible via the redis_config option in app/config/cache.php

VIEW_CACHE

Path to the view cache directory. Set to false to disable view caching entirely.

A directory path as a string or false to disable the view cache entirely

Icon Configuration

The icon config is located at app/config/icons.php. Here is were file types are mapped to their respective icons. The mapping is a PHP array where the array key is the file extension (without a preceding dot) and the array value is the desired Font Awesome class names.

icons.php
return [
    'icons' => [
        '7z' => 'fas fa-file-archive',
        'aac' => 'fas fa-music',
        'accdb' => 'fas fa-database',
        'ai' => 'fas fa-image',
        'aif' => 'fas fa-music',
        'apk' => 'fab fa-android',
        'app' => 'fas fa-window',
        'avi' => 'fas fa-video',
        'bak' => 'fas fa-save',
        'bat' => 'fas fa-terminal',
        // etc...
    ],
];

Advanced Configuration

Some configuration values do not have a direct corresponding environment variable. These values can only be controlled through their corresponding entries in the app/config files.

hidden_files

Array of hidden file definitions. Will be merged with definitions in the file defined in the hidden_files_list configuration option. Supports glob patterns (e.g. *.txt, file.{yml,yaml}, etc.).

See the Hiding Files page for additional info on hiding files.

An array of paths (strings)

memcached_config

The Memcached configuration anonymous function (closure). This option is used when the cache_driver configuration option is set to memcached. The closure receives a Memcached object as it's only parameter. You can use this object to configure the Memcached connection. At a minimum you must connect to one or more Memcached servers via the addServer() or addServers() methods.

Reference the PHP Memcached documentation for Memcached configuration options.

An anonymous function that receives a Memcached object

function (Memcached $memcached): void {
    // Configure the $memcached object
}

redis_config

The Redis configuration anonymous function (closure). This option is used when the cache_driver configuration option is set to redis. The closure receives a Redis object as it's only parameter. You can use this object to configure the Redis connection. At a minimum you must connect to one or more Redis servers via the connect() or pconnect() methods.

Reference the phpredis documentation for Redis configuration options.

An anonymous function that receives a Redis object

function (Redis $redis): void {
    // Configure the $redis object
}

http_cache

HTTP cache values for controlling browser page cache duration. An array of mime types mapped to their cache duration in seconds.

An array of mime types mapped to their cache duration as a seconds (integers).

sort_order

An anonymous function can be used to customize the sort order of files and folders in your directory listing. The anonymous function receives two SplFileInfo objects as arguments and must return an integer less than, equal to, or greater than zero to represent the first argument being respectively less than, equal to, or greater than the second.

'sort_order' => \DI\value(
    function (SplFileInfo $file1, SplFileInfo $file2): int {
        return strcmp($file1->getRealPath(), $file2->getRealPath());
    })
);

Last updated

Was this helpful?