颐和api

NewsController.cs 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Security.Claims;
  5. using System.Threading.Tasks;
  6. using Api.SignToken;
  7. using AutoMapper;
  8. using MadRunFabric.Common;
  9. using MadRunFabric.Model;
  10. using MessageApi.IRepositories;
  11. using Microsoft.AspNetCore.Authorization;
  12. using Microsoft.AspNetCore.Mvc;
  13. using Microsoft.Extensions.Logging;
  14. using MongoDB.Driver;
  15. using Microsoft.Extensions.Configuration;
  16. namespace MessageApi.Controllers
  17. {
  18. [Authorize]
  19. [ApiVersion("6.0")]
  20. [Produces("application/json")]
  21. [Route("api/[controller]")]
  22. public class NewsController : BaseController
  23. {
  24. private readonly ILogger<NewsController> _logger;
  25. private readonly IConfiguration _configuration;
  26. private readonly ISys_User_AccountRepository _sys_user_accountRepository;
  27. private readonly ISys_NewsRepository _sys_newsRepository;
  28. private readonly ISignTokenService _signTokenService;
  29. private readonly IMapper _mapper;
  30. public NewsController(
  31. ILogger<NewsController> logger,
  32. IConfiguration configuration,
  33. ISys_User_AccountRepository sys_user_accountRepository,
  34. ISys_NewsRepository sys_newsRepository,
  35. ISignTokenService signTokenService, IMapper mapper)
  36. {
  37. _logger = logger;
  38. _configuration = configuration;
  39. _sys_user_accountRepository = sys_user_accountRepository;
  40. _sys_newsRepository = sys_newsRepository;
  41. _signTokenService = signTokenService;
  42. _mapper = mapper;
  43. }
  44. /// <summary>
  45. /// 获取新闻列表
  46. /// </summary>
  47. /// <param name="keyword"></param>
  48. /// <param name="pageindex"></param>
  49. /// <param name="pagesize"></param>
  50. /// <returns></returns>
  51. [HttpGet("getlistbypage")]
  52. public async Task<IActionResult> GetListsByPageAsync(string keyword, string projectid, string typeid, int level = 0, int pageindex = 1, int pagesize = 10)
  53. {
  54. ////排序字段
  55. var sort = Builders<Sys_News>.Sort.Ascending("sort");
  56. //根据条件查询集合
  57. var listApp = new List<FilterDefinition<Sys_News>>();
  58. listApp.Add(Builders<Sys_News>.Filter.Eq("isdelete", 0));
  59. if (!string.IsNullOrEmpty(keyword))
  60. listApp.Add(Builders<Sys_News>.Filter.Where(s => s.title.Contains(keyword) || s.content.Contains(keyword)));
  61. if (!string.IsNullOrEmpty(projectid))
  62. listApp.Add(Builders<Sys_News>.Filter.Eq("projectid", projectid));
  63. if (!string.IsNullOrEmpty(typeid))
  64. listApp.Add(Builders<Sys_News>.Filter.Eq("typeid", typeid));
  65. if (level != 0)
  66. listApp.Add(Builders<Sys_News>.Filter.Eq("level", level));
  67. int recordCount = 0;
  68. var filter = Builders<Sys_News>.Filter.And(listApp);
  69. var list = await _sys_newsRepository.GetByPage(filter, pageindex, pagesize, sort);
  70. var redCount = await _sys_newsRepository.CountAsync(filter); //获取总数
  71. recordCount = int.Parse(redCount.ToString());
  72. var obj = new
  73. {
  74. rows = list,
  75. total = recordCount
  76. };
  77. return Success("成功", obj);
  78. }
  79. /// <summary>
  80. /// 获取新闻列表--关联查询
  81. /// </summary>
  82. /// <param name="keyword"></param>
  83. /// <param name="pageIndex"></param>
  84. /// <param name="pageSize"></param>
  85. /// <returns></returns>
  86. [HttpGet("getlistsbypage")]
  87. public async Task<IActionResult> GetListsByPage(string keyword, string projectid, string typeid, int state = 0, int level = 0, int pageIndex = 1, int pageSize = 10)
  88. {
  89. string rolecode = User.Claims.FirstOrDefault(c => c.Type == "RoleCode").Value;
  90. string usercode = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  91. //var userstr = _signTokenService.GetUserInfoAsync(usercode).Result;
  92. //var userinfo = userstr.ToJObject()["data"].ToString().ToObject<UserInfoModel>();
  93. string allprojectrole = _configuration["allprojectrole"];
  94. var userinfos = _sys_user_accountRepository.GetUserInfo(usercode, allprojectrole);
  95. var userinfo = JsonHelper.JsonToEntity<UserAccountInfoModel>(userinfos.ToJson());
  96. #region 定时发布
  97. DateTime dtnow = DateTime.Now;
  98. var lists = (await _sys_newsRepository.Get(x => x.state == 1 && x.publishtype == 1 && x.timingtime <= dtnow)).ToList();
  99. if (!string.IsNullOrEmpty(projectid))
  100. lists = lists.Where(x => x.projectid == projectid).ToList();
  101. if (lists.Count > 0)
  102. {
  103. foreach (var item in lists)
  104. {
  105. item.state = 0;
  106. item.createtime = DateTime.Now.ToLocalTime();
  107. await _sys_newsRepository.UpdateOne(item);
  108. }
  109. }
  110. #endregion
  111. int recordCount = 0;
  112. var result = _sys_newsRepository.GetListsByPage(keyword, projectid, typeid, state, level, userinfo, rolecode, pageIndex, pageSize, out recordCount);
  113. var obj = new
  114. {
  115. rows = result,
  116. total = recordCount,
  117. };
  118. return Success("获取成功", obj);
  119. }
  120. /// <summary>
  121. /// 新闻详情 by id
  122. /// </summary>
  123. /// <param name="id">新闻id</param>
  124. /// <returns></returns>
  125. [HttpGet("getdetailes")]
  126. public async Task<IActionResult> GetDetailsAsync(string id)
  127. {
  128. if (string.IsNullOrEmpty(id))
  129. return Error("参数错误");
  130. var model = await _sys_newsRepository.GetSingle(id);
  131. return Success("获取成功!", model);
  132. }
  133. /// <summary>
  134. /// 获取新闻详情 by id - 关联查询
  135. /// </summary>
  136. /// <param name="id"></param>
  137. /// <returns></returns>
  138. [HttpGet("getdetails")]
  139. public IActionResult GetDetails(string id)
  140. {
  141. if (string.IsNullOrEmpty(id))
  142. return Error("参数错误");
  143. var model = _sys_newsRepository.GetDetails(id);
  144. if (model != null)
  145. {
  146. return Success("获取成功!", model);
  147. }
  148. return Error("获取失败");
  149. }
  150. /// <summary>
  151. /// 添加新闻信息
  152. /// </summary>
  153. /// <param name="province"></param>
  154. /// <param name="city"></param>
  155. /// <param name="projectid"></param>
  156. /// <param name="typeid"></param>
  157. /// <param name="title"></param>
  158. /// <param name="content"></param>
  159. /// <param name="headimg"></param>
  160. /// <param name="headsmallimg"></param>
  161. /// <param name="files"></param>
  162. /// <param name="level"></param>
  163. /// <param name="sort"></param>
  164. /// <param name="state"></param>
  165. /// <param name="timingtime"></param>
  166. /// <param name="endtime"></param>
  167. /// <param name="rolecode"></param>
  168. /// <returns></returns>
  169. [HttpPost("add")]
  170. public async Task<IActionResult> AddAsync(string province, string city, string projectid, string typeid, string title, string content, string headimg,
  171. string headsmallimg, List<FileBaseModel> files, int level, int sort, int publishtype, string timingtime, string endtime, string rolecode)
  172. {
  173. string usercode = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  174. #region 验证判断
  175. //projectid为空时所有项目
  176. //if (string.IsNullOrEmpty(projectid))
  177. // return Error("项目不能为空");
  178. if (string.IsNullOrEmpty(title))
  179. return Error("新闻标题不能为空");
  180. if (string.IsNullOrEmpty(title))
  181. return Error("新闻内容不能为空");
  182. #endregion
  183. var model = new Sys_News();
  184. model.province = province;
  185. model.city = city;
  186. model.projectid = projectid;
  187. model.typeid = typeid;
  188. model.title = title;
  189. model.content = content;
  190. model.headimg = headimg;
  191. model.headsmallimg = headsmallimg;
  192. model.level = level;
  193. model.sort = sort;
  194. //model.state = 0;
  195. //新修改字段
  196. //发布类型(0立即发布、1定时发布)
  197. model.publishtype = publishtype;
  198. if (publishtype == 1)
  199. {
  200. model.state = 1; //状态(0正常显示、1不显示)
  201. model.timingtime = DateTime.Parse(timingtime);
  202. }
  203. if (!string.IsNullOrEmpty(endtime))
  204. model.endtime = DateTime.Parse(endtime);
  205. model.rolecode = rolecode;
  206. if (files != null)
  207. {
  208. model.files = files;
  209. }
  210. else
  211. {
  212. model.files = new List<FileBaseModel>();
  213. }
  214. model.isdelete = 0;
  215. model.createuser = usercode;
  216. model.createtime = DateTime.Now;
  217. bool bl = await _sys_newsRepository.Add(model);
  218. if (bl)
  219. {
  220. return Success("添加成功");
  221. }
  222. return Error("添加失败");
  223. }
  224. /// <summary>
  225. /// 修改新闻信息
  226. /// </summary>
  227. /// <param name="id"></param>
  228. /// <param name="step"></param>
  229. /// <param name="content"></param>
  230. /// <param name="dictionarycode"></param>
  231. /// <returns></returns>
  232. [HttpPost("update")]
  233. public async Task<IActionResult> UpdateAsync(string id, string province, string city, string projectid, string typeid, string title, string content,
  234. string headimg,string headsmallimg, List<FileBaseModel> files, int level, int sort, int publishtype, string timingtime, string endtime, string rolecode)
  235. {
  236. string usercode = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  237. #region 验证判断
  238. //projectid为空时所有项目
  239. //if (string.IsNullOrEmpty(projectid))
  240. // return Error("项目不能为空");
  241. if (string.IsNullOrEmpty(title))
  242. return Error("新闻标题不能为空");
  243. if (string.IsNullOrEmpty(title))
  244. return Error("新闻内容不能为空");
  245. #endregion
  246. var model = await _sys_newsRepository.GetSingle(id);
  247. if (model == null)
  248. return Error("操作失败");
  249. model.province = province;
  250. model.city = city;
  251. model.projectid = projectid;
  252. model.typeid = typeid;
  253. model.title = title;
  254. model.content = content;
  255. model.headimg = headimg;
  256. model.headsmallimg = headsmallimg;
  257. model.level = level;
  258. model.sort = sort;
  259. //新修改字段
  260. //发布类型(0立即发布、1定时发布)
  261. model.publishtype = publishtype;
  262. if (publishtype == 1)
  263. {
  264. model.state = 1; //状态(0正常显示、1不显示)
  265. model.timingtime = DateTime.Parse(timingtime);
  266. }
  267. if (!string.IsNullOrEmpty(endtime))
  268. model.endtime = DateTime.Parse(endtime);
  269. model.rolecode = rolecode;
  270. if (files != null)
  271. {
  272. model.files = files;
  273. }
  274. else
  275. {
  276. model.files = new List<FileBaseModel>();
  277. }
  278. bool b = await _sys_newsRepository.UpdateOne(model);
  279. if (b)
  280. {
  281. return Success("保存成功");
  282. }
  283. return Error("保存失败");
  284. }
  285. /// <summary>
  286. /// 删除信息 by ids
  287. /// </summary>
  288. /// <param name="ids"></param>
  289. /// <returns></returns>
  290. [HttpPost("delete")]
  291. public async Task<IActionResult> RemoveAsync(string[] ids)
  292. {
  293. string usercode = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  294. var res = 0;
  295. if (ids != null && ids.Length > 0)
  296. {
  297. foreach (var item in ids)
  298. {
  299. var ml = await _sys_newsRepository.GetSingle(item);
  300. ml.isdelete = 1;
  301. ml.deleteuser = usercode;
  302. ml.deletetime = DateTime.Now.ToLocalTime();
  303. if (_sys_newsRepository.UpdateOne(ml).Result)
  304. res += 1;
  305. }
  306. if (res == ids.Length)
  307. return Success("删除成功");
  308. else if (res > 0 && res < ids.Length)
  309. return Error("部分删除失败,请查看后重新操作");
  310. else
  311. return Error("删除失败,请查看后重新操作");
  312. }
  313. else
  314. return Error("请选择要删除的记录");
  315. }
  316. }
  317. }