/* 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 MongoDB.Bson;
using MongoDB.Bson.Serialization;
using MongoDB.Bson.Serialization.Attributes;
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)
{
}
///
/// 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 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 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"); }
}
}
}