All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.kendra.model.Document Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWSKendraFrontend module holds the client classes that are used for communicating with AWSKendraFrontend Service

There is a newer version: 1.12.780
Show newest version
/*
 * Copyright 2019-2024 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.
 */
package com.amazonaws.services.kendra.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* A document in an index. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class Document implements Serializable, Cloneable, StructuredPojo { /** *

* A identifier of the document in the index. *

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents with * their unique IDs and then use the BatchPutDocument API to index the same documents, or vice versa. * You can delete a data source and then use the BatchPutDocument API to index the same documents, or * vice versa. *

*/ private String id; /** *

* The title of the document. *

*/ private String title; /** *

* The contents of the document. *

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to encode * the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If you are calling * the Amazon Kendra endpoint directly using REST, you must base64 encode the contents before sending. *

*/ private java.nio.ByteBuffer blob; private S3Path s3Path; /** *

* Custom attributes to apply to the document. Use the custom attributes to provide additional information for * searching, to provide facets for refining searches, and to provide additional information in the query response. *

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on the * synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an optional custom * attribute as Amazon Kendra will use the ID of a running sync job. *

*/ private java.util.List attributes; /** *

* Information on principals (users and/or groups) and which documents they should have access to. This is useful * for user context filtering, where search results are filtered based on the user or their group access to * documents. *

*/ private java.util.List accessControlList; /** *

* The list of principal lists that * define the hierarchy for which documents users should have access to. *

*/ private java.util.List hierarchicalAccessControlList; /** *

* The file type of the document in the Blob field. *

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, you * must add the HTML start and closing tags (<HTML>content</HTML>) around the * content. *

*/ private String contentType; /** *

* The identifier of the access control configuration that you want to apply to the document. *

*/ private String accessControlConfigurationId; /** *

* A identifier of the document in the index. *

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents with * their unique IDs and then use the BatchPutDocument API to index the same documents, or vice versa. * You can delete a data source and then use the BatchPutDocument API to index the same documents, or * vice versa. *

* * @param id * A identifier of the document in the index.

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents * with their unique IDs and then use the BatchPutDocument API to index the same documents, or * vice versa. You can delete a data source and then use the BatchPutDocument API to index the * same documents, or vice versa. */ public void setId(String id) { this.id = id; } /** *

* A identifier of the document in the index. *

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents with * their unique IDs and then use the BatchPutDocument API to index the same documents, or vice versa. * You can delete a data source and then use the BatchPutDocument API to index the same documents, or * vice versa. *

* * @return A identifier of the document in the index.

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents * with their unique IDs and then use the BatchPutDocument API to index the same documents, or * vice versa. You can delete a data source and then use the BatchPutDocument API to index the * same documents, or vice versa. */ public String getId() { return this.id; } /** *

* A identifier of the document in the index. *

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents with * their unique IDs and then use the BatchPutDocument API to index the same documents, or vice versa. * You can delete a data source and then use the BatchPutDocument API to index the same documents, or * vice versa. *

* * @param id * A identifier of the document in the index.

*

* Note, each document ID must be unique per index. You cannot create a data source to index your documents * with their unique IDs and then use the BatchPutDocument API to index the same documents, or * vice versa. You can delete a data source and then use the BatchPutDocument API to index the * same documents, or vice versa. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withId(String id) { setId(id); return this; } /** *

* The title of the document. *

* * @param title * The title of the document. */ public void setTitle(String title) { this.title = title; } /** *

* The title of the document. *

* * @return The title of the document. */ public String getTitle() { return this.title; } /** *

* The title of the document. *

* * @param title * The title of the document. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withTitle(String title) { setTitle(title); return this; } /** *

* The contents of the document. *

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to encode * the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If you are calling * the Amazon Kendra endpoint directly using REST, you must base64 encode the contents before sending. *

*

* The AWS SDK for Java performs a Base64 encoding on this field before sending this request to the AWS service. * Users of the SDK should not perform Base64 encoding on this field. *

*

* Warning: ByteBuffers returned by the SDK are mutable. Changes to the content or position of the byte buffer will * be seen by all objects that have a reference to this object. It is recommended to call ByteBuffer.duplicate() or * ByteBuffer.asReadOnlyBuffer() before using or reading from the buffer. This behavior will be changed in a future * major version of the SDK. *

* * @param blob * The contents of the document.

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to * encode the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If * you are calling the Amazon Kendra endpoint directly using REST, you must base64 encode the contents before * sending. */ public void setBlob(java.nio.ByteBuffer blob) { this.blob = blob; } /** *

* The contents of the document. *

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to encode * the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If you are calling * the Amazon Kendra endpoint directly using REST, you must base64 encode the contents before sending. *

*

* {@code ByteBuffer}s are stateful. Calling their {@code get} methods changes their {@code position}. We recommend * using {@link java.nio.ByteBuffer#asReadOnlyBuffer()} to create a read-only view of the buffer with an independent * {@code position}, and calling {@code get} methods on this rather than directly on the returned {@code ByteBuffer}. * Doing so will ensure that anyone else using the {@code ByteBuffer} will not be affected by changes to the * {@code position}. *

* * @return The contents of the document.

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to * encode the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If * you are calling the Amazon Kendra endpoint directly using REST, you must base64 encode the contents * before sending. */ public java.nio.ByteBuffer getBlob() { return this.blob; } /** *

* The contents of the document. *

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to encode * the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If you are calling * the Amazon Kendra endpoint directly using REST, you must base64 encode the contents before sending. *

*

* The AWS SDK for Java performs a Base64 encoding on this field before sending this request to the AWS service. * Users of the SDK should not perform Base64 encoding on this field. *

*

* Warning: ByteBuffers returned by the SDK are mutable. Changes to the content or position of the byte buffer will * be seen by all objects that have a reference to this object. It is recommended to call ByteBuffer.duplicate() or * ByteBuffer.asReadOnlyBuffer() before using or reading from the buffer. This behavior will be changed in a future * major version of the SDK. *

* * @param blob * The contents of the document.

*

* Documents passed to the Blob parameter must be base64 encoded. Your code might not need to * encode the document file bytes if you're using an Amazon Web Services SDK to call Amazon Kendra APIs. If * you are calling the Amazon Kendra endpoint directly using REST, you must base64 encode the contents before * sending. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withBlob(java.nio.ByteBuffer blob) { setBlob(blob); return this; } /** * @param s3Path */ public void setS3Path(S3Path s3Path) { this.s3Path = s3Path; } /** * @return */ public S3Path getS3Path() { return this.s3Path; } /** * @param s3Path * @return Returns a reference to this object so that method calls can be chained together. */ public Document withS3Path(S3Path s3Path) { setS3Path(s3Path); return this; } /** *

* Custom attributes to apply to the document. Use the custom attributes to provide additional information for * searching, to provide facets for refining searches, and to provide additional information in the query response. *

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on the * synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an optional custom * attribute as Amazon Kendra will use the ID of a running sync job. *

* * @return Custom attributes to apply to the document. Use the custom attributes to provide additional information * for searching, to provide facets for refining searches, and to provide additional information in the * query response.

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on * the synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an * optional custom attribute as Amazon Kendra will use the ID of a running sync job. */ public java.util.List getAttributes() { return attributes; } /** *

* Custom attributes to apply to the document. Use the custom attributes to provide additional information for * searching, to provide facets for refining searches, and to provide additional information in the query response. *

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on the * synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an optional custom * attribute as Amazon Kendra will use the ID of a running sync job. *

* * @param attributes * Custom attributes to apply to the document. Use the custom attributes to provide additional information * for searching, to provide facets for refining searches, and to provide additional information in the query * response.

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on * the synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an * optional custom attribute as Amazon Kendra will use the ID of a running sync job. */ public void setAttributes(java.util.Collection attributes) { if (attributes == null) { this.attributes = null; return; } this.attributes = new java.util.ArrayList(attributes); } /** *

* Custom attributes to apply to the document. Use the custom attributes to provide additional information for * searching, to provide facets for refining searches, and to provide additional information in the query response. *

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on the * synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an optional custom * attribute as Amazon Kendra will use the ID of a running sync job. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setAttributes(java.util.Collection)} or {@link #withAttributes(java.util.Collection)} if you want to * override the existing values. *

* * @param attributes * Custom attributes to apply to the document. Use the custom attributes to provide additional information * for searching, to provide facets for refining searches, and to provide additional information in the query * response.

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on * the synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an * optional custom attribute as Amazon Kendra will use the ID of a running sync job. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withAttributes(DocumentAttribute... attributes) { if (this.attributes == null) { setAttributes(new java.util.ArrayList(attributes.length)); } for (DocumentAttribute ele : attributes) { this.attributes.add(ele); } return this; } /** *

* Custom attributes to apply to the document. Use the custom attributes to provide additional information for * searching, to provide facets for refining searches, and to provide additional information in the query response. *

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on the * synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an optional custom * attribute as Amazon Kendra will use the ID of a running sync job. *

* * @param attributes * Custom attributes to apply to the document. Use the custom attributes to provide additional information * for searching, to provide facets for refining searches, and to provide additional information in the query * response.

*

* For example, 'DataSourceId' and 'DataSourceSyncJobId' are custom attributes that provide information on * the synchronization of documents running on a data source. Note, 'DataSourceSyncJobId' could be an * optional custom attribute as Amazon Kendra will use the ID of a running sync job. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withAttributes(java.util.Collection attributes) { setAttributes(attributes); return this; } /** *

* Information on principals (users and/or groups) and which documents they should have access to. This is useful * for user context filtering, where search results are filtered based on the user or their group access to * documents. *

* * @return Information on principals (users and/or groups) and which documents they should have access to. This is * useful for user context filtering, where search results are filtered based on the user or their group * access to documents. */ public java.util.List getAccessControlList() { return accessControlList; } /** *

* Information on principals (users and/or groups) and which documents they should have access to. This is useful * for user context filtering, where search results are filtered based on the user or their group access to * documents. *

* * @param accessControlList * Information on principals (users and/or groups) and which documents they should have access to. This is * useful for user context filtering, where search results are filtered based on the user or their group * access to documents. */ public void setAccessControlList(java.util.Collection accessControlList) { if (accessControlList == null) { this.accessControlList = null; return; } this.accessControlList = new java.util.ArrayList(accessControlList); } /** *

* Information on principals (users and/or groups) and which documents they should have access to. This is useful * for user context filtering, where search results are filtered based on the user or their group access to * documents. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setAccessControlList(java.util.Collection)} or {@link #withAccessControlList(java.util.Collection)} if * you want to override the existing values. *

* * @param accessControlList * Information on principals (users and/or groups) and which documents they should have access to. This is * useful for user context filtering, where search results are filtered based on the user or their group * access to documents. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withAccessControlList(Principal... accessControlList) { if (this.accessControlList == null) { setAccessControlList(new java.util.ArrayList(accessControlList.length)); } for (Principal ele : accessControlList) { this.accessControlList.add(ele); } return this; } /** *

* Information on principals (users and/or groups) and which documents they should have access to. This is useful * for user context filtering, where search results are filtered based on the user or their group access to * documents. *

* * @param accessControlList * Information on principals (users and/or groups) and which documents they should have access to. This is * useful for user context filtering, where search results are filtered based on the user or their group * access to documents. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withAccessControlList(java.util.Collection accessControlList) { setAccessControlList(accessControlList); return this; } /** *

* The list of principal lists that * define the hierarchy for which documents users should have access to. *

* * @return The list of principal lists * that define the hierarchy for which documents users should have access to. */ public java.util.List getHierarchicalAccessControlList() { return hierarchicalAccessControlList; } /** *

* The list of principal lists that * define the hierarchy for which documents users should have access to. *

* * @param hierarchicalAccessControlList * The list of principal lists * that define the hierarchy for which documents users should have access to. */ public void setHierarchicalAccessControlList(java.util.Collection hierarchicalAccessControlList) { if (hierarchicalAccessControlList == null) { this.hierarchicalAccessControlList = null; return; } this.hierarchicalAccessControlList = new java.util.ArrayList(hierarchicalAccessControlList); } /** *

* The list of principal lists that * define the hierarchy for which documents users should have access to. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setHierarchicalAccessControlList(java.util.Collection)} or * {@link #withHierarchicalAccessControlList(java.util.Collection)} if you want to override the existing values. *

* * @param hierarchicalAccessControlList * The list of principal lists * that define the hierarchy for which documents users should have access to. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withHierarchicalAccessControlList(HierarchicalPrincipal... hierarchicalAccessControlList) { if (this.hierarchicalAccessControlList == null) { setHierarchicalAccessControlList(new java.util.ArrayList(hierarchicalAccessControlList.length)); } for (HierarchicalPrincipal ele : hierarchicalAccessControlList) { this.hierarchicalAccessControlList.add(ele); } return this; } /** *

* The list of principal lists that * define the hierarchy for which documents users should have access to. *

* * @param hierarchicalAccessControlList * The list of principal lists * that define the hierarchy for which documents users should have access to. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withHierarchicalAccessControlList(java.util.Collection hierarchicalAccessControlList) { setHierarchicalAccessControlList(hierarchicalAccessControlList); return this; } /** *

* The file type of the document in the Blob field. *

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, you * must add the HTML start and closing tags (<HTML>content</HTML>) around the * content. *

* * @param contentType * The file type of the document in the Blob field.

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, * you must add the HTML start and closing tags (<HTML>content</HTML>) * around the content. * @see ContentType */ public void setContentType(String contentType) { this.contentType = contentType; } /** *

* The file type of the document in the Blob field. *

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, you * must add the HTML start and closing tags (<HTML>content</HTML>) around the * content. *

* * @return The file type of the document in the Blob field.

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, * you must add the HTML start and closing tags (<HTML>content</HTML>) * around the content. * @see ContentType */ public String getContentType() { return this.contentType; } /** *

* The file type of the document in the Blob field. *

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, you * must add the HTML start and closing tags (<HTML>content</HTML>) around the * content. *

* * @param contentType * The file type of the document in the Blob field.

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, * you must add the HTML start and closing tags (<HTML>content</HTML>) * around the content. * @return Returns a reference to this object so that method calls can be chained together. * @see ContentType */ public Document withContentType(String contentType) { setContentType(contentType); return this; } /** *

* The file type of the document in the Blob field. *

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, you * must add the HTML start and closing tags (<HTML>content</HTML>) around the * content. *

* * @param contentType * The file type of the document in the Blob field.

*

* If you want to index snippets or subsets of HTML documents instead of the entirety of the HTML documents, * you must add the HTML start and closing tags (<HTML>content</HTML>) * around the content. * @return Returns a reference to this object so that method calls can be chained together. * @see ContentType */ public Document withContentType(ContentType contentType) { this.contentType = contentType.toString(); return this; } /** *

* The identifier of the access control configuration that you want to apply to the document. *

* * @param accessControlConfigurationId * The identifier of the access control configuration that you want to apply to the document. */ public void setAccessControlConfigurationId(String accessControlConfigurationId) { this.accessControlConfigurationId = accessControlConfigurationId; } /** *

* The identifier of the access control configuration that you want to apply to the document. *

* * @return The identifier of the access control configuration that you want to apply to the document. */ public String getAccessControlConfigurationId() { return this.accessControlConfigurationId; } /** *

* The identifier of the access control configuration that you want to apply to the document. *

* * @param accessControlConfigurationId * The identifier of the access control configuration that you want to apply to the document. * @return Returns a reference to this object so that method calls can be chained together. */ public Document withAccessControlConfigurationId(String accessControlConfigurationId) { setAccessControlConfigurationId(accessControlConfigurationId); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getId() != null) sb.append("Id: ").append(getId()).append(","); if (getTitle() != null) sb.append("Title: ").append(getTitle()).append(","); if (getBlob() != null) sb.append("Blob: ").append(getBlob()).append(","); if (getS3Path() != null) sb.append("S3Path: ").append(getS3Path()).append(","); if (getAttributes() != null) sb.append("Attributes: ").append(getAttributes()).append(","); if (getAccessControlList() != null) sb.append("AccessControlList: ").append(getAccessControlList()).append(","); if (getHierarchicalAccessControlList() != null) sb.append("HierarchicalAccessControlList: ").append(getHierarchicalAccessControlList()).append(","); if (getContentType() != null) sb.append("ContentType: ").append(getContentType()).append(","); if (getAccessControlConfigurationId() != null) sb.append("AccessControlConfigurationId: ").append(getAccessControlConfigurationId()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof Document == false) return false; Document other = (Document) obj; if (other.getId() == null ^ this.getId() == null) return false; if (other.getId() != null && other.getId().equals(this.getId()) == false) return false; if (other.getTitle() == null ^ this.getTitle() == null) return false; if (other.getTitle() != null && other.getTitle().equals(this.getTitle()) == false) return false; if (other.getBlob() == null ^ this.getBlob() == null) return false; if (other.getBlob() != null && other.getBlob().equals(this.getBlob()) == false) return false; if (other.getS3Path() == null ^ this.getS3Path() == null) return false; if (other.getS3Path() != null && other.getS3Path().equals(this.getS3Path()) == false) return false; if (other.getAttributes() == null ^ this.getAttributes() == null) return false; if (other.getAttributes() != null && other.getAttributes().equals(this.getAttributes()) == false) return false; if (other.getAccessControlList() == null ^ this.getAccessControlList() == null) return false; if (other.getAccessControlList() != null && other.getAccessControlList().equals(this.getAccessControlList()) == false) return false; if (other.getHierarchicalAccessControlList() == null ^ this.getHierarchicalAccessControlList() == null) return false; if (other.getHierarchicalAccessControlList() != null && other.getHierarchicalAccessControlList().equals(this.getHierarchicalAccessControlList()) == false) return false; if (other.getContentType() == null ^ this.getContentType() == null) return false; if (other.getContentType() != null && other.getContentType().equals(this.getContentType()) == false) return false; if (other.getAccessControlConfigurationId() == null ^ this.getAccessControlConfigurationId() == null) return false; if (other.getAccessControlConfigurationId() != null && other.getAccessControlConfigurationId().equals(this.getAccessControlConfigurationId()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getId() == null) ? 0 : getId().hashCode()); hashCode = prime * hashCode + ((getTitle() == null) ? 0 : getTitle().hashCode()); hashCode = prime * hashCode + ((getBlob() == null) ? 0 : getBlob().hashCode()); hashCode = prime * hashCode + ((getS3Path() == null) ? 0 : getS3Path().hashCode()); hashCode = prime * hashCode + ((getAttributes() == null) ? 0 : getAttributes().hashCode()); hashCode = prime * hashCode + ((getAccessControlList() == null) ? 0 : getAccessControlList().hashCode()); hashCode = prime * hashCode + ((getHierarchicalAccessControlList() == null) ? 0 : getHierarchicalAccessControlList().hashCode()); hashCode = prime * hashCode + ((getContentType() == null) ? 0 : getContentType().hashCode()); hashCode = prime * hashCode + ((getAccessControlConfigurationId() == null) ? 0 : getAccessControlConfigurationId().hashCode()); return hashCode; } @Override public Document clone() { try { return (Document) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.kendra.model.transform.DocumentMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy