/* 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.IO; using System.Threading; using System.Threading.Tasks; using MongoDB.Bson; namespace MongoDB.Driver.GridFS { /// /// Represents a Stream used by the application to write data to a GridFS file. /// public class GridFSUploadStream : DelegatingStream { // fields private readonly GridFSUploadStream _wrappedStream; // constructors /// /// Initializes a new instance of the class. /// /// The wrapped stream. internal GridFSUploadStream(GridFSUploadStream wrappedStream) : base(wrappedStream) { _wrappedStream = wrappedStream; } // public properties /// /// Gets the id of the file being added to GridFS. /// /// /// The id of the file being added to GridFS. /// public ObjectId Id { get { return _wrappedStream.Id; } } // public methods /// /// Aborts an upload operation. /// /// /// Any partial results already written to the server are deleted when Abort is called. /// /// The cancellation token. public void Abort(CancellationToken cancellationToken = default(CancellationToken)) { _wrappedStream.Abort(cancellationToken); } /// /// Aborts an upload operation. /// /// /// Any partial results already written to the server are deleted when AbortAsync is called. /// /// The cancellation token. /// A Task. public Task AbortAsync(CancellationToken cancellationToken = default(CancellationToken)) { return _wrappedStream.AbortAsync(cancellationToken); } #if NETSTANDARD1_5 || NETSTANDARD1_6 /// /// Closes the GridFS stream. /// public virtual void Close() { _wrappedStream.Close(); } #endif /// /// Closes the Stream and completes the upload operation. /// /// /// Any data remaining in the Stream is flushed to the server and the GridFS files collection document is written. /// /// The cancellation token. public void Close(CancellationToken cancellationToken) { _wrappedStream.Close(cancellationToken); } /// /// Closes the Stream and completes the upload operation. /// /// /// Any data remaining in the Stream is flushed to the server and the GridFS files collection document is written. /// /// The cancellation token. /// A Task. public Task CloseAsync(CancellationToken cancellationToken = default(CancellationToken)) { return _wrappedStream.CloseAsync(cancellationToken); } } }