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

com.marklogic.client.document.DocumentManager Maven / Gradle / Ivy

There is a newer version: 7.0.0
Show newest version
/* * Copyright 2012-2019 MarkLogic Corporation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License 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.marklogic.client.document;

import java.util.Set;

import com.marklogic.client.FailedRequestException;
import com.marklogic.client.ForbiddenUserException;
import com.marklogic.client.io.Format;
import com.marklogic.client.util.RequestLogger;
import com.marklogic.client.ResourceNotFoundException;
import com.marklogic.client.Transaction;
import com.marklogic.client.io.marker.AbstractReadHandle;
import com.marklogic.client.io.marker.AbstractWriteHandle;
import com.marklogic.client.io.marker.DocumentMetadataReadHandle;
import com.marklogic.client.io.marker.DocumentMetadataWriteHandle;
import com.marklogic.client.io.marker.DocumentPatchHandle;
import com.marklogic.client.io.marker.SearchReadHandle;
import com.marklogic.client.query.QueryDefinition;
import com.marklogic.client.query.QueryManager;
import com.marklogic.client.query.QueryManager.QueryView;

/**
 * A Document Manager provides database operations on a document.
 *
 * @param  the set of handles for reading the document content from the database
 * @param  the set of handles for writing the document content to the database
 */
public interface DocumentManager {
  /**
   * The Metadata enumeration specifies the categories of metadata read from or written to the database.
   */
  public enum Metadata {
    /**
     * Specifies all document metadata categories.
     */
    ALL,
    /**
     * Specifies document collections.
     */
    COLLECTIONS,
    /**
     * Specifies document permissions.
     */
    PERMISSIONS,
    /**
     * Specifies document properties.
     */
    PROPERTIES,
    /**
     * Specifies document search quality.
     */
    QUALITY,
    /**
     * Specifies document metadata-values.
     */
    METADATAVALUES;

    @Override
    public String toString() {
      switch(this) {
      case METADATAVALUES:
        return "METADATA-VALUES";
      default:
        return this.name();
      }
    }
  }

  /**
   * Creates a document descriptor for identifying the uri of a document,
   * its format and mimetype, and its version.
   *
   * @param uri	the identifier for the document
   * @return	a descriptor for the document
   */
  DocumentDescriptor newDescriptor(String uri);

  /**
   * Creates a document uri template for assigning a uri to a document.
   * @param extension	the identifier for the document
   * @return	a template for the document uri
   */
  DocumentUriTemplate newDocumentUriTemplate(String extension);

  /**
   * For XMLDocumentManager or JSONDocumentManager, creates a builder for specifying changes
   * to the document and metadata of a document.  For GenericDocumentManager,
   * TextDocumentManager, and BinaryDocumentManager, creates a builder for specifying
   * changes to only the metadata of a document since binary and text documents cannot
   * be changed with patches.
   * @param pathFormat	the patch path language. Set to JSON for JSONPath or XML for XPath.
   * @return	the patch builder
   */
  DocumentMetadataPatchBuilder newPatchBuilder(Format pathFormat);

  /**
   * Checks whether a document exists and gets its byte length, format, mimetype, and version
   * if it does.
   *
   * To call exists(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId the URI identifier for the document
   * @return	a descriptor for the document or null if the document is not found
   */
  DocumentDescriptor exists(String docId)
    throws ForbiddenUserException, FailedRequestException;

  /**
   * Checks whether a document exists in an open transaction and gets its byte length, format,
   * mimetype, and version if it does.
   *
   * To call exists(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @return	a descriptor for the document or null if the document is not found
   */
  DocumentDescriptor exists(String docId, Transaction transaction)
    throws ForbiddenUserException, FailedRequestException;

