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.Linq; using ShadowEditor.Model.Audio; using ShadowEditor.Server.Base; using ShadowEditor.Server.CustomAttribute; using ShadowEditor.Server.Helpers; using System.Web; using System.IO; namespace ShadowEditor.Server.Controllers { /// /// 音频控制器 /// public class AudioController : ApiBase { /// /// 获取列表 /// /// [HttpGet] [Authority(OperatingAuthority.LIST_AUDIO)] public JsonResult List() { var mongo = new MongoHelper(); // 获取所有类别 var filter = Builders.Filter.Eq("Type", "Audio"); var categories = mongo.FindMany(Constant.CategoryCollectionName, filter).ToList(); var docs = new List(); if (ConfigHelper.EnableAuthority) { var user = UserHelper.GetCurrentUser(); if (user != null) { var filter1 = Builders.Filter.Eq("UserID", user.ID); if (user.Name == "Administrator") { var filter2 = Builders.Filter.Exists("UserID"); var filter3 = Builders.Filter.Not(filter2); var filter4 = Builders.Filter.Or(filter1, filter3); docs = mongo.FindMany(Constant.AudioCollectionName, filter4).ToList(); } else { docs = mongo.FindMany(Constant.AudioCollectionName, filter1).ToList(); } } } else { docs = mongo.FindAll(Constant.AudioCollectionName).ToList(); } var list = new List(); foreach (var i in docs) { 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 AudioModel { ID = i["ID"].AsObjectId.ToString(), Name = i["Name"].AsString, CategoryID = categoryID, CategoryName = categoryName, TotalPinYin = i["TotalPinYin"].ToString(), FirstPinYin = i["FirstPinYin"].ToString(), Type = i["Type"].AsString, Url = i["Url"].AsString, CreateTime = i["CreateTime"].ToUniversalTime(), UpdateTime = i["UpdateTime"].ToUniversalTime() }; list.Add(info); } list = list.OrderByDescending(o => o.UpdateTime).ToList(); return Json(new { Code = 200, Msg = "Get Successfully!", Data = list }); } /// /// 添加 /// /// [HttpPost] [Authority(OperatingAuthority.ADD_AUDIO)] public JsonResult Add() { var file = HttpContext.Current.Request.Files[0]; var fileName = file.FileName; var fileSize = file.ContentLength; var fileType = file.ContentType; var fileExt = Path.GetExtension(fileName); var fileNameWithoutExt = Path.GetFileNameWithoutExtension(fileName); if (fileExt == null || fileExt.ToLower() != ".mp3" && fileExt.ToLower() != ".wav" && fileExt.ToLower() != ".ogg") { return Json(new Result { Code = 300, Msg = "Only mp3, wav, ogg format is allowed!" }); } // 保存文件 var now = DateTime.Now; var savePath = $"/Upload/Audio/{now.ToString("yyyyMMddHHmmss")}"; var physicalPath = HttpContext.Current.Server.MapPath(savePath); if (!Directory.Exists(physicalPath)) { Directory.CreateDirectory(physicalPath); } file.SaveAs($"{physicalPath}\\{fileName}"); var pinyin = PinYinHelper.GetTotalPinYin(fileNameWithoutExt); // 保存到Mongo var mongo = new MongoHelper(); var doc = new BsonDocument { ["ID"] = ObjectId.GenerateNewId(), ["AddTime"] = BsonDateTime.Create(now), ["FileName"] = fileName, ["FileSize"] = fileSize, ["FileType"] = fileType, ["FirstPinYin"] = string.Join("", pinyin.FirstPinYin), ["Name"] = fileNameWithoutExt, ["SaveName"] = fileName, ["SavePath"] = savePath, ["TotalPinYin"] = string.Join("", pinyin.TotalPinYin), ["Type"] = AudioType.unknown.ToString(), ["Url"] = $"{savePath}/{fileName}", ["CreateTime"] = now, ["UpdateTime"] = now }; mongo.InsertOne(Constant.AudioCollectionName, doc); return Json(new Result { Code = 200, Msg = "Upload successfully!" }); } /// /// 编辑 /// /// /// [HttpPost] [Authority(OperatingAuthority.EDIT_AUDIO)] public JsonResult Edit(AudioEditModel model) { var objectId = ObjectId.GenerateNewId(); if (!string.IsNullOrEmpty(model.ID) && !ObjectId.TryParse(model.ID, out objectId)) { return Json(new { Code = 300, Msg = "ID is not allowed." }); } if (string.IsNullOrEmpty(model.Name)) { return Json(new { Code = 300, Msg = "Name is not allowed to be empty." }); } 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); 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, update5); mongo.UpdateOne(Constant.AudioCollectionName, filter, update); return Json(new { Code = 200, Msg = "Saved successfully!" }); } /// /// 删除 /// /// /// [HttpPost] [Authority(OperatingAuthority.DELETE_AUDIO)] public JsonResult Delete(string ID) { var mongo = new MongoHelper(); var filter = Builders.Filter.Eq("ID", BsonObjectId.Create(ID)); var doc = mongo.FindOne(Constant.AudioCollectionName, filter); if (doc == null) { return Json(new { Code = 300, Msg = "The asset is not existed!" }); } // 删除音频所在目录 var path = doc["SavePath"].ToString(); var physicalPath = HttpContext.Current.Server.MapPath(path); try { Directory.Delete(physicalPath, true); } catch (Exception ex) { return Json(new { Code = 300, Msg = ex.Message }); } // 删除音频信息 mongo.DeleteOne(Constant.AudioCollectionName, filter); return Json(new { Code = 200, Msg = "Delete successfully!" }); } } }