175 lines
5.6 KiB
C#
Raw Normal View History

using System;
2014-12-16 14:43:26 +00:00
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.Linq;
2015-09-12 00:45:17 +01:00
using System.Threading.Tasks;
2014-12-16 14:43:26 +00:00
using System.Web.Mvc;
using MongoDB.Bson;
using MongoDB.Bson.Serialization.Attributes;
using MongoDB.Driver;
2014-12-16 14:43:26 +00:00
using Required = System.ComponentModel.DataAnnotations.RequiredAttribute;
namespace BuildFeed.Model
2014-12-16 14:43:26 +00:00
{
2017-02-23 20:53:49 +00:00
[DataObject]
public class MetaItemModel
{
[Key]
[BsonId]
[@Required]
public MetaItemKey Id { get; set; }
[DisplayName("Meta Description")]
public string MetaDescription { get; set; }
[DisplayName("Page Content")]
[AllowHtml]
public string PageContent { get; set; }
}
public class MetaItem
{
private const string META_COLLECTION_NAME = "metaitem";
private readonly BuildRepository _bModel;
private readonly IMongoCollection<MetaItemModel> _metaCollection;
public MetaItem()
{
var settings = new MongoClientSettings
{
2017-02-23 20:53:49 +00:00
Server = new MongoServerAddress(MongoConfig.Host, MongoConfig.Port)
};
2017-02-23 20:53:49 +00:00
if (!string.IsNullOrEmpty(MongoConfig.Username) && !string.IsNullOrEmpty(MongoConfig.Password))
{
settings.Credential =
MongoCredential.CreateCredential(MongoConfig.Database, MongoConfig.Username, MongoConfig.Password);
2017-02-23 20:53:49 +00:00
}
var dbClient = new MongoClient(settings);
2017-02-23 20:53:49 +00:00
_metaCollection = dbClient.GetDatabase(MongoConfig.Database)
.GetCollection<MetaItemModel>(META_COLLECTION_NAME);
2017-02-23 20:53:49 +00:00
_bModel = new BuildRepository();
}
[DataObjectMethod(DataObjectMethodType.Select, false)]
public async Task<IEnumerable<MetaItemModel>> Select()
=> await _metaCollection.Find(new BsonDocument()).ToListAsync();
2017-02-23 20:53:49 +00:00
[DataObjectMethod(DataObjectMethodType.Select, true)]
public async Task<IEnumerable<MetaItemModel>> SelectByType(MetaType type)
{
return await _metaCollection.Find(f => f.Id.Type == type).ToListAsync();
}
[DataObjectMethod(DataObjectMethodType.Select, false)]
public async Task<MetaItemModel> SelectById(MetaItemKey id)
{
return await _metaCollection.Find(f => f.Id.Type == id.Type && f.Id.Value == id.Value)
.SingleOrDefaultAsync();
2017-02-23 20:53:49 +00:00
}
[DataObjectMethod(DataObjectMethodType.Select, false)]
public async Task<IEnumerable<string>> SelectUnusedLabs()
{
var labs = await _bModel.SelectAllLabs();
2017-02-23 20:53:49 +00:00
var usedLabs = await _metaCollection.Find(f => f.Id.Type == MetaType.Lab).ToListAsync();
2017-02-23 20:53:49 +00:00
return from l in labs
where usedLabs.All(ul => ul.Id.Value != l)
select l;
2017-02-23 20:53:49 +00:00
}
[DataObjectMethod(DataObjectMethodType.Select, false)]
public async Task<IEnumerable<string>> SelectUnusedVersions()
{
var versions = await _bModel.SelectAllVersions();
2017-02-23 20:53:49 +00:00
var usedVersions = await _metaCollection.Find(f => f.Id.Type == MetaType.Version).ToListAsync();
2017-02-23 20:53:49 +00:00
return from v in versions
where usedVersions.All(ul => ul.Id.Value != v.ToString())
select v.ToString();
2017-02-23 20:53:49 +00:00
}
[DataObjectMethod(DataObjectMethodType.Select, false)]
public async Task<IEnumerable<string>> SelectUnusedYears()
{
var years = await _bModel.SelectAllYears();
2017-02-23 20:53:49 +00:00
var usedYears = await _metaCollection.Find(f => f.Id.Type == MetaType.Year).ToListAsync();
2017-02-23 20:53:49 +00:00
return from y in years
where usedYears.All(ul => ul.Id.Value != y.ToString())
select y.ToString();
}
[DataObjectMethod(DataObjectMethodType.Select, false)]
public async Task<IEnumerable<string>> SelectUnusedFamilies()
{
var families = await _bModel.SelectAllFamilies();
var usedFamilies = await _metaCollection.Find(f => f.Id.Type == MetaType.Family).ToListAsync();
return from y in families
where usedFamilies.All(ul => ul.Id.Value != y.ToString())
select y.ToString();
2017-02-23 20:53:49 +00:00
}
[DataObjectMethod(DataObjectMethodType.Insert, true)]
public async Task Insert(MetaItemModel item)
{
await _metaCollection.InsertOneAsync(item);
}
[DataObjectMethod(DataObjectMethodType.Update, true)]
public async Task Update(MetaItemModel item)
{
await _metaCollection.ReplaceOneAsync(f => f.Id.Type == item.Id.Type && f.Id.Value == item.Id.Value, item);
}
[DataObjectMethod(DataObjectMethodType.Insert, false)]
public async Task InsertAll(IEnumerable<MetaItemModel> items)
{
await _metaCollection.InsertManyAsync(items);
}
[DataObjectMethod(DataObjectMethodType.Delete, true)]
public async Task DeleteById(MetaItemKey id)
{
await _metaCollection.DeleteOneAsync(f => f.Id.Type == id.Type && f.Id.Value == id.Value);
}
}
public class MetaItemKey
{
public string Value { get; set; }
public MetaType Type { get; set; }
2017-02-23 20:53:49 +00:00
public MetaItemKey()
{
}
public MetaItemKey(string id)
{
var items = id.Split(':');
2017-02-23 20:53:49 +00:00
Type = (MetaType)Enum.Parse(typeof(MetaType), items[0]);
Value = items[1];
}
public override string ToString() => $"{Type}:{Value}";
2017-02-23 20:53:49 +00:00
}
public enum MetaType
{
Lab,
Version,
Source,
Year,
Family
2017-02-23 20:53:49 +00:00
}
2014-12-16 14:43:26 +00:00
}