/* Copyright 2016-present MongoDB Inc. * * 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. */ using System; using System.IO; using System.Threading; using System.Threading.Tasks; using MongoDB.Bson; namespace MongoDB.Driver.GridFS { /// /// Represents a GridFS system bucket. /// public interface IGridFSBucket : IGridFSBucket { // methods /// /// Finds matching entries from the files collection. /// /// The filter. /// The options. /// The cancellation token. /// A cursor of files collection documents. IAsyncCursor Find(FilterDefinition filter, GridFSFindOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Finds matching entries from the files collection. /// /// The filter. /// The options. /// The cancellation token. /// A Task whose result is a cursor of files collection documents. Task> FindAsync(FilterDefinition filter, GridFSFindOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Opens a Stream that can be used by the application to write data to a GridFS file. /// /// The filename. /// The options. /// The cancellation token. /// A Stream. GridFSUploadStream OpenUploadStream(string filename, GridFSUploadOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Opens a Stream that can be used by the application to write data to a GridFS file. /// /// The filename. /// The options. /// The cancellation token. /// A Task whose result is a Stream. Task OpenUploadStreamAsync(string filename, GridFSUploadOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Uploads a file (or a new revision of a file) to GridFS. /// /// The filename. /// The source. /// The options. /// The cancellation token. /// The id of the new file. ObjectId UploadFromBytes(string filename, byte[] source, GridFSUploadOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Uploads a file (or a new revision of a file) to GridFS. /// /// The filename. /// The source. /// The options. /// The cancellation token. /// A Task whose result is the id of the new file. Task UploadFromBytesAsync(string filename, byte[] source, GridFSUploadOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Uploads a file (or a new revision of a file) to GridFS. /// /// The filename. /// The source. /// The options. /// The cancellation token. /// The id of the new file. ObjectId UploadFromStream(string filename, Stream source, GridFSUploadOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); /// /// Uploads a file (or a new revision of a file) to GridFS. /// /// The filename. /// The source. /// The options. /// The cancellation token. /// A Task whose result is the id of the new file. Task UploadFromStreamAsync(string filename, Stream source, GridFSUploadOptions options = null, CancellationToken cancellationToken = default(CancellationToken)); } }