/* * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ /* * Do not modify this file. This file is generated from the qldb-2019-01-02.normal.json service model. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; using System.Net; using Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.QLDB.Model { /// <summary> /// Container for the parameters to the UpdateLedger operation. /// Updates properties on a ledger. /// </summary> public partial class UpdateLedgerRequest : AmazonQLDBRequest { private bool? _deletionProtection; private string _kmsKey; private string _name; /// <summary> /// Gets and sets the property DeletionProtection. /// <para> /// Specifies whether the ledger is protected from being deleted by any user. If not defined /// during ledger creation, this feature is enabled (<code>true</code>) by default. /// </para> /// /// <para> /// If deletion protection is enabled, you must first disable it before you can delete /// the ledger. You can disable it by calling the <code>UpdateLedger</code> operation /// to set this parameter to <code>false</code>. /// </para> /// </summary> public bool DeletionProtection { get { return this._deletionProtection.GetValueOrDefault(); } set { this._deletionProtection = value; } } // Check to see if DeletionProtection property is set internal bool IsSetDeletionProtection() { return this._deletionProtection.HasValue; } /// <summary> /// Gets and sets the property KmsKey. /// <para> /// The key in Key Management Service (KMS) to use for encryption of data at rest in the /// ledger. For more information, see <a href="https://docs.aws.amazon.com/qldb/latest/developerguide/encryption-at-rest.html">Encryption /// at rest</a> in the <i>Amazon QLDB Developer Guide</i>. /// </para> /// /// <para> /// Use one of the following options to specify this parameter: /// </para> /// <ul> <li> /// <para> /// <code>AWS_OWNED_KMS_KEY</code>: Use an KMS key that is owned and managed by Amazon /// Web Services on your behalf. /// </para> /// </li> <li> /// <para> /// <b>Undefined</b>: Make no changes to the KMS key of the ledger. /// </para> /// </li> <li> /// <para> /// <b>A valid symmetric customer managed KMS key</b>: Use the specified symmetric encryption /// KMS key in your account that you create, own, and manage. /// </para> /// /// <para> /// Amazon QLDB does not support asymmetric keys. For more information, see <a href="https://docs.aws.amazon.com/kms/latest/developerguide/symmetric-asymmetric.html">Using /// symmetric and asymmetric keys</a> in the <i>Key Management Service Developer Guide</i>. /// </para> /// </li> </ul> /// <para> /// To specify a customer managed KMS key, you can use its key ID, Amazon Resource Name /// (ARN), alias name, or alias ARN. When using an alias name, prefix it with <code>"alias/"</code>. /// To specify a key in a different Amazon Web Services account, you must use the key /// ARN or alias ARN. /// </para> /// /// <para> /// For example: /// </para> /// <ul> <li> /// <para> /// Key ID: <code>1234abcd-12ab-34cd-56ef-1234567890ab</code> /// </para> /// </li> <li> /// <para> /// Key ARN: <code>arn:aws:kms:us-east-2:111122223333:key/1234abcd-12ab-34cd-56ef-1234567890ab</code> /// /// </para> /// </li> <li> /// <para> /// Alias name: <code>alias/ExampleAlias</code> /// </para> /// </li> <li> /// <para> /// Alias ARN: <code>arn:aws:kms:us-east-2:111122223333:alias/ExampleAlias</code> /// </para> /// </li> </ul> /// <para> /// For more information, see <a href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id">Key /// identifiers (KeyId)</a> in the <i>Key Management Service Developer Guide</i>. /// </para> /// </summary> [AWSProperty(Max=1600)] public string KmsKey { get { return this._kmsKey; } set { this._kmsKey = value; } } // Check to see if KmsKey property is set internal bool IsSetKmsKey() { return this._kmsKey != null; } /// <summary> /// Gets and sets the property Name. /// <para> /// The name of the ledger. /// </para> /// </summary> [AWSProperty(Required=true, Min=1, Max=32)] public string Name { get { return this._name; } set { this._name = value; } } // Check to see if Name property is set internal bool IsSetName() { return this._name != null; } } }