commonMain.aws.sdk.kotlin.services.configservice.model.OrganizationCustomPolicyRuleMetadata.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of configservice-jvm Show documentation
Show all versions of configservice-jvm Show documentation
The AWS Kotlin client for Config Service
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.configservice.model
import aws.smithy.kotlin.runtime.SdkDsl
/**
* An object that specifies metadata for your organization's Config Custom Policy rule. The metadata includes the runtime system in use, which accounts have debug logging enabled, and other custom rule metadata, such as resource type, resource ID of Amazon Web Services resource, and organization trigger types that initiate Config to evaluate Amazon Web Services resources against a rule.
*/
public class OrganizationCustomPolicyRuleMetadata private constructor(builder: Builder) {
/**
* A list of accounts that you can enable debug logging for your organization Config Custom Policy rule. List is null when debug logging is enabled for all accounts.
*/
public val debugLogDeliveryAccounts: List? = builder.debugLogDeliveryAccounts
/**
* The description that you provide for your organization Config Custom Policy rule.
*/
public val description: kotlin.String? = builder.description
/**
* A string, in JSON format, that is passed to your organization Config Custom Policy rule.
*/
public val inputParameters: kotlin.String? = builder.inputParameters
/**
* The maximum frequency with which Config runs evaluations for a rule. Your Config Custom Policy rule is triggered when Config delivers the configuration snapshot. For more information, see ConfigSnapshotDeliveryProperties.
*/
public val maximumExecutionFrequency: aws.sdk.kotlin.services.configservice.model.MaximumExecutionFrequency? = builder.maximumExecutionFrequency
/**
* The type of notification that initiates Config to run an evaluation for a rule. For Config Custom Policy rules, Config supports change-initiated notification types:
* + `ConfigurationItemChangeNotification` - Initiates an evaluation when Config delivers a configuration item as a result of a resource change.
* + `OversizedConfigurationItemChangeNotification` - Initiates an evaluation when Config delivers an oversized configuration item. Config may generate this notification type when a resource changes and the notification exceeds the maximum size allowed by Amazon SNS.
*/
public val organizationConfigRuleTriggerTypes: List? = builder.organizationConfigRuleTriggerTypes
/**
* The runtime system for your organization Config Custom Policy rules. Guard is a policy-as-code language that allows you to write policies that are enforced by Config Custom Policy rules. For more information about Guard, see the [Guard GitHub Repository](https://github.com/aws-cloudformation/cloudformation-guard).
*/
public val policyRuntime: kotlin.String = requireNotNull(builder.policyRuntime) { "A non-null value must be provided for policyRuntime" }
/**
* The policy definition containing the logic for your organization Config Custom Policy rule.
*/
public val policyText: kotlin.String = requireNotNull(builder.policyText) { "A non-null value must be provided for policyText" }
/**
* The ID of the Amazon Web Services resource that was evaluated.
*/
public val resourceIdScope: kotlin.String? = builder.resourceIdScope
/**
* The type of the Amazon Web Services resource that was evaluated.
*/
public val resourceTypesScope: List? = builder.resourceTypesScope
/**
* One part of a key-value pair that make up a tag. A key is a general label that acts like a category for more specific tag values.
*/
public val tagKeyScope: kotlin.String? = builder.tagKeyScope
/**
* The optional part of a key-value pair that make up a tag. A value acts as a descriptor within a tag category (key).
*/
public val tagValueScope: kotlin.String? = builder.tagValueScope
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.configservice.model.OrganizationCustomPolicyRuleMetadata = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("OrganizationCustomPolicyRuleMetadata(")
append("debugLogDeliveryAccounts=$debugLogDeliveryAccounts,")
append("description=$description,")
append("inputParameters=$inputParameters,")
append("maximumExecutionFrequency=$maximumExecutionFrequency,")
append("organizationConfigRuleTriggerTypes=$organizationConfigRuleTriggerTypes,")
append("policyRuntime=$policyRuntime,")
append("policyText=$policyText,")
append("resourceIdScope=$resourceIdScope,")
append("resourceTypesScope=$resourceTypesScope,")
append("tagKeyScope=$tagKeyScope,")
append("tagValueScope=$tagValueScope")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = debugLogDeliveryAccounts?.hashCode() ?: 0
result = 31 * result + (description?.hashCode() ?: 0)
result = 31 * result + (inputParameters?.hashCode() ?: 0)
result = 31 * result + (maximumExecutionFrequency?.hashCode() ?: 0)
result = 31 * result + (organizationConfigRuleTriggerTypes?.hashCode() ?: 0)
result = 31 * result + (policyRuntime.hashCode())
result = 31 * result + (policyText.hashCode())
result = 31 * result + (resourceIdScope?.hashCode() ?: 0)
result = 31 * result + (resourceTypesScope?.hashCode() ?: 0)
result = 31 * result + (tagKeyScope?.hashCode() ?: 0)
result = 31 * result + (tagValueScope?.hashCode() ?: 0)
return result
}
override fun equals(other: kotlin.Any?): kotlin.Boolean {
if (this === other) return true
if (other == null || this::class != other::class) return false
other as OrganizationCustomPolicyRuleMetadata
if (debugLogDeliveryAccounts != other.debugLogDeliveryAccounts) return false
if (description != other.description) return false
if (inputParameters != other.inputParameters) return false
if (maximumExecutionFrequency != other.maximumExecutionFrequency) return false
if (organizationConfigRuleTriggerTypes != other.organizationConfigRuleTriggerTypes) return false
if (policyRuntime != other.policyRuntime) return false
if (policyText != other.policyText) return false
if (resourceIdScope != other.resourceIdScope) return false
if (resourceTypesScope != other.resourceTypesScope) return false
if (tagKeyScope != other.tagKeyScope) return false
if (tagValueScope != other.tagValueScope) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.configservice.model.OrganizationCustomPolicyRuleMetadata = Builder(this).apply(block).build()
@SdkDsl
public class Builder {
/**
* A list of accounts that you can enable debug logging for your organization Config Custom Policy rule. List is null when debug logging is enabled for all accounts.
*/
public var debugLogDeliveryAccounts: List? = null
/**
* The description that you provide for your organization Config Custom Policy rule.
*/
public var description: kotlin.String? = null
/**
* A string, in JSON format, that is passed to your organization Config Custom Policy rule.
*/
public var inputParameters: kotlin.String? = null
/**
* The maximum frequency with which Config runs evaluations for a rule. Your Config Custom Policy rule is triggered when Config delivers the configuration snapshot. For more information, see ConfigSnapshotDeliveryProperties.
*/
public var maximumExecutionFrequency: aws.sdk.kotlin.services.configservice.model.MaximumExecutionFrequency? = null
/**
* The type of notification that initiates Config to run an evaluation for a rule. For Config Custom Policy rules, Config supports change-initiated notification types:
* + `ConfigurationItemChangeNotification` - Initiates an evaluation when Config delivers a configuration item as a result of a resource change.
* + `OversizedConfigurationItemChangeNotification` - Initiates an evaluation when Config delivers an oversized configuration item. Config may generate this notification type when a resource changes and the notification exceeds the maximum size allowed by Amazon SNS.
*/
public var organizationConfigRuleTriggerTypes: List? = null
/**
* The runtime system for your organization Config Custom Policy rules. Guard is a policy-as-code language that allows you to write policies that are enforced by Config Custom Policy rules. For more information about Guard, see the [Guard GitHub Repository](https://github.com/aws-cloudformation/cloudformation-guard).
*/
public var policyRuntime: kotlin.String? = null
/**
* The policy definition containing the logic for your organization Config Custom Policy rule.
*/
public var policyText: kotlin.String? = null
/**
* The ID of the Amazon Web Services resource that was evaluated.
*/
public var resourceIdScope: kotlin.String? = null
/**
* The type of the Amazon Web Services resource that was evaluated.
*/
public var resourceTypesScope: List? = null
/**
* One part of a key-value pair that make up a tag. A key is a general label that acts like a category for more specific tag values.
*/
public var tagKeyScope: kotlin.String? = null
/**
* The optional part of a key-value pair that make up a tag. A value acts as a descriptor within a tag category (key).
*/
public var tagValueScope: kotlin.String? = null
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.configservice.model.OrganizationCustomPolicyRuleMetadata) : this() {
this.debugLogDeliveryAccounts = x.debugLogDeliveryAccounts
this.description = x.description
this.inputParameters = x.inputParameters
this.maximumExecutionFrequency = x.maximumExecutionFrequency
this.organizationConfigRuleTriggerTypes = x.organizationConfigRuleTriggerTypes
this.policyRuntime = x.policyRuntime
this.policyText = x.policyText
this.resourceIdScope = x.resourceIdScope
this.resourceTypesScope = x.resourceTypesScope
this.tagKeyScope = x.tagKeyScope
this.tagValueScope = x.tagValueScope
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.configservice.model.OrganizationCustomPolicyRuleMetadata = OrganizationCustomPolicyRuleMetadata(this)
internal fun correctErrors(): Builder {
if (policyRuntime == null) policyRuntime = ""
if (policyText == null) policyText = ""
return this
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy