diff --git a/asg_form/Controllers/admin.cs b/asg_form/Controllers/admin.cs index 7b0768a..8a9d381 100644 --- a/asg_form/Controllers/admin.cs +++ b/asg_form/Controllers/admin.cs @@ -467,13 +467,16 @@ public async Task> GetAdminUsersV2(string? keyword = nu { if (this.User.FindAll(ClaimTypes.Role).Any(a => a.Value == "admin")) { - var ouser = await userManager.FindByIdAsync(userid); - + + var ouser = await userManager.FindByIdAsync(userid); ouser.officium = opname; + + if(ouser.joinTime == null) ouser.joinTime = DateTime.Now.ToString(); + await userManager.UpdateAsync(ouser); - return "成功!"; + return Ok(new { code = 200, message = "成功" }); } else { diff --git a/asg_form/Controllers/user_form.cs b/asg_form/Controllers/user_form.cs index 41d5bc7..5525c79 100644 --- a/asg_form/Controllers/user_form.cs +++ b/asg_form/Controllers/user_form.cs @@ -1,11 +1,15 @@ using Manganese.Text; +using Masuit.Tools; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Identity; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; +using SharpCompress.Archives; using System.Data; using System.Security.Claims; using static asg_form.blog; +using static asg_form.Controllers.user_form; +using static System.Runtime.InteropServices.JavaScript.JSType; namespace asg_form.Controllers { @@ -189,26 +193,45 @@ namespace asg_form.Controllers public string joinTime { get; set; } } + public class userRanking + { + public long userId { get; set; } + public string username { get; set; } + public string joinTime { get; set; } + } /// - /// 职位时间设置接口 + /// 解说排行榜 /// /// - [Authorize] - [Route("api/v1/user/settime")] - [HttpPost] - public async Task> settime([FromBody] timeSet msg) + [Route("api/v1/user/ranking")] + [HttpGet] + public async Task> rankingList(short page = 1, short limit = 10) { - - string userId = this.User.FindFirst(ClaimTypes.NameIdentifier)!.Value; - var user = await userManager.FindByIdAsync(userId); - if(user.officium != "Commentator") + try { - return Ok(new { code = 200, message = "你不是解说,不参与排名!" }); + DateTime currentTime = DateTime.Now; + + var rankings = userManager.Users + .Where(u => u.joinTime != null && u.officium == "Commentator") + .OrderByDescending(u => (currentTime - u.joinTime.ToDateTime()).TotalSeconds) + .Skip((page - 1) * limit) + .Take(limit) + .Select(u => new userRanking + { + userId = u.Id, + username = u.chinaname, + joinTime = u.joinTime, + }) + .ToList(); + + return Ok(new { code = 200, message = "", rankings }); } - user.joinTime = msg.joinTime; - await userManager.UpdateAsync(user); - return Ok(new { code = 200, message = "你成功修改了自己加入ASG的时间!" }); + catch (Exception ex) + { + return StatusCode(500, new { code = 500, message = "获取排行榜失败", error = ex.Message }); + } + } }