  /**
   * Reads the document content from the database in the representation specified by the IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId the URI identifier for the document
   * @param as	the IO class for reading the content of the document
   * @param  the type of object that will be returned by the handle registered for it
   * @return	an object of the IO class with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T readAs(String docId, Class as)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document content from the database in the representation specified by the IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId the URI identifier for the document
   * @param as	the IO class for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param  the type of object that will be returned by the handle registered for it
   * @return	an object of the IO class with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T readAs(String docId, Class as, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document metadata and content from the database in the representation specified by the IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param as	the IO class for reading the content of the document
   * @param  the type of object that will be returned by the handle registered for it
   * @return	an object of the IO class with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T readAs(String docId, DocumentMetadataReadHandle metadataHandle, Class as)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document metadata and content from the database in the representation specified by the IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param as	the IO class for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param  the type of object that will be returned by the handle registered for it
   * @return	an object of the IO class with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T readAs(String docId, DocumentMetadataReadHandle metadataHandle, Class as, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Reads the document content from the database in the representation provided by the handle
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for reading the content of the document
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, T contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document content from the database as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, T contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document content from the database in the representations provided by the handles
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, T contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document content from the database as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, T contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Reads the document metadata and content from the database in the representations provided by the handles
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, DocumentMetadataReadHandle metadataHandle, T contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document metadata and content from the database as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, DocumentMetadataReadHandle metadataHandle, T contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document metadata and content from the database in the representations provided by the handles
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, DocumentMetadataReadHandle metadataHandle, T contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document metadata and content from the database as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, DocumentMetadataReadHandle metadataHandle, T contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;

  /**
   * Reads the document content from an open database transaction in the representation provided by the handle
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, T contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document content from an open database transaction  as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, T contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document content from an open database transaction in the representation provided by the handle
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, T contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document content from an open database transaction as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, T contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;

  /**
   * Reads the document metadata and content from an open database transaction in the representations provided by the handles
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, DocumentMetadataReadHandle metadataHandle, T contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document metadata and content from an open database transaction as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(String docId, DocumentMetadataReadHandle metadataHandle, T contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document metadata and content from an open database transaction in the representations provided by the handles
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, DocumentMetadataReadHandle metadataHandle, T contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Reads the document metadata and content from an open database transaction as transformed on the server.
   *
   * To call read(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param contentHandle	a handle for reading the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of content handle to return
   * @return	the content handle populated with the content of the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T read(DocumentDescriptor desc, DocumentMetadataReadHandle metadataHandle, T contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage read(String... uris);

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param serverTimestamp the point in time at which to read these
   *   documents.  The value must be a merge timestamp obtained from the
   *   server via getServerTimestamp() on any handle.
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  /* Hide the following for now because the API isn't yet fully fleshed-out
    DocumentPage read(long serverTimestamp, String... uris);
   */

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param transform the transform to be run on the server on each document (must already be installed)
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage read(ServerTransform transform, String... uris);

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param serverTimestamp the point in time at which to read these
   *   documents.  The value must be a merge timestamp obtained from the
   *   server via getServerTimestamp() on any handle.
   * @param transform the transform to be run on the server on each document (must already be installed)
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  /* Hide the following for now because the API isn't yet fully fleshed-out
    DocumentPage read(long serverTimestamp, ServerTransform transform, String... uris);
   */

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param transaction the transaction in which this read is participating
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage read(Transaction transaction, String... uris);

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param serverTimestamp the point in time at which to read these
   *   documents.  The value must be a merge timestamp obtained from the
   *   server via getServerTimestamp() on any handle.
   * @param transaction the transaction in which this read is participating
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  /* Hide the following for now because the API isn't yet fully fleshed-out
    DocumentPage read(long serverTimestamp, Transaction transaction, String... uris);
   */

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param transform the transform to be run on the server on each document (must already be installed)
   * @param transaction the transaction in which this read is participating
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage read(ServerTransform transform, Transaction transaction, String... uris);

  /**
   * Reads from the database a list of documents matching the provided uris.  Allows
   * iteration across matching documents and metadata (only if setMetadataCategories
   * has been called to request metadata).  To find out how many of your uris matched,
   * call the {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param serverTimestamp the point in time at which to read these
   *   documents.  The value must be a merge timestamp obtained from the
   *   server via getServerTimestamp() on any handle.
   * @param transform the transform to be run on the server on each document (must already be installed)
   * @param transaction the transaction in which this read is participating
   * @param uris the database uris identifying documents to retrieve
   * @return the DocumentPage of matching documents and metadata
   */
  /* Hide the following for now because the API isn't yet fully fleshed-out
    DocumentPage read(long serverTimestamp, ServerTransform transform, Transaction transaction, String... uris);
   */

  /**
   * Reads from the database the metadata for a list of documents matching the
   * provided uris.  Allows iteration across the metadata for matching documents
   * (only if setMetadataCategories has been called to request metadata).  To find
   * out how many of your uris matched, call the
   * {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param uris the database uris identifying documents
   * @return the DocumentPage of metadata from matching documents
   */
  DocumentPage readMetadata(String... uris);

