#[non_exhaustive]pub struct FirewallPolicyRule {Show 15 fields
pub action: Option<String>,
pub description: Option<String>,
pub direction: Option<Direction>,
pub disabled: Option<bool>,
pub enable_logging: Option<bool>,
pub kind: Option<String>,
pub match: Option<FirewallPolicyRuleMatcher>,
pub priority: Option<i32>,
pub rule_name: Option<String>,
pub rule_tuple_count: Option<i32>,
pub security_profile_group: Option<String>,
pub target_resources: Vec<String>,
pub target_secure_tags: Vec<FirewallPolicyRuleSecureTag>,
pub target_service_accounts: Vec<String>,
pub tls_inspect: Option<bool>,
/* private fields */
}firewall-policies or instances or network-firewall-policies or networks or region-network-firewall-policies only.Expand description
Represents a rule that describes one or more match conditions along with the action to be taken when traffic matches this condition (allow or deny).
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.action: Option<String>The Action to perform when the client connection triggers the rule. Valid actions for firewall rules are: “allow”, “deny”, “apply_security_profile_group” and “goto_next”. Valid actions for packet mirroring rules are: “mirror”, “do_not_mirror” and “goto_next”.
description: Option<String>An optional description for this resource.
direction: Option<Direction>The direction in which this rule applies.
disabled: Option<bool>Denotes whether the firewall policy rule is disabled. When set to true, the firewall policy rule is not enforced and traffic behaves as if it did not exist. If this is unspecified, the firewall policy rule will be enabled.
enable_logging: Option<bool>Denotes whether to enable logging for a particular rule. If logging is enabled, logs will be exported to the configured export destination in Stackdriver. Logs may be exported to BigQuery or Pub/Sub. Note: you cannot enable logging on “goto_next” rules.
kind: Option<String>Output only. [Output only] Type of the resource. Returnscompute#firewallPolicyRule for firewall rules andcompute#packetMirroringRule for packet mirroring rules.
match: Option<FirewallPolicyRuleMatcher>A match condition that incoming traffic is evaluated against. If it evaluates to true, the corresponding ‘action’ is enforced.
priority: Option<i32>An integer indicating the priority of a rule in the list. The priority must be a positive value between 0 and 2147483647. Rules are evaluated from highest to lowest priority where 0 is the highest priority and 2147483647 is the lowest priority.
rule_name: Option<String>An optional name for the rule. This field is not a unique identifier and can be updated.
rule_tuple_count: Option<i32>Output only. [Output Only] Calculation of the complexity of a single firewall policy rule.
security_profile_group: Option<String>A fully-qualified URL of a SecurityProfile resource instance. Example: https://networksecurity.googleapis.com/v1/projects/{project}/locations/{location}/securityProfileGroups/my-security-profile-group Must be specified if action is one of ‘apply_security_profile_group’ or ‘mirror’. Cannot be specified for other actions.
target_resources: Vec<String>A list of network resource URLs to which this rule applies. This field allows you to control which network’s VMs get this rule. If this field is left blank, all VMs within the organization will receive the rule.
A list of secure tags that controls which instances the firewall rule applies to. If targetSecureTag are specified, then the firewall rule applies only to instances in the VPC network that have one of those EFFECTIVE secure tags, if all the target_secure_tag are in INEFFECTIVE state, then this rule will be ignored.targetSecureTag may not be set at the same time astargetServiceAccounts. If neither targetServiceAccounts nortargetSecureTag are specified, the firewall rule applies to all instances on the specified network. Maximum number of target label tags allowed is 256.
target_service_accounts: Vec<String>A list of service accounts indicating the sets of instances that are applied with this rule.
tls_inspect: Option<bool>Boolean flag indicating if the traffic should be TLS decrypted. Can be set only if action = ‘apply_security_profile_group’ and cannot be set for other actions.
Implementations§
Source§impl FirewallPolicyRule
impl FirewallPolicyRule
pub fn new() -> Self
Sourcepub fn set_action<T>(self, v: T) -> Self
pub fn set_action<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_action<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_action<T>(self, v: Option<T>) -> Self
Sourcepub fn set_description<T>(self, v: T) -> Self
pub fn set_description<T>(self, v: T) -> Self
Sets the value of description.
§Example
let x = FirewallPolicyRule::new().set_description("example");Sourcepub fn set_or_clear_description<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_description<T>(self, v: Option<T>) -> Self
Sets or clears the value of description.
§Example
let x = FirewallPolicyRule::new().set_or_clear_description(Some("example"));
let x = FirewallPolicyRule::new().set_or_clear_description(None::<String>);Sourcepub fn set_direction<T>(self, v: T) -> Self
pub fn set_direction<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_direction<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_direction<T>(self, v: Option<T>) -> Self
Sourcepub fn set_disabled<T>(self, v: T) -> Self
pub fn set_disabled<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_disabled<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_disabled<T>(self, v: Option<T>) -> Self
Sourcepub fn set_enable_logging<T>(self, v: T) -> Self
pub fn set_enable_logging<T>(self, v: T) -> Self
Sets the value of enable_logging.
§Example
let x = FirewallPolicyRule::new().set_enable_logging(true);Sourcepub fn set_or_clear_enable_logging<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_enable_logging<T>(self, v: Option<T>) -> Self
Sets or clears the value of enable_logging.
§Example
let x = FirewallPolicyRule::new().set_or_clear_enable_logging(Some(false));
let x = FirewallPolicyRule::new().set_or_clear_enable_logging(None::<bool>);Sourcepub fn set_or_clear_kind<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_kind<T>(self, v: Option<T>) -> Self
Sourcepub fn set_match<T>(self, v: T) -> Selfwhere
T: Into<FirewallPolicyRuleMatcher>,
pub fn set_match<T>(self, v: T) -> Selfwhere
T: Into<FirewallPolicyRuleMatcher>,
Sourcepub fn set_or_clear_match<T>(self, v: Option<T>) -> Selfwhere
T: Into<FirewallPolicyRuleMatcher>,
pub fn set_or_clear_match<T>(self, v: Option<T>) -> Selfwhere
T: Into<FirewallPolicyRuleMatcher>,
Sets or clears the value of r#match.
§Example
use google_cloud_compute_v1::model::FirewallPolicyRuleMatcher;
let x = FirewallPolicyRule::new().set_or_clear_match(Some(FirewallPolicyRuleMatcher::default()/* use setters */));
let x = FirewallPolicyRule::new().set_or_clear_match(None::<FirewallPolicyRuleMatcher>);Sourcepub fn set_priority<T>(self, v: T) -> Self
pub fn set_priority<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_priority<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_priority<T>(self, v: Option<T>) -> Self
Sourcepub fn set_rule_name<T>(self, v: T) -> Self
pub fn set_rule_name<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_rule_name<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_rule_name<T>(self, v: Option<T>) -> Self
Sourcepub fn set_rule_tuple_count<T>(self, v: T) -> Self
pub fn set_rule_tuple_count<T>(self, v: T) -> Self
Sets the value of rule_tuple_count.
§Example
let x = FirewallPolicyRule::new().set_rule_tuple_count(42);Sourcepub fn set_or_clear_rule_tuple_count<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_rule_tuple_count<T>(self, v: Option<T>) -> Self
Sets or clears the value of rule_tuple_count.
§Example
let x = FirewallPolicyRule::new().set_or_clear_rule_tuple_count(Some(42));
let x = FirewallPolicyRule::new().set_or_clear_rule_tuple_count(None::<i32>);Sourcepub fn set_security_profile_group<T>(self, v: T) -> Self
pub fn set_security_profile_group<T>(self, v: T) -> Self
Sets the value of security_profile_group.
§Example
let x = FirewallPolicyRule::new().set_security_profile_group("example");Sourcepub fn set_or_clear_security_profile_group<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_security_profile_group<T>(self, v: Option<T>) -> Self
Sets or clears the value of security_profile_group.
§Example
let x = FirewallPolicyRule::new().set_or_clear_security_profile_group(Some("example"));
let x = FirewallPolicyRule::new().set_or_clear_security_profile_group(None::<String>);Sourcepub fn set_target_resources<T, V>(self, v: T) -> Self
pub fn set_target_resources<T, V>(self, v: T) -> Self
Sets the value of target_resources.
§Example
let x = FirewallPolicyRule::new().set_target_resources(["a", "b", "c"]);Sets the value of target_secure_tags.
§Example
use google_cloud_compute_v1::model::FirewallPolicyRuleSecureTag;
let x = FirewallPolicyRule::new()
.set_target_secure_tags([
FirewallPolicyRuleSecureTag::default()/* use setters */,
FirewallPolicyRuleSecureTag::default()/* use (different) setters */,
]);Sourcepub fn set_target_service_accounts<T, V>(self, v: T) -> Self
pub fn set_target_service_accounts<T, V>(self, v: T) -> Self
Sets the value of target_service_accounts.
§Example
let x = FirewallPolicyRule::new().set_target_service_accounts(["a", "b", "c"]);Sourcepub fn set_tls_inspect<T>(self, v: T) -> Self
pub fn set_tls_inspect<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_tls_inspect<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_tls_inspect<T>(self, v: Option<T>) -> Self
Sets or clears the value of tls_inspect.
§Example
let x = FirewallPolicyRule::new().set_or_clear_tls_inspect(Some(false));
let x = FirewallPolicyRule::new().set_or_clear_tls_inspect(None::<bool>);Trait Implementations§
Source§impl Clone for FirewallPolicyRule
impl Clone for FirewallPolicyRule
Source§fn clone(&self) -> FirewallPolicyRule
fn clone(&self) -> FirewallPolicyRule
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more