Feature variables retrieves request and response metadata. Use this metadata to dynamically alter a request or a response.
The following features support variables:
- Rewrite Cache Key (cache_key_rewrite)
- Cache Key (cache_key). Feature variable supported is limited to the Expressions option (
include_expressions
). - Add Response Headers (add_response_headers)
- Set Request Headers (set_request_headers)
- Set Response Headers (set_response_headers)
- URL Redirect (url_redirect)
- URL Rewrite (url_rewrite)
Definitions
Feature variables are categorized as follows:
Client Device
This category contains feature variables that describe the client’s device or browser.
Type | Variable | Description |
---|---|---|
Brand Name | %{wurfl_cap_brand_name} | Indicates the brand name of the device. Sample Value: Samsung |
Device OS | %{wurfl_cap_device_os} | Indicates the operating system installed on the device. Sample Value: IOS |
Device OS Version | %{wurfl_cap_device_os_version} | Indicates the version number of the OS installed on the device. Sample Value: 1.0.1 |
Dual Orientation | %{wurfl_cap_dual_orientation} | Indicates whether the device supports dual orientation. Sample Value: true |
HTML Preferred DTD | %{wurfl_cap_html_preferred_dtd} | Indicates the mobile device’s preferred document type definition (DTD) for HTML content. Sample Value: html5 |
Image Inlining | %{wurfl_cap_image_inlining} | Indicates whether the device supports Base64-encoded images. Sample Value: false |
Is Android | %{wurfl_vcap_is_android} | Indicates whether the device uses the Android OS. Sample Value: true |
Is App | %{wurfl_vcap_is_app} | Indicates whether a native application requested content. Sample Value: true |
Is Full Desktop | %{wurfl_vcap_is_full_desktop} | Indicates whether the device provides a full desktop experience. Sample Value: true |
Is IOS | %{wurfl_vcap_is_ios} | Indicates whether the device uses iOS. Sample Value: false |
Is Robot | %{wurfl_vcap_is_robot} | Indicates whether the device is considered to be an automated HTTP client (e.g., a robot crawler). Sample Value: true |
Is Smart TV | %{wurfl_cap_is_smarttv} | Indicates whether the device is a smart TV. Sample Value: false |
Is Smartphone | %{wurfl_vcap_is_smartphone} | Indicates whether the device is a smartphone. Sample Value: true |
Is Tablet | %{wurfl_cap_is_tablet} | Indicates whether the device is a tablet. This is an OS-independent description. Sample Value: true |
Is Touchscreen | %{wurfl_vcap_is_touchscreen} | Indicates whether the device’s primary pointing device is a touchscreen. Sample Value: true |
Is Windows Phone | %{wurfl_vcap_is_windows_phone} | Indicates whether the device is a a Windows Mobile 6.5/Windows Phone 7 or higher. Sample Value: true |
Is Wireless Device | %{wurfl_cap_is_wireless_device} | Indicates whether the device is considered a wireless device For the purposes of this capability, PCs and laptops are not considered to be mobile devices. Sample Value: true |
Marketing Name | %{wurfl_cap_marketing_name} | Indicates the device’s marketing name. Sample Value: BlackBerry 8100 Pearl |
Mobile Browser | %{wurfl_cap_mobile_browser} | Indicates the browser used to request content from the device. Sample Value: Chrome |
Mobile Browser Version | %{wurfl_cap_mobile_browser_version} | Indicates the version of the browser used to request content from the device. Sample Value: 31 |
Model Name | %{wurfl_cap_model_name} | Indicates the device’s model name. Sample Value: s10 |
Progressive Download | %{wurfl_cap_progressive_download} | Indicates whether the device supports the playback of audio/video while it is still being downloaded. Sample Value: true |
Release Date | %{wurfl_cap_release_date} | Indicates the year and month on which the device was added to the WURFL database. Format: yyyy_mm Sample Value: 2022_december |
Resolution Height | %{wurfl_cap_resolution_height} | Indicates the device’s height in pixels. Sample Value: 768 |
Resolution Width | %{wurfl_cap_resolution_width} | Indicates the device’s width in pixels. Sample Value: 1024 |
Client Geography
This category contains feature variables that describe the client’s geography.
A blank value is returned when GEO metadata is unavailable for a particular request.
Type | Variable | Description |
---|---|---|
City (Client) | %{geo_city} | Indicates the client’s city. Sample Value: Los Angeles |
Continent (Client) | %{geo_continent} | Indicates the client’s continent through its abbreviation. Valid values are:
Sample Value: NA |
Country (Client) | %{geo_country} | Indicates the country from which the requested originated through its country code. Sample Value: US |
Designated Market Area (Client) | %{geo_dma_code} | Indicates the client’s media market by its region code. This field is only applicable to requests that originate from the United States. Sample Value: 745 |
Latitude (Client) | %{geo_latitude} | Indicates the client’s latitude. Sample Value: 34.0995 |
Longitude (Client) | %{geo_longitude} | Indicates the client’s longitude. Sample Value: -118.4143 |
Metropolitan Statistical Area (Client) | %{geo_metro_code} | Indicates the client’s metropolitan area. This field is only applicable to requests that originate from the United States. Sample Value: 745 |
Postal Code (Client) | %{geo_postal_code} | Indicates the client’s postal code. We only return the first 3 characters for Canadian postal codes and the first 2 - 4 characters for United Kingdom postal codes. Sample Value: 90210 |
Region (Client) | %{geo_region} | Indicates the client’s region (e.g., state or province) through its alphanumeric abbreviation. Sample Value: CA |
Client Network
This category contains feature variables that describe the client’s network.
Type | Variable | Description |
---|---|---|
ASN (Client) | %{geo_asnum} | Indicates the client’s AS number. Sample Value: AS15133 |
IP Address (Client) | %{virt_dst_addr} | Indicates the client’s IP address. Sample Value: 192.168.1.1 |
Port (Client) | %{virt_dst_port} | Indicates the client’s ephemeral port. Sample Value: 55885 |
General
This category contains the QUIC Versions feature variable.
Type | Variable | Description |
---|---|---|
QUIC Versions | %{quic_altsvc_versions} | Indicates the set of QUIC versions supported by our CDN service. This variable identifies QUIC versions using Google’s latest specification. Sample Value: h3-Q049=":443"; ma=2592000,h3-Q048=":443"; ma=2592000,h3-Q046=":443"; ma=2592000,h3-Q043=":443"; ma=2592000 |
mTLS
This category contains feature variables that describe a client’s mTLS authentication request.
Type | Variable | Description |
---|---|---|
Client Certificate | %{virt_ssl_client_cert} | Contains the client certificate in PEM format. Example: -----BEGIN%20CERTIFICATE----- ... %0A-----END%20CERTIFICATE-----%0A |
Client Certificate’s Days to Expiration | %{virt_ssl_client_v_remain} | Indicates the number of days until the client certificate will expire. Example: 123 |
Client Certificate’s Expiration Date | %{virt_ssl_client_v_end} | Indicates the date and time (GMT) at which the client certificate will expire. Example: Aug 7 18:54:27 2033 GMT |
Client Certificate’s Fingerprint | %{virt_ssl_client_fingerprint} | Contains the client certificate’s SHA1 fingerprint. Example: 7C2E166156E2D165AD7468B0E0145411B655F041 |
Client Certificate’s Issued Date | %{virt_ssl_client_v_start} | Indicates the date and time (GMT) at which the client certificate was issued. Example: Aug 10 18:54:27 2023 GMT |
Client Certificate’s Serial Number | %{virt_ssl_client_serial} | Indicates the client certificate’s serial number. Example: 655603895D3E8ECC4DF507FB33A1171A53F37CAF |
Client Certificate’s Validation Status | %{virt_ssl_client_verify} | Indicates the result for the validation of the client certificate. Valid values are:
|
Distinguished Name - Issuer | %{virt_ssl_client_i_dn} | Identifies the Distinguished Name (DN) for the client certificate’s issuer. Example: CN=ACME INTERMEDIATE CLIENT CA,OU=Security,O=ACME Inc.,L=Los Angeles,ST=California,C=US |
Distinguished Name - Subject | %{virt_ssl_client_s_dn} | Identifies the Distinguished Name (DN) for the client certificate’s subject. Example: CN=www.example.com,OU=Security,O=ACME Inc.,L=Los Angeles,ST=California,C=US |
Request
This category contains feature variables that describe the request.
Type | Variable | Description |
---|---|---|
Cookie Value | %{cookie_<COOKIE>} | Returns the value corresponding to the cookie identified by the <COOKIE> term. Replace dashes in the cookie name with underscores (e.g., change preferences-cookie to preferences_cookie ).Sample Usage: %{cookie__utma} Sample Value: 111662281.2.10.1222100123 |
HTTP Method | %{request_method} | Indicates the HTTP request method. Sample Value: GET |
JA3 MD5 Hash | %{virt_ssl_client_ja3_md5} | Indicates the JA3 fingerprint assigned to the request. A JA3 fingerprint identifies a client using key characteristics from a TLS request. This allows us to classify traffic across various IP addresses and ports. |
Normalized Path | %{normalized_path} | Indicates the normalized relative path for the request submitted to the CDN. Key information:
/marketing/images/bunny.png |
Normalized Query String | %{normalized_query} | Indicates the normalized query string defined in the request URL. URL normalization, as defined in RFC 3986, was applied to this value. Original Query String: "client=/123?" Sample Value: %22client=/123?%22 |
Normalized URI | %{normalized_uri} | Indicates the normalized relative path and query string for the request submitted to the CDN. Key information:
/dir/foo.js?%22client=/123?%22 |
Path | %{path} | Indicates the relative path to the requested content. Key information:
Sample Value: /rewrittendir/foo.js |
Query String Found | %{is_args} | The value for this variable varies according to whether the request contains a query string.
? |
Query String Parameter Found | %{is_amp} | The value for this variable varies according to whether the request contains at least one query string parameter.
& |
Query String Parameter Value | %{arg_<QUERY STRING PARAMETER>} | Returns the value corresponding to the query string parameter identified by the <QUERY STRING PARAMETER> term. Sample Usage: %{arg_language} Sample Query String Parameter: language=en Sample Value: en |
Query String Value | %{query_string} | Indicates the entire query string value defined in the request URL. Sample Value: key1=val1&key2=val2&key3=val3 |
Referrer Domain | %{referring_domain} | Indicates the domain defined in the Referer request header. Sample Value: www.google.com |
Request Header Value | %{http_<REQUEST HEADER>} | Returns the value corresponding to the request header identified by the <REQUEST HEADER> term. Replace dashes in the request header name with underscores (e.g., change User-Agent to User_Agent ).Sample Usage: %{http_Connection} Sample Value: Keep-Alive |
Request Host | %{host} | Indicates the host defined in the request URL. Sample Value: www.example.com |
Request ID | %{http_x_ec_uuid} | Indicates a request’s unique system-defined ID. A new ID is generated whenever a client (i.e., user agent) submits a request. Sample Value: 12345678901234567890123456789012345678 |
Request Protocol (Client) | %{virt_http_version} | Indicates the version of the client’s request protocol. Sample Value: 2.0 |
Request Protocol (Edge Server) | %{request_protocol} | Indicates the request protocol used by an edge server to proxy the request. Sample Value: HTTP/1.1 |
Request Scheme | %{scheme} | Indicates the request scheme. Sample Value: http |
Request URI | %{request} | Describes the request. Syntax: <HTTP METHOD> <RELATIVE PATH> <PROTOCOL>
GET /marketing/foo.js?loggedin=true HTTP/1.1 |
Request URI (Relative) | %{request_uri} | Indicates the relative path, including the query string, defined in the request URI. Sample Value: /marketing/foo.js?loggedin=true |
Session ID | %{http_x_ec_session_id} | Indicates a unique system-defined ID for the request’s connection to our servers. Multiple rapid requests by a single client may result in a single session ID when the connection is reused for those requests. Use %{http_x_ec_uuid} if you require a unique ID for each request.Sample Value: 12345678901234567890123456789012345678 |
TLS Cipher Suite | %{virt_ssl_cipher} | Indicates the name of the cipher suite used to secure a HTTPS connection. Sample Value: ECDHE-RSA-AES256-SHA |
TLS Protocol | %{virt_ssl_protocol} | Indicates the SSL/TLS protocol used to secure a HTTPS connection. Sample Value: TLSv1.2 |
Response
This category contains feature variables that describe the response sent to the client.
Type | Variable | Description |
---|---|---|
HTTP Status Code | %{status} | Indicates the HTTP status code for the response. Sample Value: 200 |
Response Header Value | %{resp_<RESPONSE HEADER>} | Returns the value corresponding to the response header identified by the <RESPONSE HEADER> term. Replace dashes in the response header name with underscores (e.g., change User-Agent to User_Agent ). Requests cannot be defined using variables associated with response metadata. For example, this variable cannot be used to define a request header through the set_request_headers feature.%{resp_Content_Length} Sample Value: 100 |
Usage
Feature variables support the following syntax:
-
Feature Variable: Use this syntax to get the entire value corresponding to the specified feature variable.Example:
%{host}
-
Feature Variable with a Delimiter: Use this syntax to transform the value corresponding to the specified feature variable.Example: The following example converts the value associated with the
%{host}
variable to lower-case.%{host,}
-
Feature Variable with a Delimiter and an Expression: Use regular expressions to replace, delete, or manipulate a feature variable’s value.Example:
%{host/=^www\.([^\.]+)\.([^\.:]+)/cdn.$2.$3:80}
Feature variable names only support alphabet characters and underscores. Convert unsupported characters to underscores.
Delimiter Quick Reference
A delimiter can be specified after a feature variable to achieve any of the following effects:
-
Transform the value associated with the variable.Example: Convert the entire value to lower-case.
-
Delete the value associated with the variable.
-
Manipulate the value associated with the variable.Example: Use regular expressions to change the value associated with the feature variable.
A brief description for each delimiter is provided below.
Delimiter | Description |
---|---|
:= | Indicates that a default value will be assigned to the variable when it is either missing or set to NULL. |
:+ | Indicates that a default value will be assigned to the variable when a value has been assigned to it. |
: | Indicates that a substring of the value assigned to the variable will be expanded. |
# | Indicates that the pattern specified after this delimiter should be deleted when it is found at the beginning of the value associated with the variable. |
% | Indicates that the pattern specified after this delimiter should be deleted when it is found at the end of the value associated with the variable. The above definition is only applicable when the % symbol is used as a delimiter. |
/ | Delimits a feature variable or a pattern. |
// | Find and replace all instances of the specified pattern. |
/= | Find, copy, and rewrite all occurrences of the specified pattern. |
, | Convert the value associated with the feature variable to lower-case. |
^ | Convert the value associated with the feature variable to upper-case. |
,, | Convert all instances of the specified character in the value associated with the feature variable to lower-case. |
^^ | Convert all instances of the specified character in the value associated with the feature variable to upper-case. |
Exceptions
Text will not be treated as a feature variable under the following circumstances:
-
Escaping % Symbol: The percentage symbol can be escaped through the use of a backslash.Example: The following sample value will be treated as a literal value and not as a feature variable:
\%{host}
-
Unknown Variables: An empty string is always returned for unknown variables.Example:
%{unknownvariable}
-
Invalid Characters or Syntax: Variables that contain invalid characters or syntax are treated as literal values.Example #1: The following value contains an invalid character (i.e., -):
%{resp_user-agent}
Example #2: The following value contains a double set of curly braces:%{{host}}
Example #3: The following value is missing a closing curly brace:%{host
-
Missing Variable Name: A NULL value is always returned when a variable is not specified.Example:
%{}
-
Trailing Characters: Characters that trail a variable are treated as literal values.Example: The following sample value contains a trailing curly brace that will be treated as a literal value:
%{host}}
Setting Default Header Values
A default value can be assigned to a header when it meets any of the following conditions:
- Missing/unset
- Set to
NULL
.
Define this default value through any of the following methods:
-
Set a header to a default value when the header is missing or its value is set to
NULL
.Syntax:%{<FEATURE VARIABLE>:=<DEFAULT VALUE>}
Example: The following value sets theReferer
header tounspecified
when it is either missing or set to NULL. No action will take place if it has been set.%{http_referer:=unspecified}
-
Set a header to a default value when it is missing.Syntax:
%{<FEATURE VARIABLE>=<DEFAULT VALUE>}
Example: The following value sets theReferer
header tounspecified
when it is missing. No action will take place if it has been set.%{http_referer=unspecified}
-
Set the header to a default value when it does not meet any of the following conditions:
- Missing header.
- Set to
NULL
.
Syntax:%{<FEATURE VARIABLE>:+<DEFAULT VALUE>}
Example: The following value sets theReferer
header tounspecified
when a value has been assigned to it. No action will take place if it has been set.%{http_referer:+unspecified}
Manipulating Variables
Variables can be manipulated in the following ways:
- Expanding substrings
- Removing patterns
Substring Expansion
By default, a variable will expand to its full value. Use the following syntax to only expand a substring of the variable’s value:
%{<VARIABLE>:<OFFSET>:<LENGTH>}
Key information:
-
The value assigned to the
<OFFSET>
term determines the starting character of the substring.- Positive: The starting character of the substring is calculated from the first character in the string.
- Zero: The starting character of the substring is the first character in the string.
- Negative: The starting character of the substring is calculated from the last character in the string.
-
The length of the substring is determined by the
<LENGTH>
term.- Omitted: Omitting the
<LENGTH>
term allows the substring to include all characters between the starting character and the end of the string. - Positive: Determines the length of the substring from the starting character to the right.
- Negative: Determines the length of the substring from the starting character to the left.
- Omitted: Omitting the
Example:
This example relies on the following sample request URL:
https://cdn.mydomain.com/folder/marketing/myconsultant/proposal.html
The following string demonstrates various methods for manipulating variables:
https://www%{http_host:3}/mobile/%{request_uri:7:10}/%{request_uri:-5:-8}.htm
Based on the sample request URL, the above variable manipulation will produce the following value:
https://www.mydomain.com/mobile/marketing/proposal.htm
Pattern Removal
Text that matches a specific pattern can be removed from either the beginning or the end of a variable’s value.
-
Remove text when the specified pattern is found at the beginning of a variable’s value.
%{<VARIABLE>#<PATTERN>}
-
Remove text when the specified pattern is found at the end of a variable’s value.
%{<VARIABLE>%<PATTERN>}
Find And Replace
Find and replace syntax is described below.
-
Find and replace first occurrence of the specified pattern.Syntax:
%{<VARIABLE>/<FIND>/<REPLACE>}
-
Find and replace all occurrences of the specified pattern.Syntax:
%{<VARIABLE>//<FIND>/<REPLACE>}
-
Convert the entire value to upper-case.Syntax:
%{<VARIABLE>^}
-
Convert the first occurrence of the specified pattern to upper-case.Syntax:
%{<VARIABLE>^<FIND>}
-
Convert the entire value to lower-case.Syntax:
%{<VARIABLE>,}
-
Convert the first occurrence of the specified pattern to lower-case.Syntax:
%{<VARIABLE>,<FIND>}
Key information:
-
Expand text that matches the specified pattern by specifying a dollar sign followed by a whole integer (e.g.,
$1
). -
Multiple patterns may be specified. The order in which the pattern is specified determines the integer that will be assigned to it.In the following example, the first pattern matches
www
orwww
followed by a single digit, the second pattern matches the second-level domain, and the third pattern matches the top-level domain.%{host/=^(www\d?)\.([^\.]+)\.([^\.:]+)/cdn.$2.$3:80}
-
The rewritten value can consist of any combination of text and these placeholders.In the above example, the hostname will be rewritten according to this pattern:
cdn.$2.$3:80
(e.g., cdn.mydomain.com:80). -
The case of a pattern placeholder (e.g.,
$1
) can be modified through the following flags:-
U: Upper-case the expanded value.Sample syntax:
%{host/=^(www\d?)\.([^\.]+)\.([^\.:]+)/cdn.$U2.$3:80}
-
L: Lower-case the expanded value.Sample syntax:
%{host/=^(www\d?)\.([^\.]+)\.([^\.:]+)/cdn.$L2.$3:80}
-
-
An operator must be specified before the pattern. The specified operator determines the pattern capturing behavior:
=
indicates that all occurrences of the specified pattern must be captured and rewritten.^
indicates that only text that starts with the specified pattern will be captured.$
indicates that only text that ends with the specified pattern will be capture.
-
Omitting the
/<REWRITE>
value will result in the deletion of the text that matches the pattern.