  /**
   * Reads from the database the metadata for a list of documents matching the
   * provided uris.  Allows iteration across the metadata for matching documents
   * (only if setMetadataCategories has been called to request metadata).  To find
   * out how many of your uris matched, call the
   * {@link DocumentPage#size() DocumentPage.size()} method.
   *
   * @param transaction the transaction in which this read is participating
   * @param uris the database uris identifying documents
   * @return the DocumentPage of metadata from matching documents
   */
  DocumentPage readMetadata(Transaction transaction, String... uris);

  /**
   * Just like {@link QueryManager#search(QueryDefinition, SearchReadHandle, long) QueryManager.search}
   * but return complete documents via iterable DocumentPage.  Retrieves up to getPageLength()
   * documents in each DocumentPage. If setMetadataCategories has
   * been called, populates metadata for each result in the format specified by
   * {@link #setNonDocumentFormat setNonDocumentFormat}.
   * @param querydef	the definition of query criteria and query options
   * @param start	the offset of the first document in the page (where 1 is the first result)
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage search(QueryDefinition querydef, long start);

  /**
   * Just like {@link QueryManager#search(QueryDefinition, SearchReadHandle, long) QueryManager.search}
   * but return complete documents via iterable DocumentPage.  Retrieves up to getPageLength()
   * documents in each DocumentPage. If setMetadataCategories has
   * been called, populates metadata for each result in the format specified by
   * {@link #setNonDocumentFormat setNonDocumentFormat}.
   * @param querydef	the definition of query criteria and query options
   * @param start	the offset of the first document in the page (where 1 is the first result)
   * @param serverTimestamp the point in time at which to read these
   *   documents.  The value must be a merge timestamp obtained from the
   *   server via getServerTimestamp() on any handle.
   * @return the DocumentPage of matching documents and metadata
   */
  /* Hide the following for now because the API isn't yet fully fleshed-out
    DocumentPage search(QueryDefinition querydef, long start, long serverTimestamp);
   */

  /**
   * Just like {@link QueryManager#search(QueryDefinition, SearchReadHandle, long, Transaction) QueryManager.search}
   * but return complete documents via iterable DocumentPage.  Retrieves up to getPageLength()
   * documents in each DocumentPage. If setMetadataCategories has
   * been called, populates metadata for each result in the format specified by
   * {@link #setNonDocumentFormat setNonDocumentFormat}.
   * @param querydef	the definition of query criteria and query options
   * @param start	the offset of the first document in the page (where 1 is the first result)
   * @param transaction	an open transaction for matching documents
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage search(QueryDefinition querydef, long start, Transaction transaction);

  /**
   * Just like {@link QueryManager#search(QueryDefinition, SearchReadHandle, long, Transaction) QueryManager.search}
   * but return complete documents via iterable DocumentPage.  Retrieves up to getPageLength()
   * documents in each DocumentPage. If setMetadataCategories has
   * been called, populates metadata for each result in the format specified by
   * {@link #setNonDocumentFormat setNonDocumentFormat}.
   * @param querydef	the definition of query criteria and query options
   * @param start	the offset of the first document in the page (where 1 is the first result)
   * @param transaction	an open transaction for matching documents
   * @param serverTimestamp the point in time at which to read these
   *   documents.  The value must be a merge timestamp obtained from the
   *   server via getServerTimestamp() on any handle.
   * @return the DocumentPage of matching documents and metadata
   */
  /* Hide the following for now because the API isn't yet fully fleshed-out
    DocumentPage search(QueryDefinition querydef, long start, long serverTimestamp, Transaction transaction);
   */

