/* Copyright 2015-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.Collections.Generic; using System.Linq; using MongoDB.Bson; using MongoDB.Bson.Serialization; using MongoDB.Bson.Serialization.Attributes; using MongoDB.Bson.Serialization.Serializers; using MongoDB.Driver.Core.Misc; namespace MongoDB.Driver.GridFS { /// /// Represents information about a stored GridFS file (backed by a files collection document). /// [BsonSerializer(typeof(GridFSFileInfoSerializer))] public sealed class GridFSFileInfo : BsonDocumentBackedClass { // constructors /// /// Initializes a new instance of the class. /// /// The backing document. public GridFSFileInfo(BsonDocument backingDocument) : base(backingDocument, GridFSFileInfoSerializer.Instance) { } // public properties /// /// Gets the aliases. /// /// /// The aliases. /// [Obsolete("Place aliases inside metadata instead.")] public IEnumerable Aliases { get { return GetValue("Aliases", null); } } /// /// Gets the backing document. /// /// /// The backing document. /// new public BsonDocument BackingDocument { get { return base.BackingDocument; } } /// /// Gets the size of a chunk. /// /// /// The size of a chunk. /// public int ChunkSizeBytes { get { return GetValue("ChunkSizeBytes"); } } /// /// Gets the type of the content. /// /// /// The type of the content. /// [Obsolete("Place contentType inside metadata instead.")] public string ContentType { get { return GetValue("ContentType", null); } } /// /// Gets the filename. /// /// /// The filename. /// public string Filename { get { return GetValue("Filename"); } } /// /// Gets the identifier. /// /// /// The identifier. /// public ObjectId Id { get { return GetValue("IdAsBsonValue").AsObjectId; } } /// /// Gets the identifier as a BsonValue. /// /// /// The identifier as a BsonValue. /// [Obsolete("All new GridFS files should use an ObjectId as the Id.")] public BsonValue IdAsBsonValue { get { return GetValue("IdAsBsonValue"); } } /// /// Gets the length. /// /// /// The length. /// public long Length { get { return GetValue("Length"); } } /// /// Gets the MD5 checksum. /// /// /// The MD5 checksum. /// [Obsolete("MD5 support will be removed soon.")] public string MD5 { get { return GetValue("MD5", null); } } /// /// Gets the metadata. /// /// /// The metadata. /// public BsonDocument Metadata { get { return GetValue("Metadata", null); } } /// /// Gets the upload date time. /// /// /// The upload date time. /// public DateTime UploadDateTime { get { return GetValue("UploadDateTime"); } } } }