Control: 9.9 Ensure that 'HTTP Version' is the latest, if used to run the web app
Description
Periodically, newer versions are released for HTTP either due to security flaws or to include additional functionality. Using the latest HTTP version for web apps to take advantage of security fixes, if any, and/or new functionalities of the newer version.
Newer versions may contain security enhancements and additional functionality. With each software installation, organizations need to determine if a given update meets their requirements and also verify the compatibility and support provided for any additional software against the update revision that is selected.
HTTP 2.0 has additional performance improvements on the head-of-line blocking problem of old HTTP version, header compression, and prioritization of requests. HTTP 2.0 no longer supports HTTP 1.1's chunked transfer encoding mechanism, as it provides its own, more efficient, mechanisms for data streaming.
Remediation
From Console
Perform the following action to check latest version installed:
- Login to Azure Portal and go to
App Services
. - Click on each App.
- Under
Settings
section, click onConfiguration
. - Go to
General settings
tab. - Under
Platform settings
, ensureHTTP version
is set to0.2
.
Note Most modern browsers support HTTP 2.0 protocol over TLS only, while non- encrypted traffic continues to use HTTP 1.1. To ensure that client browsers connect to your app with HTTP/2, either buy an App Service Certificate for your app's custom domain or bind a third party certificate.
Perform the following action to install latest version:
- Login to Azure Portal and go to
App Services
. - Click on each App.
- Under
Settings
section, click onConfiguration
. - Go to
General settings
tab. - Under
Platform settings
, setHTTP version
to the latest0.2
. - Click
Save
.
From Command Line
To set HTTP 2.0 version for an existing app, run the following command:
az webapp config set --resource-group <RESOURCE_GROUP_NAME> --name <APP_NAME> --http20-enabled true
Usage
Run the control in your terminal:
powerpipe control run azure_compliance.control.cis_v130_9_9
Snapshot and share results via Turbot Pipes:
powerpipe loginpowerpipe control run azure_compliance.control.cis_v130_9_9 --share
SQL
This control uses a named query:
appservice_web_app_latest_http_version