  /**
   * Just like {@link QueryManager#search(QueryDefinition, SearchReadHandle, long) QueryManager.search}
   * but return complete documents via iterable DocumentPage.  Retrieves up to getPageLength()
   * documents in each DocumentPage.  If searchHandle is not null,
   * requests a search response and populates searchHandle with it. If setMetadataCategories has
   * been called, populates metadata for each result in the format specified by
   * {@link #setNonDocumentFormat setNonDocumentFormat}.
   * @param querydef	the definition of query criteria and query options
   * @param start	the offset of the first document in the page (where 1 is the first result)
   * @param searchHandle	a handle for reading the search response which will include view types
   *     specified by {@link #setSearchView setSearchView} and format specified by
   *     {@link #setNonDocumentFormat setNonDocumentFormat}
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage search(QueryDefinition querydef, long start, SearchReadHandle searchHandle);

  /**
   * Just like {@link QueryManager#search(QueryDefinition, SearchReadHandle, long, Transaction)}
   * but return complete documents via iterable DocumentPage.  Retrieves up to getPageLength()
   * documents in each DocumentPage.  If searchHandle is not null,
   * requests a search response and populates searchHandle with it. If setMetadataCategories has
   * been called, populates metadata for each result in the format specified by
   * {@link #setNonDocumentFormat setNonDocumentFormat}.
   * @param querydef	the definition of query criteria and query options
   * @param start	the offset of the first document in the page (where 1 is the first result)
   * @param searchHandle	a handle for reading the search response which will include view types
   *     specified by {@link #setSearchView setSearchView} and format specified by
   *     {@link #setNonDocumentFormat setNonDocumentFormat}
   * @param transaction	an open transaction for matching documents
   * @return the DocumentPage of matching documents and metadata
   */
  DocumentPage search(QueryDefinition querydef, long start, SearchReadHandle searchHandle, Transaction transaction);

  /** Get the maximum number of records to return in a page from calls to {@link #search search}
   *  @return the maximum number of records to return in a page from calls to
   *      {@link #search search} */
  long getPageLength();

  /**
   * Specifies the maximum number of documents that can appear in any page of the query results,
   * overriding any maximum specified in the query options.
   * @param length	the maximum number of records to return in a page from calls to
   *     {@link #search search}
   */
  void setPageLength(long length);

  /**
   * Returns the format (if set) for the search response from
   * {@link #search(QueryDefinition, long, SearchReadHandle) search} and
   * metadata available from {@link DocumentRecord#getMetadata(DocumentMetadataReadHandle)
   * DocumentPage.next().getMetadata(handle)} (assuming
   * {@link #setMetadataCategories setMetadataCategories} has been called
   * to request specific metadata). If setNonDocumentFormat has not been called,
   * the server default format will be used.
   * @return the format, if set, null otherwise
   */
  Format getNonDocumentFormat();

  /**
   * Specifies the format for the search response from
   * {@link #search(QueryDefinition, long, SearchReadHandle) search} and
   * metadata available from {@link DocumentRecord#getMetadata(DocumentMetadataReadHandle)
   * DocumentPage.next().getMetadata(handle)} (assuming
   * {@link #setMetadataCategories setMetadataCategories} has been called
   * to request specific metadata). If setNonDocumentFormat is not called,
   * the server default format will be used.
   * @param nonDocumentFormat the format to use
   */
  void setNonDocumentFormat(Format nonDocumentFormat);

  /**
   * Returns the view types included in a SearchReadHandle populated by calls to
   * {@link #search(QueryDefinition, long, SearchReadHandle) search}
   * @return	the view types included in a SearchReadHandle populated by calls to
   *     {@link #search(QueryDefinition, long, SearchReadHandle) search}
   */
  QueryView getSearchView();

  /**
   * Specifies the view types included in a SearchReadHandle populated by calls to
   * {@link #search(QueryDefinition, long, SearchReadHandle) search}
   * @param view	the view types included in a SearchReadHandle populated by calls to
   *     {@link #search(QueryDefinition, long, SearchReadHandle) search}
   */
  void setSearchView(QueryView view);

  DocumentWriteSet newWriteSet();

  /**
   * Write a set of documents and metadata to the server via REST API bulk capabilities.
   * @param writeSet	the set of documents and metadata to write
   * @see REST API -> Reading
   *      and Writing Multiple Documents
   */
  void write(DocumentWriteSet writeSet);

  /**
   * Write a set of documents and metadata to the server via REST API bulk capabilities.
   * @param writeSet	the set of documents and metadata to write
   * @param transform	a server transform to modify the contents of each document
   * @see REST API -> Reading
   *      and Writing Multiple Documents
   */
  void write(DocumentWriteSet writeSet, ServerTransform transform);

  /**
   * Write a set of documents and metadata to the server via REST API bulk capabilities.
   * @param writeSet	the set of documents and metadata to write
   * @param transaction	an open transaction under which the documents will be written
   * @see REST API -> Reading
   *      and Writing Multiple Documents
   */
  void write(DocumentWriteSet writeSet, Transaction transaction);

