/* * 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 wisdom-2020-10-19.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.ConnectWisdomService.Model { /// /// Container for the parameters to the CreateKnowledgeBase operation. /// Creates a knowledge base. /// /// /// /// When using this API, you cannot reuse Amazon /// AppIntegrations DataIntegrations with external knowledge bases such as Salesforce /// and ServiceNow. If you do, you'll get an InvalidRequestException error. /// /// /// /// /// For example, you're programmatically managing your external knowledge base, and you /// want to add or remove one of the fields that is being ingested from Salesforce. Do /// the following: /// ///
  1. /// /// Call DeleteKnowledgeBase. /// ///
  2. /// /// Call DeleteDataIntegration. /// ///
  3. /// /// Call CreateDataIntegration /// to recreate the DataIntegration or a create different one. /// ///
  4. /// /// Call CreateKnowledgeBase. /// ///
///
public partial class CreateKnowledgeBaseRequest : AmazonConnectWisdomServiceRequest { private string _clientToken; private string _description; private KnowledgeBaseType _knowledgeBaseType; private string _name; private RenderingConfiguration _renderingConfiguration; private ServerSideEncryptionConfiguration _serverSideEncryptionConfiguration; private SourceConfiguration _sourceConfiguration; private Dictionary _tags = new Dictionary(); /// /// Gets and sets the property ClientToken. /// /// A unique, case-sensitive identifier that you provide to ensure the idempotency of /// the request. If not provided, the Amazon Web Services SDK populates this field. For /// more information about idempotency, see Making /// retries safe with idempotent APIs. /// /// [AWSProperty(Min=1, Max=4096)] public string ClientToken { get { return this._clientToken; } set { this._clientToken = value; } } // Check to see if ClientToken property is set internal bool IsSetClientToken() { return this._clientToken != null; } /// /// Gets and sets the property Description. /// /// The description. /// /// [AWSProperty(Min=1, Max=255)] public string Description { get { return this._description; } set { this._description = value; } } // Check to see if Description property is set internal bool IsSetDescription() { return this._description != null; } /// /// Gets and sets the property KnowledgeBaseType. /// /// The type of knowledge base. Only CUSTOM knowledge bases allow you to upload your own /// content. EXTERNAL knowledge bases support integrations with third-party systems whose /// content is synchronized automatically. /// /// [AWSProperty(Required=true)] public KnowledgeBaseType KnowledgeBaseType { get { return this._knowledgeBaseType; } set { this._knowledgeBaseType = value; } } // Check to see if KnowledgeBaseType property is set internal bool IsSetKnowledgeBaseType() { return this._knowledgeBaseType != null; } /// /// Gets and sets the property Name. /// /// The name of the knowledge base. /// /// [AWSProperty(Required=true, Min=1, Max=255)] 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; } /// /// Gets and sets the property RenderingConfiguration. /// /// Information about how to render the content. /// /// public RenderingConfiguration RenderingConfiguration { get { return this._renderingConfiguration; } set { this._renderingConfiguration = value; } } // Check to see if RenderingConfiguration property is set internal bool IsSetRenderingConfiguration() { return this._renderingConfiguration != null; } /// /// Gets and sets the property ServerSideEncryptionConfiguration. /// /// The KMS key used for encryption. /// /// public ServerSideEncryptionConfiguration ServerSideEncryptionConfiguration { get { return this._serverSideEncryptionConfiguration; } set { this._serverSideEncryptionConfiguration = value; } } // Check to see if ServerSideEncryptionConfiguration property is set internal bool IsSetServerSideEncryptionConfiguration() { return this._serverSideEncryptionConfiguration != null; } /// /// Gets and sets the property SourceConfiguration. /// /// The source of the knowledge base content. Only set this argument for EXTERNAL knowledge /// bases. /// /// public SourceConfiguration SourceConfiguration { get { return this._sourceConfiguration; } set { this._sourceConfiguration = value; } } // Check to see if SourceConfiguration property is set internal bool IsSetSourceConfiguration() { return this._sourceConfiguration != null; } /// /// Gets and sets the property Tags. /// /// The tags used to organize, track, or control access for this resource. /// /// public Dictionary Tags { get { return this._tags; } set { this._tags = value; } } // Check to see if Tags property is set internal bool IsSetTags() { return this._tags != null && this._tags.Count > 0; } } }