// // DISCLAIMER // // Copyright 2017-2023 ArangoDB GmbH, Cologne, Germany // // 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. // // Copyright holder is ArangoDB GmbH, Cologne, Germany // package driver import "context" // CollectionDocuments provides access to the documents in a single collection. type CollectionDocuments interface { // DocumentExists checks if a document with given key exists in the collection. DocumentExists(ctx context.Context, key string) (bool, error) // ReadDocument reads a single document with given key from the collection. // The document data is stored into result, the document meta data is returned. // If no document exists with given key, a NotFoundError is returned. ReadDocument(ctx context.Context, key string, result interface{}) (DocumentMeta, error) // ReadDocuments reads multiple documents with given keys from the collection. // The documents data is stored into elements of the given results slice, // the documents meta data is returned. // If no document exists with a given key, a NotFoundError is returned at its errors index. ReadDocuments(ctx context.Context, keys []string, results interface{}) (DocumentMetaSlice, ErrorSlice, error) // CreateDocument creates a single document in the collection. // The document data is loaded from the given document, the document meta data is returned. // If the document data already contains a `_key` field, this will be used as key of the new document, // otherwise a unique key is created. // A ConflictError is returned when a `_key` field contains a duplicate key, other any other field violates an index constraint. // To return the NEW document, prepare a context with `WithReturnNew`. // To wait until document has been synced to disk, prepare a context with `WithWaitForSync`. CreateDocument(ctx context.Context, document interface{}) (DocumentMeta, error) // CreateDocuments creates multiple documents in the collection. // The document data is loaded from the given documents slice, the documents meta data is returned. // If a documents element already contains a `_key` field, this will be used as key of the new document, // otherwise a unique key is created. // If a documents element contains a `_key` field with a duplicate key, other any other field violates an index constraint, // a ConflictError is returned in its index in the errors slice. // To return the NEW documents, prepare a context with `WithReturnNew`. The data argument passed to `WithReturnNew` must be // a slice with the same number of entries as the `documents` slice. // To wait until document has been synced to disk, prepare a context with `WithWaitForSync`. // If the create request itself fails or one of the arguments is invalid, an error is returned. CreateDocuments(ctx context.Context, documents interface{}) (DocumentMetaSlice, ErrorSlice, error) // UpdateDocument updates a single document with given key in the collection. // The document meta data is returned. // To return the NEW document, prepare a context with `WithReturnNew`. // To return the OLD document, prepare a context with `WithReturnOld`. // To wait until document has been synced to disk, prepare a context with `WithWaitForSync`. // If no document exists with given key, a NotFoundError is returned. // If `_id` field is present in the document body, it is always ignored. UpdateDocument(ctx context.Context, key string, update interface{}) (DocumentMeta, error) // UpdateDocuments updates multiple document with given keys in the collection. // The updates are loaded from the given updates slice, the documents meta data are returned. // To return the NEW documents, prepare a context with `WithReturnNew` with a slice of documents. // To return the OLD documents, prepare a context with `WithReturnOld` with a slice of documents. // To wait until documents has been synced to disk, prepare a context with `WithWaitForSync`. // If no document exists with a given key, a NotFoundError is returned at its errors index. // If keys are nil, each element in the update slice must contain a `_key` field. // If `_id` field is present in the document body, it is always ignored. UpdateDocuments(ctx context.Context, keys []string, updates interface{}) (DocumentMetaSlice, ErrorSlice, error) // ReplaceDocument replaces a single document with given key in the collection with the document given in the document argument. // The document meta data is returned. // To return the NEW document, prepare a context with `WithReturnNew`. // To return the OLD document, prepare a context with `WithReturnOld`. // To wait until document has been synced to disk, prepare a context with `WithWaitForSync`. // If no document exists with given key, a NotFoundError is returned. // If `_id` field is present in the document body, it is always ignored. ReplaceDocument(ctx context.Context, key string, document interface{}) (DocumentMeta, error) // ReplaceDocuments replaces multiple documents with given keys in the collection with the documents given in the documents argument. // The replacements are loaded from the given documents slice, the documents meta data are returned. // To return the NEW documents, prepare a context with `WithReturnNew` with a slice of documents. // To return the OLD documents, prepare a context with `WithReturnOld` with a slice of documents. // To wait until documents has been synced to disk, prepare a context with `WithWaitForSync`. // If no document exists with a given key, a NotFoundError is returned at its errors index. // If keys is nil, each element in the documents slice must contain a `_key` field. // If `_id` field is present in the document body, it is always ignored. ReplaceDocuments(ctx context.Context, keys []string, documents interface{}) (DocumentMetaSlice, ErrorSlice, error) // RemoveDocument removes a single document with given key from the collection. // The document meta data is returned. // To return the OLD document, prepare a context with `WithReturnOld`. // To wait until removal has been synced to disk, prepare a context with `WithWaitForSync`. // If no document exists with given key, a NotFoundError is returned. RemoveDocument(ctx context.Context, key string) (DocumentMeta, error) // RemoveDocuments removes multiple documents with given keys from the collection. // The document meta data are returned. // To return the OLD documents, prepare a context with `WithReturnOld` with a slice of documents. // To wait until removal has been synced to disk, prepare a context with `WithWaitForSync`. // If no document exists with a given key, a NotFoundError is returned at its errors index. RemoveDocuments(ctx context.Context, keys []string) (DocumentMetaSlice, ErrorSlice, error) // ImportDocuments imports one or more documents into the collection. // The document data is loaded from the given documents argument, statistics are returned. // The documents argument can be one of the following: // - An array of structs: All structs will be imported as individual documents. // - An array of maps: All maps will be imported as individual documents. // To wait until all documents have been synced to disk, prepare a context with `WithWaitForSync`. // To return details about documents that could not be imported, prepare a context with `WithImportDetails`. ImportDocuments(ctx context.Context, documents interface{}, options *ImportDocumentOptions) (ImportDocumentStatistics, error) } // ImportDocumentOptions holds optional options that control the import document process. type ImportDocumentOptions struct { // FromPrefix is an optional prefix for the values in _from attributes. If specified, the value is automatically // prepended to each _from input value. This allows specifying just the keys for _from. FromPrefix string `json:"fromPrefix,omitempty"` // ToPrefix is an optional prefix for the values in _to attributes. If specified, the value is automatically // prepended to each _to input value. This allows specifying just the keys for _to. ToPrefix string `json:"toPrefix,omitempty"` // Overwrite is a flag that if set, then all data in the collection will be removed prior to the import. // Note that any existing index definitions will be preseved. Overwrite bool `json:"overwrite,omitempty"` // OnDuplicate controls what action is carried out in case of a unique key constraint violation. // Possible values are: // - ImportOnDuplicateError // - ImportOnDuplicateUpdate // - ImportOnDuplicateReplace // - ImportOnDuplicateIgnore OnDuplicate ImportOnDuplicate `json:"onDuplicate,omitempty"` // Complete is a flag that if set, will make the whole import fail if any error occurs. // Otherwise the import will continue even if some documents cannot be imported. Complete bool `json:"complete,omitempty"` } // ImportOnDuplicate is a type to control what action is carried out in case of a unique key constraint violation. type ImportOnDuplicate string const ( // ImportOnDuplicateError will not import the current document because of the unique key constraint violation. // This is the default setting. ImportOnDuplicateError = ImportOnDuplicate("error") // ImportOnDuplicateUpdate will update an existing document in the database with the data specified in the request. // Attributes of the existing document that are not present in the request will be preserved. ImportOnDuplicateUpdate = ImportOnDuplicate("update") // ImportOnDuplicateReplace will replace an existing document in the database with the data specified in the request. ImportOnDuplicateReplace = ImportOnDuplicate("replace") // ImportOnDuplicateIgnore will not update an existing document and simply ignore the error caused by a unique key constraint violation. ImportOnDuplicateIgnore = ImportOnDuplicate("ignore") ) // ImportDocumentStatistics holds statistics of an import action. type ImportDocumentStatistics struct { // Created holds the number of documents imported. Created int64 `json:"created,omitempty"` // Errors holds the number of documents that were not imported due to an error. Errors int64 `json:"errors,omitempty"` // Empty holds the number of empty lines found in the input (will only contain a value greater zero for types documents or auto). Empty int64 `json:"empty,omitempty"` // Updated holds the number of updated/replaced documents (in case onDuplicate was set to either update or replace). Updated int64 `json:"updated,omitempty"` // Ignored holds the number of failed but ignored insert operations (in case onDuplicate was set to ignore). Ignored int64 `json:"ignored,omitempty"` // if query parameter details is set to true, the result will contain a details attribute which is an array // with more detailed information about which documents could not be inserted. Details []string ArangoError }