  /**
   * Write a set of documents and metadata to the server via REST API bulk capabilities.
   * @param writeSet	the set of documents and metadata to write
   * @param transform	a server transform to modify the contents of each document
   * @param transaction	an open transaction under which the documents will be written
   * @see REST API -> Reading
   *      and Writing Multiple Documents
   */
  void write(DocumentWriteSet writeSet, ServerTransform transform, Transaction transaction);

  /**
   * Writes the document content to the database from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId	the URI identifier for the document
   * @param content	an IO representation of the document content
   */
  void writeAs(String docId, Object content)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to the database from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId	the URI identifier for the document
   * @param content	an IO representation of the document content
   * @param transform	a server transform to modify the document content
   */
  void writeAs(String docId, Object content, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to the database from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param content	an IO representation of the document content
   */
  void writeAs(String docId, DocumentMetadataWriteHandle metadataHandle, Object content)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to the database from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param content	an IO representation of the document content
   * @param transform	a server transform to modify the document content
   */
  void writeAs(String docId, DocumentMetadataWriteHandle metadataHandle, Object content, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Writes the document content to the database from the representation provided by the handle
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for writing the content of the document
   */
  void write(String docId, W contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to the database as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   */
  void write(String docId, W contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to the database from the representation provided by the handle
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for writing the content of the document
   */
  void write(DocumentDescriptor desc, W contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to the database as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   */
  void write(DocumentDescriptor desc, W contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Writes the document metadata and content to the database from the representations provided by the handles
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   */
  void write(String docId, DocumentMetadataWriteHandle metadataHandle, W contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document metadata and content to the database as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   */
  void write(String docId, DocumentMetadataWriteHandle metadataHandle, W contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document metadata and content to the database from the representations provided by the handles
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   */
  void write(DocumentDescriptor desc, DocumentMetadataWriteHandle metadataHandle, W contentHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document metadata and content to the database as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   */
  void write(DocumentDescriptor desc, DocumentMetadataWriteHandle metadataHandle, W contentHandle, ServerTransform transform)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Writes the document content to an open database transaction from the representation provided by the handle
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(String docId, W contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to an open database transaction as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(String docId, W contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to an open database transaction from the representation provided by the handle
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(DocumentDescriptor desc, W contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document content to an open database transaction as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(DocumentDescriptor desc, W contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Writes the document metadata and content to an open database transaction from the representations provided by the handles
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(String docId, DocumentMetadataWriteHandle metadataHandle, W contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Writes the document metadata and content to an open database transaction as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(String docId, DocumentMetadataWriteHandle metadataHandle, W contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Writes the document metadata and content to an open database transaction from the representations provided by the handles
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(DocumentDescriptor desc, DocumentMetadataWriteHandle metadataHandle, W contentHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;
  /**
   * Writes the document metadata and content to an open database transaction as transformed on the server.
   *
   * To call write(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   */
  void write(DocumentDescriptor desc, DocumentMetadataWriteHandle metadataHandle, W contentHandle, ServerTransform transform, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException,  FailedRequestException;

  /**
   * Deletes the document metadata and content from the database
   *
   * To call delete(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @throws ResourceNotFoundException if the document is not found
   */
  void delete(String docId)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Deletes the document metadata and content from an open database transaction
   *
   * To call delete(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @throws ResourceNotFoundException if the document is not found
   */
  void delete(String docId, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Deletes the documents' metadata and content
   *
   * To call delete(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param uris	the identifiers for the documents to delete
   * @throws ResourceNotFoundException if the document is not found
   */
  void delete(String... uris)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Deletes the documents' metadata and content from an open database transaction
   *
   * To call delete(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param transaction	an open transaction
   * @param uris	the identifiers for the documents to delete
   * @throws ResourceNotFoundException if the document is not found
   */
  void delete(Transaction transaction, String... uris)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Deletes the document metadata and content from the database
   *
   * To call delete(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @throws ResourceNotFoundException if the document is not found
   */
  void delete(DocumentDescriptor desc)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Deletes the document metadata and content from an open database transaction
   *
   * To call delete(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @throws ResourceNotFoundException if the document is not found
   */
  void delete(DocumentDescriptor desc, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Creates a database document with a uri assigned by the server from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param template	the template for constructing the document uri
   * @param content	an IO representation of the document content
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor createAs(DocumentUriTemplate template, Object content)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with a uri assigned by the server from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param template	the template for constructing the document uri
   * @param content	an IO representation of the document content
   * @param transform	a server transform to modify the document content
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor createAs(DocumentUriTemplate template, Object content, ServerTransform transform)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with a uri assigned by the server from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param template	the template for constructing the document uri
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param content	an IO representation of the document content
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor createAs(DocumentUriTemplate template, DocumentMetadataWriteHandle metadataHandle, Object content)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with a uri assigned by the server from an object of an IO class.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param template	the template for constructing the document uri
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param content	an IO representation of the document content
   * @param transform	a server transform to modify the document content
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor createAs(DocumentUriTemplate template, DocumentMetadataWriteHandle metadataHandle, Object content, ServerTransform transform)
    throws ForbiddenUserException, FailedRequestException;

  /**
   * Creates a database document with a uri assigned by the server.
   * @param template	the template for constructing the document uri
   * @param contentHandle	a handle for writing the content of the document
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, W contentHandle)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with a uri assigned by the server as transformed on the server.
   * @param template	the template for constructing the document uri
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, W contentHandle, ServerTransform transform)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with a uri assigned by the server in an open database transaction.
   * @param template	the template for constructing the document uri
   * @param contentHandle	a handle for writing the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, W contentHandle, Transaction transaction)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with a uri assigned by the server in an open database transaction as transformed on the server.
   * @param template	the template for constructing the document uri
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, W contentHandle, ServerTransform transform, Transaction transaction)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with metadata and content and a uri assigned by the server.
   * @param template	the template for constructing the document uri
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, DocumentMetadataWriteHandle metadataHandle, W contentHandle)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with metadata and content and a uri assigned by the server as transformed on the server.
   * @param template	the template for constructing the document uri
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, DocumentMetadataWriteHandle metadataHandle, W contentHandle, ServerTransform transform)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * @param template	the template for constructing the document uri
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, DocumentMetadataWriteHandle metadataHandle, W contentHandle, Transaction transaction)
    throws ForbiddenUserException, FailedRequestException;
  /**
   * Creates a database document with metadata and content and a uri assigned by the server in an open database transaction as transformed on the server.
   * @param template	the template for constructing the document uri
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param contentHandle	a handle for writing the content of the document
   * @param transform	a server transform to modify the document content
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @return	the database uri that identifies the created document
   */
  DocumentDescriptor create(DocumentUriTemplate template, DocumentMetadataWriteHandle metadataHandle, W contentHandle, ServerTransform transform, Transaction transaction)
    throws ForbiddenUserException, FailedRequestException;

  /**
   * Modifies the metadata or content of a document within an open database transaction on the server.
   * Content can only be modified for JSON or XML documents.  You must use the setMetadataCategories()
   * method to specify whether the patch includes metadata.  An IO representation such as a string,
   * input stream, or XML DOM specifies the patch as content.
   *
   * The IO class must have been registered before creating the database client.
   * By default, the provided handles that implement
   * {@link com.marklogic.client.io.marker.ContentHandle ContentHandle} are registered.
   *
   * Learn more about shortcut methods
   *
   * @param docId	the URI identifier for the document
   * @param patch	an IO representation of the patch
   */
  void patchAs(String docId, Object patch)
    throws ForbiddenUserException, FailedRequestException;

  /**
   * Modifies the metadata or content of a document within an open database transaction on the server.
   * Content can only be modified for JSON or XML documents.  When sending
   * a raw JSON or XML patch, you must use the setMetadataCategories()
   * method to specify whether the patch includes metadata.
   *
   * To call patch(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param patch	a handle for writing the modification to the document metadata or content
   */
  void patch(String docId, DocumentPatchHandle patch);
  /**
   * Modifies the metadata or content of a document within an open database transaction on the server.
   * Content can only be modified for JSON or XML documents.  When sending
   * a raw JSON or XML patch, you must use the setMetadataCategories()
   * method to specify whether the patch includes metadata.
   *
   * To call patch(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param patch	a handle for writing the modification to the document metadata or content
   * @param transaction	a open transaction
   */
  void patch(String docId, DocumentPatchHandle patch, Transaction transaction);
  /**
   * Modifies the metadata or content of a document.
   * Content can only be modified for JSON or XML documents.  When sending
   * a raw JSON or XML patch, you must use the setMetadataCategories()
   * method to specify whether the patch includes metadata.
   *
   * To call patch(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param patch	a handle for writing the modification to the document metadata or content
   */
  void patch(DocumentDescriptor desc, DocumentPatchHandle patch);
  /**
   * Modifies the metadata or content of a document within an open database transaction on the server.
   * Content can only be modified for JSON or XML documents.  When sending
   * a raw JSON or XML patch, you must use the setMetadataCategories()
   * method to specify whether the patch includes metadata.
   *
   * To call patch(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param desc	a descriptor for the URI identifier, format, and mimetype of the document
   * @param patch	a handle for writing the modification to the document metadata or content
   * @param transaction	a open transaction
   */
  void patch(DocumentDescriptor desc, DocumentPatchHandle patch, Transaction transaction);

  /**
   * Reads the document metadata from the database in the representation provided by the handle
   *
   * To call readMetadata(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param  the type of DocumentMetadataReadHandle to return
   * @return	the metadata handle populated with the metadata for the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T readMetadata(String docId, T metadataHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reads the document metadata from an open database transaction in the representation provided by the handle
   *
   * To call readMetadata(), an application must authenticate as rest-reader, rest-writer, or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for reading the metadata of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @param  the type of DocumentMetadataReadHandle to return
   * @return	the metadata handle populated with the metadata for the document in the database
   * @throws ResourceNotFoundException if the document is not found
   */
   T readMetadata(String docId, T metadataHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Writes the document metadata to the database from the representation provided by the handle
   *
   * To call writeMetadata(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @throws ResourceNotFoundException if the document is not found
   */
  void writeMetadata(String docId, DocumentMetadataWriteHandle metadataHandle)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Writes the document metadata to an open database transaction from the representation provided by the handle
   *
   * To call writeMetadata(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param metadataHandle	a handle for writing the metadata of the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @throws ResourceNotFoundException if the document is not found
   */
  void writeMetadata(String docId, DocumentMetadataWriteHandle metadataHandle, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Reverts the document metadata in the database to the defaults
   *
   * To call writeDefaultMetadata(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @throws ResourceNotFoundException if the document is not found
   */
  void writeDefaultMetadata(String docId)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;
  /**
   * Reverts the document metadata in an open database transaction to the defaults
   *
   * To call writeDefaultMetadata(), an application must authenticate as rest-writer or rest-admin.
   *
   * @param docId	the URI identifier for the document
   * @param transaction	a open transaction under which the document may have been created or deleted
   * @throws ResourceNotFoundException if the document is not found
   */
  void writeDefaultMetadata(String docId, Transaction transaction)
    throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException;

  /**
   * Gets the default format of the managed documents
   *
   * @return	the default format for documents supported by this document manager
   */
  Format getContentFormat();

  /**
   * Sets the default format of the managed documents
   *
   * @param format  the default format for documents supported by this document manager
   */
  void setContentFormat(Format format);

  /**
   * Returns the categories of metadata to read, write, patch, or search.
   *
   * @return	the set of metadata categories
   */
  Set getMetadataCategories();
  /**
   * Specifies the categories of metadata to read, write, patch, or search.
   * @param categories	the set of metadata categories
   */
  void setMetadataCategories(Set categories);
  /**
   * Specifies the categories of metadata to read, write, patch, or search.
   * @param categories	the set of metadata categories
   */
  void setMetadataCategories(Metadata... categories);
  /**
   * Clears the metadata categories.
   */
  void clearMetadataCategories();

  /**
   * Returns the transform for read requests that don't specify a transform.
   * @return	the name of the transform
   */
  ServerTransform getReadTransform();
  /**
   * Specifies a transform for read requests that don't specify a transform.
   *
   * @param transform	the name of the transform
   */
  void setReadTransform(ServerTransform transform);

  /**
   * Returns the transform for write requests that don't specify a transform.
   * @return	the name of the transform
   */
  ServerTransform getWriteTransform();
  /**
   * Specifies a transform for write requests that don't specify a transform.
   *
   * @param transform	the name of the transform
   */
  void setWriteTransform(ServerTransform transform);

  /**
   * Starts debugging client requests. You can suspend and resume debugging output
   * using the methods of the logger.
   *
   * @param logger	the logger that receives debugging output
   */
  void startLogging(RequestLogger logger);
  /**
   *  Stops debugging client requests.
   */
  void stopLogging();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy