Skip to content

drutiny/drutiny

.htaccess redirects

Name: Apache:LimitHtacessRedirects
Package: drutiny/drutiny
Class: \Drutiny\Audit\Apache\HtaccessRedirects

When there are a large number of redirects in the .htaccess file they are all required to be loaded at run time during every request as Apache needs to analyze the contents so that it can make appropriate decisions about how to process the application and incoming requests. Redirect rules should be refactored to take advantage of regular expressions if possible. Otherwise the redirect module should be added to the site and all of the redirects in the .htaccess file should be moved into the Drupal site. Although these redirects will then require a Drupal bootstrap in order to fulfill the request, Varnish will be able to cache the redirect once it has been made once as long as there is a maximum age set on the site.

Parameters

Name Type Description Default
max_redirects integer The maximum number of redirects to allow in htaccess. 10

Database size

Name: Database:Size
Package: drutiny/drutiny
Class: \Drutiny\Audit\Database\DatabaseSize

Large databases can negatively impact your production site, and slow down things like database dumps. The size reported is the data and index size combined.

Parameters

Name Type Description Default
max_size integer The maximum size in megabytes the database should be. 1000
warning_size integer The size in megabytes this check will issues a warning at. 800

Anonymous sessions

Name: Drupal:AnonSession
Package: drutiny/drutiny
Class: Drutiny\Audit\Drupal\SqlResultAudit

If you are generating sessions for anonymous users, you are causing a major performance impact to your site. Having anonymous sessions will break traditional page caching in Varnish and CDNs.

Parameters

Name Type Description Default
field string The name of the field in the result row to pull the value from count
value mixed The value to compare against 0
query string The SQL query to run. Can use other parameters for variable replacement. "SELECT COUNT(*) as count FROM sessions\nWHERE uid = 0\n AND session NOT LIKE 'openid%'\n AND session NOT LIKE '%Access denied%'\n"

Lint PHP files in Theme

Name: Drupal:LintTheme
Package: drutiny/drutiny
Class: Drutiny\Audit\Drupal\PhpLint

Ensure all PHP files in the theme pass basic PHP syntax parsing.

Parameters

Name Type Description Default
path string The path where to lint PHP files. '%root/%themes'

User Enumeration

Name: Drupal:Security:UserEmueration
Package: drutiny/drutiny
Class: Drutiny\Audit\Drupal\ModuleEnabled

User enumeration is when a malicious actor can use brute-force to either guess or confirm valid users in a system. User enumeration is often a web application vulnerability, though it can also be found in any system that requires user authentication. Two of the most common areas where user enumeration occurs are in a site's login page and its ‘Forgot Password' functionality.

User enumeration is a default vulnerability in Drupal but can be mitigated through the use of the Username Enumeration Prevention module.

Parameters

Name Type Description Default
module string The module to check is enabled. username_enumeration_prevention

Syslog

Name: Drupal:SyslogEnabled
Package: drutiny/drutiny
Class: \Drutiny\Audit\Drupal\ModuleEnabled

Syslog module writes Drupal watchdog logs to the syslog.

Parameters

Name Type Description Default
module string The name of the module to ensure is enabled. syslog

Drupal Theme Security

Name: Drupal:ThemeSecurity
Package: drutiny/drutiny
Class: Drutiny\Audit\Filesystem\CodeScan

Some basic checks to ensure that the theme is not doing any seriously bad things. Note this is not supposed to be perfect, but used as an aid in code review.

Parameters

