using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Http; using System.Web.Http; using System.Web.Http.Results; using MongoDB.Bson; using MongoDB.Driver; using Newtonsoft.Json; using Newtonsoft.Json.Linq; using ShadowEditor.Model.Material; using ShadowEditor.Server.Base; using ShadowEditor.Server.Helpers; namespace ShadowEditor.Server.Controllers { /// /// 材质控制器 /// public class MaterialController : ApiBase { /// /// 获取列表 /// /// [HttpGet] public JsonResult List() { var mongo = new MongoHelper(); // 获取所有类别 var filter = Builders.Filter.Eq("Type", "Material"); var categories = mongo.FindMany(Constant.CategoryCollectionName, filter).ToList(); var materials = mongo.FindAll(Constant.MaterialCollectionName).ToList(); var list = new List(); foreach (var i in materials) { var categoryID = ""; var categoryName = ""; if (i.Contains("Category") && !i["Category"].IsBsonNull && !string.IsNullOrEmpty(i["Category"].ToString())) { var doc = categories.Where(n => n["_id"].ToString() == i["Category"].ToString()).FirstOrDefault(); if (doc != null) { categoryID = doc["_id"].ToString(); categoryName = doc["Name"].ToString(); } } var info = new MaterialModel { ID = i["ID"].AsObjectId.ToString(), Name = i["Name"].AsString, CategoryID = categoryID, CategoryName = categoryName, TotalPinYin = i["TotalPinYin"].ToString(), FirstPinYin = i["FirstPinYin"].ToString(), CreateTime = i["CreateTime"].ToUniversalTime(), UpdateTime = i["UpdateTime"].ToUniversalTime(), Thumbnail = i.Contains("Thumbnail") && !i["Thumbnail"].IsBsonNull ? i["Thumbnail"].ToString() : null }; list.Add(info); } list = list.OrderByDescending(n => n.UpdateTime).ToList(); return Json(new { Code = 200, Msg = "获取成功!", Data = list }); } /// /// 获取 /// /// /// [HttpGet] public JsonResult Get(string ID) { var mongo = new MongoHelper(); var filter = Builders.Filter.Eq("ID", BsonObjectId.Create(ID)); var doc = mongo.FindOne(Constant.MaterialCollectionName, filter); if (doc == null) { return Json(new { Code = 300, Msg = "该材质不存在!" }); } var obj = new JObject { ["ID"] = doc["ID"].AsObjectId.ToString(), ["Name"] = doc["Name"].AsString, ["TotalPinYin"] = doc["TotalPinYin"].ToString(), ["FirstPinYin"] = doc["FirstPinYin"].ToString(), ["CreateTime"] = doc["CreateTime"].ToUniversalTime(), ["UpdateTime"] = doc["UpdateTime"].ToUniversalTime(), ["Data"] = JsonConvert.DeserializeObject(doc["Data"].ToJson()), ["Thumbnail"] = doc["Thumbnail"].ToString(), }; return Json(new { Code = 200, Msg = "获取成功!", Data = obj }); } /// /// 编辑 /// /// /// [HttpPost] public JsonResult Edit(MaterialEditModel model) { var objectId = ObjectId.GenerateNewId(); if (!string.IsNullOrEmpty(model.ID) && !ObjectId.TryParse(model.ID, out objectId)) { return Json(new { Code = 300, Msg = "ID不合法。" }); } if (string.IsNullOrEmpty(model.Name)) { return Json(new { Code = 300, Msg = "名称不允许为空。" }); } var mongo = new MongoHelper(); var pinyin = PinYinHelper.GetTotalPinYin(model.Name); var filter = Builders.Filter.Eq("ID", objectId); var update1 = Builders.Update.Set("Name", model.Name); var update2 = Builders.Update.Set("TotalPinYin", pinyin.TotalPinYin); var update3 = Builders.Update.Set("FirstPinYin", pinyin.FirstPinYin); var update4 = Builders.Update.Set("Thumbnail", model.Thumbnail); UpdateDefinition update5; if (string.IsNullOrEmpty(model.Category)) { update5 = Builders.Update.Unset("Category"); } else { update5 = Builders.Update.Set("Category", model.Category); } var update = Builders.Update.Combine(update1, update2, update3, update4, update5); mongo.UpdateOne(Constant.MaterialCollectionName, filter, update); return Json(new { Code = 200, Msg = "保存成功!" }); } /// /// 保存 /// /// /// [HttpPost] public JsonResult Save(MaterialSaveModel model) { var objectId = ObjectId.GenerateNewId(); if (!string.IsNullOrEmpty(model.ID) && !ObjectId.TryParse(model.ID, out objectId)) { return Json(new { Code = 300, Msg = "ID不合法。" }); } if (string.IsNullOrEmpty(model.Name)) { return Json(new { Code = 300, Msg = "名称不允许为空。" }); } // 查询 var mongo = new MongoHelper(); var filter = Builders.Filter.Eq("ID", objectId); var doc = mongo.FindOne(Constant.MaterialCollectionName, filter); var now = DateTime.Now; if (doc == null) // 新建 { var pinyin = PinYinHelper.GetTotalPinYin(model.Name); doc = new BsonDocument { ["ID"] = objectId, ["Name"] = model.Name, ["CategoryID"] = 0, ["CategoryName"] = "", ["TotalPinYin"] = string.Join("", pinyin.TotalPinYin), ["FirstPinYin"] = string.Join("", pinyin.FirstPinYin), ["Version"] = 0, ["CreateTime"] = BsonDateTime.Create(now), ["UpdateTime"] = BsonDateTime.Create(now), ["Data"] = BsonDocument.Parse(model.Data), ["Thumbnail"] = model.Thumbnail }; mongo.InsertOne(Constant.MaterialCollectionName, doc); } else // 更新 { var update1 = Builders.Update.Set("UpdateTime", BsonDateTime.Create(now)); var update2 = Builders.Update.Set("Data", BsonDocument.Parse(model.Data)); var update = Builders.Update.Combine(update1, update2); mongo.UpdateOne(Constant.MaterialCollectionName, filter, update); } return Json(new { Code = 200, Msg = "保存成功!", ID = objectId }); } /// /// 删除 /// /// /// [HttpPost] public JsonResult Delete(string ID) { var mongo = new MongoHelper(); var filter = Builders.Filter.Eq("ID", BsonObjectId.Create(ID)); var doc = mongo.FindOne(Constant.MaterialCollectionName, filter); if (doc == null) { return Json(new { Code = 300, Msg = "该资源不存在!" }); } mongo.DeleteOne(Constant.MaterialCollectionName, filter); return Json(new { Code = 200, Msg = "删除成功!" }); } } }