commonMain.aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityConfig.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bedrock-jvm Show documentation
Show all versions of bedrock-jvm Show documentation
The AWS SDK for Kotlin client for Bedrock
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.bedrock.model
import aws.smithy.kotlin.runtime.SdkDsl
/**
* The PII entity to configure for the guardrail.
*/
public class GuardrailPiiEntityConfig private constructor(builder: Builder) {
/**
* Configure guardrail action when the PII entity is detected.
*/
public val action: aws.sdk.kotlin.services.bedrock.model.GuardrailSensitiveInformationAction = requireNotNull(builder.action) { "A non-null value must be provided for action" }
/**
* Configure guardrail type when the PII entity is detected.
*
* The following PIIs are used to block or mask sensitive information:
* + **General**
* + **ADDRESS**A physical address, such as "100 Main Street, Anytown, USA" or "Suite #12, Building 123". An address can include information such as the street, building, location, city, state, country, county, zip code, precinct, and neighborhood.
* + **AGE**An individual's age, including the quantity and unit of time. For example, in the phrase "I am 40 years old," Guarrails recognizes "40 years" as an age.
* + **NAME**An individual's name. This entity type does not include titles, such as Dr., Mr., Mrs., or Miss. guardrails doesn't apply this entity type to names that are part of organizations or addresses. For example, guardrails recognizes the "John Doe Organization" as an organization, and it recognizes "Jane Doe Street" as an address.
* + **EMAIL**An email address, such as *[email protected]*.
* + **PHONE**A phone number. This entity type also includes fax and pager numbers.
* + **USERNAME**A user name that identifies an account, such as a login name, screen name, nick name, or handle.
* + **PASSWORD**An alphanumeric string that is used as a password, such as "**very20special#pass**".
* + **DRIVER_ID**The number assigned to a driver's license, which is an official document permitting an individual to operate one or more motorized vehicles on a public road. A driver's license number consists of alphanumeric characters.
* + **LICENSE_PLATE**A license plate for a vehicle is issued by the state or country where the vehicle is registered. The format for passenger vehicles is typically five to eight digits, consisting of upper-case letters and numbers. The format varies depending on the location of the issuing state or country.
* + **VEHICLE_IDENTIFICATION_NUMBER**A Vehicle Identification Number (VIN) uniquely identifies a vehicle. VIN content and format are defined in the *ISO 3779* specification. Each country has specific codes and formats for VINs.
* + **Finance**
* + **REDIT_DEBIT_CARD_CVV**A three-digit card verification code (CVV) that is present on VISA, MasterCard, and Discover credit and debit cards. For American Express credit or debit cards, the CVV is a four-digit numeric code.
* + **CREDIT_DEBIT_CARD_EXPIRY**The expiration date for a credit or debit card. This number is usually four digits long and is often formatted as *month/year* or *MM/YY*. Guardrails recognizes expiration dates such as *01/21*, *01/2021*, and *Jan 2021*.
* + **CREDIT_DEBIT_CARD_NUMBER**The number for a credit or debit card. These numbers can vary from 13 to 16 digits in length. However, Amazon Comprehend also recognizes credit or debit card numbers when only the last four digits are present.
* + **PIN**A four-digit personal identification number (PIN) with which you can access your bank account.
* + **INTERNATIONAL_BANK_ACCOUNT_NUMBER**An International Bank Account Number has specific formats in each country. For more information, see [www.iban.com/structure](https://www.iban.com/structure).
* + **SWIFT_CODE**A SWIFT code is a standard format of Bank Identifier Code (BIC) used to specify a particular bank or branch. Banks use these codes for money transfers such as international wire transfers.SWIFT codes consist of eight or 11 characters. The 11-digit codes refer to specific branches, while eight-digit codes (or 11-digit codes ending in 'XXX') refer to the head or primary office.
* + **IT**
* + **IP_ADDRESS**An IPv4 address, such as *198.51.100.0*.
* + **MAC_ADDRESS**A *media access control* (MAC) address is a unique identifier assigned to a network interface controller (NIC).
* + **URL**A web address, such as *www.example.com*.
* + **AWS_ACCESS_KEY**A unique identifier that's associated with a secret access key; you use the access key ID and secret access key to sign programmatic Amazon Web Services requests cryptographically.
* + **AWS_SECRET_KEY**A unique identifier that's associated with an access key. You use the access key ID and secret access key to sign programmatic Amazon Web Services requests cryptographically.
* + **USA specific**
* + **US_BANK_ACCOUNT_NUMBER**A US bank account number, which is typically 10 to 12 digits long.
* + **US_BANK_ROUTING_NUMBER**A US bank account routing number. These are typically nine digits long,
* + **US_INDIVIDUAL_TAX_IDENTIFICATION_NUMBER**A US Individual Taxpayer Identification Number (ITIN) is a nine-digit number that starts with a "9" and contain a "7" or "8" as the fourth digit. An ITIN can be formatted with a space or a dash after the third and forth digits.
* + **US_PASSPORT_NUMBER**A US passport number. Passport numbers range from six to nine alphanumeric characters.
* + **US_SOCIAL_SECURITY_NUMBER**A US Social Security Number (SSN) is a nine-digit number that is issued to US citizens, permanent residents, and temporary working residents.
* + **Canada specific**
* + **CA_HEALTH_NUMBER**A Canadian Health Service Number is a 10-digit unique identifier, required for individuals to access healthcare benefits.
* + **CA_SOCIAL_INSURANCE_NUMBER**A Canadian Social Insurance Number (SIN) is a nine-digit unique identifier, required for individuals to access government programs and benefits.The SIN is formatted as three groups of three digits, such as *123-456-789*. A SIN can be validated through a simple check-digit process called the [Luhn algorithm](https://www.wikipedia.org/wiki/Luhn_algorithm).
* + **UK Specific**
* + **UK_NATIONAL_HEALTH_SERVICE_NUMBER**A UK National Health Service Number is a 10-17 digit number, such as *485 777 3456*. The current system formats the 10-digit number with spaces after the third and sixth digits. The final digit is an error-detecting checksum.
* + **UK_NATIONAL_INSURANCE_NUMBER**A UK National Insurance Number (NINO) provides individuals with access to National Insurance (social security) benefits. It is also used for some purposes in the UK tax system.The number is nine digits long and starts with two letters, followed by six numbers and one letter. A NINO can be formatted with a space or a dash after the two letters and after the second, forth, and sixth digits.
* + **UK_UNIQUE_TAXPAYER_REFERENCE_NUMBER**A UK Unique Taxpayer Reference (UTR) is a 10-digit number that identifies a taxpayer or a business.
* + **Custom**
* + **Regex filter** - You can use a regular expressions to define patterns for a guardrail to recognize and act upon such as serial number, booking ID etc..
*/
public val type: aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityType = requireNotNull(builder.type) { "A non-null value must be provided for type" }
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityConfig = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("GuardrailPiiEntityConfig(")
append("action=$action,")
append("type=$type")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = action.hashCode()
result = 31 * result + (type.hashCode())
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 GuardrailPiiEntityConfig
if (action != other.action) return false
if (type != other.type) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityConfig = Builder(this).apply(block).build()
@SdkDsl
public class Builder {
/**
* Configure guardrail action when the PII entity is detected.
*/
public var action: aws.sdk.kotlin.services.bedrock.model.GuardrailSensitiveInformationAction? = null
/**
* Configure guardrail type when the PII entity is detected.
*
* The following PIIs are used to block or mask sensitive information:
* + **General**
* + **ADDRESS**A physical address, such as "100 Main Street, Anytown, USA" or "Suite #12, Building 123". An address can include information such as the street, building, location, city, state, country, county, zip code, precinct, and neighborhood.
* + **AGE**An individual's age, including the quantity and unit of time. For example, in the phrase "I am 40 years old," Guarrails recognizes "40 years" as an age.
* + **NAME**An individual's name. This entity type does not include titles, such as Dr., Mr., Mrs., or Miss. guardrails doesn't apply this entity type to names that are part of organizations or addresses. For example, guardrails recognizes the "John Doe Organization" as an organization, and it recognizes "Jane Doe Street" as an address.
* + **EMAIL**An email address, such as *[email protected]*.
* + **PHONE**A phone number. This entity type also includes fax and pager numbers.
* + **USERNAME**A user name that identifies an account, such as a login name, screen name, nick name, or handle.
* + **PASSWORD**An alphanumeric string that is used as a password, such as "**very20special#pass**".
* + **DRIVER_ID**The number assigned to a driver's license, which is an official document permitting an individual to operate one or more motorized vehicles on a public road. A driver's license number consists of alphanumeric characters.
* + **LICENSE_PLATE**A license plate for a vehicle is issued by the state or country where the vehicle is registered. The format for passenger vehicles is typically five to eight digits, consisting of upper-case letters and numbers. The format varies depending on the location of the issuing state or country.
* + **VEHICLE_IDENTIFICATION_NUMBER**A Vehicle Identification Number (VIN) uniquely identifies a vehicle. VIN content and format are defined in the *ISO 3779* specification. Each country has specific codes and formats for VINs.
* + **Finance**
* + **REDIT_DEBIT_CARD_CVV**A three-digit card verification code (CVV) that is present on VISA, MasterCard, and Discover credit and debit cards. For American Express credit or debit cards, the CVV is a four-digit numeric code.
* + **CREDIT_DEBIT_CARD_EXPIRY**The expiration date for a credit or debit card. This number is usually four digits long and is often formatted as *month/year* or *MM/YY*. Guardrails recognizes expiration dates such as *01/21*, *01/2021*, and *Jan 2021*.
* + **CREDIT_DEBIT_CARD_NUMBER**The number for a credit or debit card. These numbers can vary from 13 to 16 digits in length. However, Amazon Comprehend also recognizes credit or debit card numbers when only the last four digits are present.
* + **PIN**A four-digit personal identification number (PIN) with which you can access your bank account.
* + **INTERNATIONAL_BANK_ACCOUNT_NUMBER**An International Bank Account Number has specific formats in each country. For more information, see [www.iban.com/structure](https://www.iban.com/structure).
* + **SWIFT_CODE**A SWIFT code is a standard format of Bank Identifier Code (BIC) used to specify a particular bank or branch. Banks use these codes for money transfers such as international wire transfers.SWIFT codes consist of eight or 11 characters. The 11-digit codes refer to specific branches, while eight-digit codes (or 11-digit codes ending in 'XXX') refer to the head or primary office.
* + **IT**
* + **IP_ADDRESS**An IPv4 address, such as *198.51.100.0*.
* + **MAC_ADDRESS**A *media access control* (MAC) address is a unique identifier assigned to a network interface controller (NIC).
* + **URL**A web address, such as *www.example.com*.
* + **AWS_ACCESS_KEY**A unique identifier that's associated with a secret access key; you use the access key ID and secret access key to sign programmatic Amazon Web Services requests cryptographically.
* + **AWS_SECRET_KEY**A unique identifier that's associated with an access key. You use the access key ID and secret access key to sign programmatic Amazon Web Services requests cryptographically.
* + **USA specific**
* + **US_BANK_ACCOUNT_NUMBER**A US bank account number, which is typically 10 to 12 digits long.
* + **US_BANK_ROUTING_NUMBER**A US bank account routing number. These are typically nine digits long,
* + **US_INDIVIDUAL_TAX_IDENTIFICATION_NUMBER**A US Individual Taxpayer Identification Number (ITIN) is a nine-digit number that starts with a "9" and contain a "7" or "8" as the fourth digit. An ITIN can be formatted with a space or a dash after the third and forth digits.
* + **US_PASSPORT_NUMBER**A US passport number. Passport numbers range from six to nine alphanumeric characters.
* + **US_SOCIAL_SECURITY_NUMBER**A US Social Security Number (SSN) is a nine-digit number that is issued to US citizens, permanent residents, and temporary working residents.
* + **Canada specific**
* + **CA_HEALTH_NUMBER**A Canadian Health Service Number is a 10-digit unique identifier, required for individuals to access healthcare benefits.
* + **CA_SOCIAL_INSURANCE_NUMBER**A Canadian Social Insurance Number (SIN) is a nine-digit unique identifier, required for individuals to access government programs and benefits.The SIN is formatted as three groups of three digits, such as *123-456-789*. A SIN can be validated through a simple check-digit process called the [Luhn algorithm](https://www.wikipedia.org/wiki/Luhn_algorithm).
* + **UK Specific**
* + **UK_NATIONAL_HEALTH_SERVICE_NUMBER**A UK National Health Service Number is a 10-17 digit number, such as *485 777 3456*. The current system formats the 10-digit number with spaces after the third and sixth digits. The final digit is an error-detecting checksum.
* + **UK_NATIONAL_INSURANCE_NUMBER**A UK National Insurance Number (NINO) provides individuals with access to National Insurance (social security) benefits. It is also used for some purposes in the UK tax system.The number is nine digits long and starts with two letters, followed by six numbers and one letter. A NINO can be formatted with a space or a dash after the two letters and after the second, forth, and sixth digits.
* + **UK_UNIQUE_TAXPAYER_REFERENCE_NUMBER**A UK Unique Taxpayer Reference (UTR) is a 10-digit number that identifies a taxpayer or a business.
* + **Custom**
* + **Regex filter** - You can use a regular expressions to define patterns for a guardrail to recognize and act upon such as serial number, booking ID etc..
*/
public var type: aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityType? = null
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityConfig) : this() {
this.action = x.action
this.type = x.type
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.bedrock.model.GuardrailPiiEntityConfig = GuardrailPiiEntityConfig(this)
internal fun correctErrors(): Builder {
if (action == null) action = GuardrailSensitiveInformationAction.SdkUnknown("no value provided")
if (type == null) type = GuardrailPiiEntityType.SdkUnknown("no value provided")
return this
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy