Struct aws_sdk_wafv2::types::FieldToMatch  
source · #[non_exhaustive]pub struct FieldToMatch {
    pub single_header: Option<SingleHeader>,
    pub single_query_argument: Option<SingleQueryArgument>,
    pub all_query_arguments: Option<AllQueryArguments>,
    pub uri_path: Option<UriPath>,
    pub query_string: Option<QueryString>,
    pub body: Option<Body>,
    pub method: Option<Method>,
    pub json_body: Option<JsonBody>,
    pub headers: Option<Headers>,
    pub cookies: Option<Cookies>,
    pub header_order: Option<HeaderOrder>,
}Expand description
The part of the web request that you want WAF to inspect. Include the single FieldToMatch type that you want to inspect, with additional specifications as needed, according to the type. You specify a single request component in FieldToMatch for each rule statement that requires it. To inspect more than one component of the web request, create a separate rule statement for each component.
Example JSON for a QueryString field to match: 
  "FieldToMatch": { "QueryString": {} } 
Example JSON for a Method field to match specification:
  "FieldToMatch": { "Method": { "Name": "DELETE" } } 
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.single_header: Option<SingleHeader>Inspect a single header. Provide the name of the header to inspect, for example, User-Agent or Referer. This setting isn't case sensitive.
Example JSON: "SingleHeader": { "Name": "haystack" } 
Alternately, you can filter and inspect all headers with the Headers FieldToMatch setting. 
single_query_argument: Option<SingleQueryArgument>Inspect a single query argument. Provide the name of the query argument to inspect, such as UserName or SalesRegion. The name can be up to 30 characters long and isn't case sensitive.
Example JSON: "SingleQueryArgument": { "Name": "myArgument" } 
all_query_arguments: Option<AllQueryArguments>Inspect all query arguments.
uri_path: Option<UriPath>Inspect the request URI path. This is the part of the web request that identifies a resource, for example, /images/daily-ad.jpg.
query_string: Option<QueryString>Inspect the query string. This is the part of a URL that appears after a ? character, if any.
body: Option<Body>Inspect the request body as plain text. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
A limited amount of the request body is forwarded to WAF for inspection by the underlying host service. For regional resources, the limit is 8 KB (8,192 kilobytes) and for CloudFront distributions, the limit is 16 KB (16,384 kilobytes). For CloudFront distributions, you can increase the limit in the web ACL's AssociationConfig, for additional processing fees. 
For information about how to handle oversized request bodies, see the Body object configuration. 
method: Option<Method>Inspect the HTTP method. The method indicates the type of operation that the request is asking the origin to perform.
json_body: Option<JsonBody>Inspect the request body as JSON. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
A limited amount of the request body is forwarded to WAF for inspection by the underlying host service. For regional resources, the limit is 8 KB (8,192 kilobytes) and for CloudFront distributions, the limit is 16 KB (16,384 kilobytes). For CloudFront distributions, you can increase the limit in the web ACL's AssociationConfig, for additional processing fees. 
For information about how to handle oversized request bodies, see the JsonBody object configuration. 
headers: Option<Headers>Inspect the request headers. You must configure scope and pattern matching filters in the Headers object, to define the set of headers to and the parts of the headers that WAF inspects. 
Only the first 8 KB (8192 bytes) of a request's headers and only the first 200 headers are forwarded to WAF for inspection by the underlying host service. You must configure how to handle any oversize header content in the Headers object. WAF applies the pattern matching filters to the headers that it receives from the underlying host service. 
Inspect the request cookies. You must configure scope and pattern matching filters in the Cookies object, to define the set of cookies and the parts of the cookies that WAF inspects. 
Only the first 8 KB (8192 bytes) of a request's cookies and only the first 200 cookies are forwarded to WAF for inspection by the underlying host service. You must configure how to handle any oversize cookie content in the Cookies object. WAF applies the pattern matching filters to the cookies that it receives from the underlying host service. 
header_order: Option<HeaderOrder>Inspect a string containing the list of the request's header names, ordered as they appear in the web request that WAF receives for inspection. WAF generates the string and then uses that as the field to match component in its inspection. WAF separates the header names in the string using colons and no added spaces, for example host:user-agent:accept:authorization:referer.
Implementations§
source§impl FieldToMatch
 
impl FieldToMatch
sourcepub fn single_header(&self) -> Option<&SingleHeader>
 
pub fn single_header(&self) -> Option<&SingleHeader>
Inspect a single header. Provide the name of the header to inspect, for example, User-Agent or Referer. This setting isn't case sensitive.
Example JSON: "SingleHeader": { "Name": "haystack" } 
Alternately, you can filter and inspect all headers with the Headers FieldToMatch setting. 
sourcepub fn single_query_argument(&self) -> Option<&SingleQueryArgument>
 
