/* 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).
///
/// The type of the file identifier.
[BsonSerializer(typeof(GridFSFileInfoSerializer<>))]
public sealed class GridFSFileInfo : BsonDocumentBackedClass
{
// constructors
///
/// Initializes a new instance of the class.
///
/// The backing document.
/// The fileInfo serializer.
public GridFSFileInfo(BsonDocument backingDocument, IGridFSFileInfoSerializer fileInfoSerializer)
: base(backingDocument, fileInfoSerializer)
{
}
// 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 TFileId Id
{
get { return GetValue("Id"); }
}
// public properties
///
/// Gets the length.
///
///
/// The length.
///
public long Length
{
get { return GetValue("Length"); }
}
///
/// Gets the MD5 checksum.
///
///
/// The MD5 checksum.
///
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"); }
}
}
}