#![doc = "generated by AutoRust"]
#![allow(non_camel_case_types)]
#![allow(unused_imports)]
use serde::{Deserialize, Serialize};
#[doc = "Actions to invoke when the alert fires."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct Action {
#[doc = "Action Group resource Id to invoke when the alert fires."]
#[serde(rename = "actionGroupId", default, skip_serializing_if = "Option::is_none")]
pub action_group_id: Option<String>,
#[doc = "The properties of a webhook object."]
#[serde(rename = "webHookProperties", default, skip_serializing_if = "Option::is_none")]
pub web_hook_properties: Option<serde_json::Value>,
}
impl Action {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "A condition of the scheduled query rule."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub struct Condition {
#[doc = "Log query alert"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub query: Option<String>,
#[doc = "Aggregation type"]
#[serde(rename = "timeAggregation")]
pub time_aggregation: condition::TimeAggregation,
#[doc = "The column containing the metric measure number."]
#[serde(rename = "metricMeasureColumn", default, skip_serializing_if = "Option::is_none")]
pub metric_measure_column: Option<String>,
#[doc = "The column containing the resource id. The content of the column must be a uri formatted as resource id"]
#[serde(rename = "resourceIdColumn", default, skip_serializing_if = "Option::is_none")]
pub resource_id_column: Option<String>,
#[doc = "List of Dimensions conditions"]
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub dimensions: Vec<Dimension>,
#[doc = "The criteria operator."]
pub operator: condition::Operator,
#[doc = "the criteria threshold value that activates the alert."]
pub threshold: f64,
#[doc = "The minimum number of violations required within the selected lookback time window required to raise an alert."]
#[serde(rename = "failingPeriods", default, skip_serializing_if = "Option::is_none")]
pub failing_periods: Option<condition::FailingPeriods>,
}
impl Condition {
pub fn new(time_aggregation: condition::TimeAggregation, operator: condition::Operator, threshold: f64) -> Self {
Self {
query: None,
time_aggregation,
metric_measure_column: None,
resource_id_column: None,
dimensions: Vec::new(),
operator,
threshold,
failing_periods: None,
}
}
}
pub mod condition {
use super::*;
#[doc = "Aggregation type"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub enum TimeAggregation {
Count,
Average,
Minimum,
Maximum,
Total,
}
#[doc = "The criteria operator."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub enum Operator {
Equals,
GreaterThan,
GreaterThanOrEqual,
LessThan,
LessThanOrEqual,
}
#[doc = "The minimum number of violations required within the selected lookback time window required to raise an alert."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct FailingPeriods {
#[doc = "The number of aggregated lookback points. The lookback time window is calculated based on the aggregation granularity (windowSize) and the selected number of aggregated points. Default value is 1"]
#[serde(rename = "numberOfEvaluationPeriods", default, skip_serializing_if = "Option::is_none")]
pub number_of_evaluation_periods: Option<i64>,
#[doc = "The number of violations to trigger an alert. Should be smaller or equal to numberOfEvaluationPeriods. Default value is 1"]
#[serde(rename = "minFailingPeriodsToAlert", default, skip_serializing_if = "Option::is_none")]
pub min_failing_periods_to_alert: Option<i64>,
}
impl FailingPeriods {
pub fn new() -> Self {
Self::default()
}
}
}
#[doc = "Dimension splitting and filtering definition"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub struct Dimension {
#[doc = "Name of the dimension"]
pub name: String,
#[doc = "Operator for dimension values"]
pub operator: dimension::Operator,
#[doc = "List of dimension values"]
pub values: Vec<String>,
}
impl Dimension {
pub fn new(name: String, operator: dimension::Operator, values: Vec<String>) -> Self {
Self { name, operator, values }
}
}
pub mod dimension {
use super::*;
#[doc = "Operator for dimension values"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub enum Operator {
Include,
Exclude,
}
}
#[doc = "The resource management error additional info."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ErrorAdditionalInfo {
#[doc = "The additional info type."]
#[serde(rename = "type", default, skip_serializing_if = "Option::is_none")]
pub type_: Option<String>,
#[doc = "The additional info."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub info: Option<serde_json::Value>,
}
impl ErrorAdditionalInfo {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "Describes the format of Error response."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ErrorContract {
#[doc = "Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.)"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub error: Option<ErrorResponse>,
}
impl ErrorContract {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.)"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ErrorResponse {
#[doc = "The error code."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub code: Option<String>,
#[doc = "The error message."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub message: Option<String>,
#[doc = "The error target."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub target: Option<String>,
#[doc = "The error details."]
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub details: Vec<ErrorResponse>,
#[doc = "The error additional info."]
#[serde(rename = "additionalInfo", default, skip_serializing_if = "Vec::is_empty")]
pub additional_info: Vec<ErrorAdditionalInfo>,
}
impl ErrorResponse {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "Common fields that are returned in the response for all Azure Resource Manager resources"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct Resource {
#[doc = "Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub id: Option<String>,
#[doc = "The name of the resource"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[doc = "The type of the resource. E.g. \"Microsoft.Compute/virtualMachines\" or \"Microsoft.Storage/storageAccounts\""]
#[serde(rename = "type", default, skip_serializing_if = "Option::is_none")]
pub type_: Option<String>,
}
impl Resource {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "The rule criteria that defines the conditions of the scheduled query rule."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ScheduledQueryRuleCriteria {
#[doc = "A list of conditions to evaluate against the specified scopes"]
#[serde(rename = "allOf", default, skip_serializing_if = "Vec::is_empty")]
pub all_of: Vec<Condition>,
}
impl ScheduledQueryRuleCriteria {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "scheduled query rule Definition"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ScheduledQueryRuleProperties {
#[doc = "The api-version used when creating this alert rule"]
#[serde(rename = "createdWithApiVersion", default, skip_serializing_if = "Option::is_none")]
pub created_with_api_version: Option<String>,
#[doc = "True if alert rule is legacy Log Analytic rule"]
#[serde(rename = "isLegacyLogAnalyticsRule", default, skip_serializing_if = "Option::is_none")]
pub is_legacy_log_analytics_rule: Option<bool>,
#[doc = "The description of the scheduled query rule."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub description: Option<String>,
#[doc = "The display name of the alert rule"]
#[serde(rename = "displayName", default, skip_serializing_if = "Option::is_none")]
pub display_name: Option<String>,
#[doc = "Severity of the alert. Should be an integer between [0-4]. Value of 0 is severest"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub severity: Option<scheduled_query_rule_properties::Severity>,
#[doc = "The flag which indicates whether this scheduled query rule is enabled. Value should be true or false"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub enabled: Option<bool>,
#[doc = "The list of resource id's that this scheduled query rule is scoped to."]
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub scopes: Vec<String>,
#[doc = "How often the scheduled query rule is evaluated represented in ISO 8601 duration format."]
#[serde(rename = "evaluationFrequency", default, skip_serializing_if = "Option::is_none")]
pub evaluation_frequency: Option<String>,
#[doc = "The period of time (in ISO 8601 duration format) on which the Alert query will be executed (bin size)."]
#[serde(rename = "windowSize", default, skip_serializing_if = "Option::is_none")]
pub window_size: Option<String>,
#[doc = "If specified then overrides the query time range (default is WindowSize*NumberOfEvaluationPeriods)"]
#[serde(rename = "overrideQueryTimeRange", default, skip_serializing_if = "Option::is_none")]
pub override_query_time_range: Option<String>,
#[doc = "List of resource type of the target resource(s) on which the alert is created/updated. For example if the scope is a resource group and targetResourceTypes is Microsoft.Compute/virtualMachines, then a different alert will be fired for each virtual machine in the resource group which meet the alert criteria"]
#[serde(rename = "targetResourceTypes", default, skip_serializing_if = "Vec::is_empty")]
pub target_resource_types: Vec<String>,
#[doc = "The rule criteria that defines the conditions of the scheduled query rule."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub criteria: Option<ScheduledQueryRuleCriteria>,
#[doc = "Mute actions for the chosen period of time (in ISO 8601 duration format) after the alert is fired."]
#[serde(rename = "muteActionsDuration", default, skip_serializing_if = "Option::is_none")]
pub mute_actions_duration: Option<String>,
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub actions: Vec<Action>,
}
impl ScheduledQueryRuleProperties {
pub fn new() -> Self {
Self::default()
}
}
pub mod scheduled_query_rule_properties {
use super::*;
#[doc = "Severity of the alert. Should be an integer between [0-4]. Value of 0 is severest"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub enum Severity {
#[serde(rename = "0")]
N0,
#[serde(rename = "1")]
N1,
#[serde(rename = "2")]
N2,
#[serde(rename = "3")]
N3,
#[serde(rename = "4")]
N4,
}
}
#[doc = "The scheduled query rule resource."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub struct ScheduledQueryRuleResource {
#[serde(flatten)]
pub tracked_resource: TrackedResource,
#[doc = "Metadata used by portal/tooling/etc to render different UX experiences for resources of the same type; e.g. ApiApps are a kind of Microsoft.Web/sites type. If supported, the resource provider must validate and persist this value."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub kind: Option<String>,
#[doc = "The etag field is *not* required. If it is provided in the response body, it must also be provided as a header per the normal etag convention. Entity tags are used for comparing two or more entities from the same requested resource. HTTP/1.1 uses entity tags in the etag (section 14.19), If-Match (section 14.24), If-None-Match (section 14.26), and If-Range (section 14.27) header fields. "]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub etag: Option<String>,
#[doc = "scheduled query rule Definition"]
pub properties: ScheduledQueryRuleProperties,
}
impl ScheduledQueryRuleResource {
pub fn new(tracked_resource: TrackedResource, properties: ScheduledQueryRuleProperties) -> Self {
Self {
tracked_resource,
kind: None,
etag: None,
properties,
}
}
}
#[doc = "Represents a collection of scheduled query rule resources."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ScheduledQueryRuleResourceCollection {
#[doc = "The values for the scheduled query rule resources."]
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub value: Vec<ScheduledQueryRuleResource>,
}
impl ScheduledQueryRuleResourceCollection {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "The scheduled query rule resource for patch operations."]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, Default)]
pub struct ScheduledQueryRuleResourcePatch {
#[doc = "Resource tags"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub tags: Option<serde_json::Value>,
#[doc = "scheduled query rule Definition"]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub properties: Option<ScheduledQueryRuleProperties>,
}
impl ScheduledQueryRuleResourcePatch {
pub fn new() -> Self {
Self::default()
}
}
#[doc = "The resource model definition for an Azure Resource Manager tracked top level resource which has 'tags' and a 'location'"]
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
pub struct TrackedResource {
#[serde(flatten)]
pub resource: Resource,
#[doc = "Resource tags."]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub tags: Option<serde_json::Value>,
#[doc = "The geo-location where the resource lives"]
pub location: String,
}
impl TrackedResource {
pub fn new(location: String) -> Self {
Self {
resource: Resource::default(),
tags: None,
location,
}
}
}