pub fn single_query_argument(&self) -> Option<&SingleQueryArgument>
Inspect a single query argument. Provide the name of the query argument to inspect, such as UserName or SalesRegion. The name can be up to 30 characters long and isn't case sensitive.
Example JSON: "SingleQueryArgument": { "Name": "myArgument" } 
sourcepub fn all_query_arguments(&self) -> Option<&AllQueryArguments>
 
pub fn all_query_arguments(&self) -> Option<&AllQueryArguments>
Inspect all query arguments.
sourcepub fn uri_path(&self) -> Option<&UriPath>
 
pub fn uri_path(&self) -> Option<&UriPath>
Inspect the request URI path. This is the part of the web request that identifies a resource, for example, /images/daily-ad.jpg.
sourcepub fn query_string(&self) -> Option<&QueryString>
 
pub fn query_string(&self) -> Option<&QueryString>
Inspect the query string. This is the part of a URL that appears after a ? character, if any.
sourcepub fn body(&self) -> Option<&Body>
 
pub fn body(&self) -> Option<&Body>
Inspect the request body as plain text. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
A limited amount of the request body is forwarded to WAF for inspection by the underlying host service. For regional resources, the limit is 8 KB (8,192 kilobytes) and for CloudFront distributions, the limit is 16 KB (16,384 kilobytes). For CloudFront distributions, you can increase the limit in the web ACL's AssociationConfig, for additional processing fees. 
For information about how to handle oversized request bodies, see the Body object configuration. 
sourcepub fn method(&self) -> Option<&Method>
 
pub fn method(&self) -> Option<&Method>
Inspect the HTTP method. The method indicates the type of operation that the request is asking the origin to perform.
sourcepub fn json_body(&self) -> Option<&JsonBody>
 
pub fn json_body(&self) -> Option<&JsonBody>
Inspect the request body as JSON. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
A limited amount of the request body is forwarded to WAF for inspection by the underlying host service. For regional resources, the limit is 8 KB (8,192 kilobytes) and for CloudFront distributions, the limit is 16 KB (16,384 kilobytes). For CloudFront distributions, you can increase the limit in the web ACL's AssociationConfig, for additional processing fees. 
For information about how to handle oversized request bodies, see the JsonBody object configuration. 
sourcepub fn headers(&self) -> Option<&Headers>
 
pub fn headers(&self) -> Option<&Headers>
Inspect the request headers. You must configure scope and pattern matching filters in the Headers object, to define the set of headers to and the parts of the headers that WAF inspects. 
Only the first 8 KB (8192 bytes) of a request's headers and only the first 200 headers are forwarded to WAF for inspection by the underlying host service. You must configure how to handle any oversize header content in the Headers object. WAF applies the pattern matching filters to the headers that it receives from the underlying host service. 
Inspect the request cookies. You must configure scope and pattern matching filters in the Cookies object, to define the set of cookies and the parts of the cookies that WAF inspects. 
Only the first 8 KB (8192 bytes) of a request's cookies and only the first 200 cookies are forwarded to WAF for inspection by the underlying host service. You must configure how to handle any oversize cookie content in the Cookies object. WAF applies the pattern matching filters to the cookies that it receives from the underlying host service. 
sourcepub fn header_order(&self) -> Option<&HeaderOrder>
 
pub fn header_order(&self) -> Option<&HeaderOrder>
Inspect a string containing the list of the request's header names, ordered as they appear in the web request that WAF receives for inspection. WAF generates the string and then uses that as the field to match component in its inspection. WAF separates the header names in the string using colons and no added spaces, for example host:user-agent:accept:authorization:referer.
source§impl FieldToMatch
 
impl FieldToMatch
sourcepub fn builder() -> FieldToMatchBuilder
 
pub fn builder() -> FieldToMatchBuilder
Creates a new builder-style object to manufacture FieldToMatch.
Trait Implementations§
source§impl Clone for FieldToMatch
 
impl Clone for FieldToMatch
source§fn clone(&self) -> FieldToMatch
 
fn clone(&self) -> FieldToMatch
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for FieldToMatch
 
impl Debug for FieldToMatch
source§impl PartialEq<FieldToMatch> for FieldToMatch
 
impl PartialEq<FieldToMatch> for FieldToMatch
source§fn eq(&self, other: &FieldToMatch) -> bool
 
fn eq(&self, other: &FieldToMatch) -> bool
self and other values to be equal, and is used
by ==.