Name Type Description Default
directory string Absolute filepath to directory to scan '%root/%themes'
filetypes array file extensions to include in the scan - php
- inc
- theme
patterns array patterns to run over each matching file. - _POST
- exec(
- db_query
- db_select
- db_merge
- db_update
- db_write_record
- ->query
- drupal_http_request
- curl_init
- passthru
- proc_open
- system(
- sleep(

Large Drupal Files

Name: Drupal:largeFiles
Package: drutiny/drutiny
Class: \Drutiny\Audit\Drupal\LargeDrupalFiles

Large static assets should be optimized for online display or ideally be housed in other services, e.g. Amazon S3 (for files) or Youtube (for videos). Storing large files can consume storage volumes, increase page load time and contribute to a higher than desired cache eviction rate. Varnish, on Acquia Cloud, does not cache files larger than 10 MB.

This policy identifies files managed by Drupal that are larger than .

Parameters

Name Type Description Default
max_size integer Report files larger than this value measured in bytes. 10000000

Module updates

Name: Drupal:moduleUpdates
Package: drutiny/drutiny
Class: \Drutiny\Audit\Drupal\ModuleUpdateStatus

Throughout the lifetime of your site, the Drupal project and its community contributed modules will release new versions that contain bug fixes, new features and security updates. It important to keep your site up to date and patched from known security vulnerabilities.

Note that upgrading modules, especially between major versions can introduce regressions into your site. While its important to maintain a continual update schedule for your site, regression testing changes is of equal importance.

Database updates

Name: Drupal:updates
Package: drutiny/drutiny
Class: \Drutiny\Audit\Drupal\UpdateDBStatus

Updates to Drupal core or contrib modules sometimes include important database changes which should be applied after the code updates have been deployed.

Always error test policy

Name: Test:Error
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysError

This policy should always error. Twee godard poutine knausgaard, street art keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Always fail test policy

Name: Test:Fail
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysFail

This policy should always fail. Twee godard poutine knausgaard, street art keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Not applicable test policy

Name: Test:NA
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysNA

This policy should always be not applicable. Twee godard poutine knausgaard, keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Always notice test policy

Name: Test:Notice
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysNotice

This policy should always be a notice. Twee godard poutine knausgaard, street keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Always pass test policy

Name: Test:Pass
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysPass

This policy should always pass. Twee godard poutine knausgaard, street art keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Always pass dependant test policy

Name: Test:PassDependant
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysPass

This policy should always pass. Twee godard poutine knausgaard, street art keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Always warn test policy

Name: Test:Warning
Package: drutiny/drutiny
Class: \Drutiny\Audit\AlwaysWarn

This policy should always issue a warning. Twee godard poutine knausgaard, keytar readymade unicorn wayfarers vape mumblecore blue bottle. Portland pitchfork air plant kale chips, craft beer meditation tumeric seitan umami vexillologist cred coloring book taxidermy actually.

Banjo narwhal la croix portland green juice lumbersexual biodiesel kombucha vegan umami aesthetic trust fund ramps. Art party +1 celiac everyday carry succulents seitan franzen distillery venmo keytar cray mustache gastropub. 8-bit seitan banh mi, vice chillwave viral synth vinyl +1. Mixtape mustache pitchfork, meh tacos kitsch offal pop-up intelligentsia VHS air plant pork belly. Thundercats microdosing taxidermy try-hard +1 ennui photo booth 8-bit.

Drupal Theme Directory Size

Name: fs:DrupalThemeDirectory
Package: drutiny/drutiny
Class: Drutiny\Audit\Filesystem\FsSize

Large theme directories can be indicative of best practice violations: * Source files in site artifact. e.g. node_modules * Media assets unsuitable for web delivery

Parameters

Name Type Description Default
max_size integer The maximum size in MegaBytes a directory should be. 50
path string The path of the directory to check for size. '%root/%themes'

Sensitive public files

Name: fs:SensitivePublicFiles
Package: drutiny/drutiny
Class: Drutiny\Audit\Filesystem\SensitivePublicFiles

Certain file extensions should never be in public files for security reasons.

Parameters

Name Type Description Default
extensions string The sensitive file extensions to look for. 'php,sh,py,sql,bz2,gz,tar,tgz,zip'

Large public files

Name: fs:largeFiles
Package: drutiny/drutiny
Class: Drutiny\Audit\Filesystem\LargeFiles

Large static assets should ideally be housed in other services, e.g. Amazon S3 (for files) or Youtube (for videos).

Parameters

Name Type Description Default
max_size integer Report files larger than this value measured in megabytes. 50