270 lines
9.5 KiB
C#
270 lines
9.5 KiB
C#
using AngleSharp.Text;
|
||
using asg_form.Controllers.Hubs;
|
||
using asg_form.Controllers.Store;
|
||
using Manganese.Array;
|
||
using Microsoft.AspNetCore.Authorization;
|
||
using Microsoft.AspNetCore.Identity;
|
||
using Microsoft.AspNetCore.Mvc;
|
||
using Microsoft.AspNetCore.SignalR;
|
||
using NPOI.HPSF;
|
||
using System.Security.Claims;
|
||
using static Microsoft.EntityFrameworkCore.DbLoggerCategory;
|
||
using System.Web;
|
||
using System.Net.NetworkInformation;
|
||
using Microsoft.EntityFrameworkCore.Storage.ValueConversion.Internal;
|
||
using NPOI.SS.Formula.Functions;
|
||
using Microsoft.EntityFrameworkCore;
|
||
using Flandre.Core.Models;
|
||
using Mirai.Net.Sessions.Http.Managers;
|
||
using Mirai.Net.Utils.Scaffolds;
|
||
using Flandre.Core.Messaging.Segments;
|
||
using Flandre.Core.Messaging;
|
||
|
||
namespace asg_form.Controllers
|
||
{
|
||
public class TaskDB
|
||
{
|
||
public long id { get; set; }
|
||
public string chinaname { get; set; }
|
||
public string createPerson { get; set; }
|
||
public long? createUserId { get; set; }
|
||
public long userId { get; set; }
|
||
public string taskName { get; set; }
|
||
public string taskDescription { get; set; }
|
||
public string status { get; set; }
|
||
public long money { get; set; }
|
||
|
||
public string createTime { get; set; }
|
||
|
||
public string lastOperateTime { get; set; }
|
||
|
||
public string approvalPerson { get; set; }
|
||
}
|
||
public class TaskCreate
|
||
{
|
||
public string Chinaname { get; set; }
|
||
public string CreatePerson { get; set; }
|
||
public long? CreateUserid { get; set; }
|
||
public long UserId { get; set; }
|
||
public string TaskName { get; set; }
|
||
public string TaskDescription { get; set; }
|
||
public long Money { get; set; }
|
||
public string? atuserqq { get; set; }
|
||
|
||
}
|
||
public class AssignmentController : ControllerBase
|
||
{
|
||
private readonly RoleManager<Role> roleManager;
|
||
private readonly UserManager<User> userManager;
|
||
public AssignmentController(
|
||
RoleManager<Role> roleManager, UserManager<User> userManager)
|
||
{
|
||
this.roleManager = roleManager;
|
||
this.userManager = userManager;
|
||
}
|
||
|
||
[Route("api/v1/admin/Task")]
|
||
[HttpPost]
|
||
[Authorize]
|
||
public async Task<ActionResult<string>> PubTask([FromBody] TaskCreate taskinfo)
|
||
{
|
||
if (!this.User.FindAll(ClaimTypes.Role).Any(a => a.Value == "nbadmin"))
|
||
{
|
||
return Ok(new error_mb { code = 401, message = "无权访问" });
|
||
}
|
||
var dateString = DateTime.Now;
|
||
using (TestDbContext sub = new TestDbContext())
|
||
{
|
||
int wp = -2;
|
||
try
|
||
{
|
||
var task = new TaskDB
|
||
{
|
||
chinaname = taskinfo.Chinaname,
|
||
createPerson = taskinfo.CreatePerson,
|
||
createUserId = taskinfo.CreateUserid,
|
||
userId = taskinfo.UserId,
|
||
taskName = taskinfo.TaskName,
|
||
taskDescription = taskinfo.TaskDescription,
|
||
money = taskinfo.Money,
|
||
status = "0",
|
||
createTime = dateString.ToString(),
|
||
lastOperateTime = dateString.ToString(),
|
||
approvalPerson = "未审核"
|
||
};
|
||
sub.T_Task.Add(task);
|
||
await sub.SaveChangesAsync();
|
||
wp = -1;
|
||
string msg = $"<ASG机器人通知> 尊敬的 {taskinfo.Chinaname},{taskinfo.CreatePerson}为您下了一个任务,请及时上后台查看!";
|
||
string qqgroup = "925510646";
|
||
wp = 0;
|
||
var message = new MessageBuilder().Add(new AtSegment(taskinfo.atuserqq)).Text(msg).Build();
|
||
|
||
await runbot.runbotr.SendMessageAsync(MessageEnvironment.Channel, qqgroup, null, message, qqgroup);
|
||
return Ok(new error_mb { code = 200, message = "新建任务成功" });
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
return Ok(new { code = 500, message = "服务器错误", details = ex ,wp});
|
||
}
|
||
|
||
}
|
||
|
||
}
|
||
|
||
|
||
[Route("api/v1/admin/Task")]
|
||
[HttpDelete]
|
||
[Authorize]
|
||
public async Task<ActionResult<object>> DelTask([FromQuery] long id)
|
||
{
|
||
if (!this.User.FindAll(ClaimTypes.Role).Any(a => a.Value == "nbadmin"))
|
||
{
|
||
return Ok(new error_mb { code = 401, message = "无权访问" });
|
||
}
|
||
using (TestDbContext sub = new TestDbContext())
|
||
{
|
||
sub.T_Task.Remove(sub.T_Task.Find(id));
|
||
await sub.SaveChangesAsync();
|
||
return Ok(new error_mb { code = 200, message = "成功删除" });
|
||
}
|
||
}
|
||
|
||
[Route("api/v1/Task")]
|
||
[HttpGet]
|
||
[Authorize]
|
||
public async Task<ActionResult<object>> CekTask([FromQuery] long taskid)
|
||
{
|
||
using (TestDbContext sub = new TestDbContext())
|
||
{
|
||
var task = sub.T_Task.Find(taskid);
|
||
var dateString = DateTime.Now;
|
||
task.status = "1";
|
||
task.lastOperateTime = dateString.ToString();
|
||
await sub.SaveChangesAsync();
|
||
return Ok(new error_mb { code = 200, message = "成功提交修改" });
|
||
}
|
||
}
|
||
public class statusChange
|
||
{
|
||
public long taskid { get; set; }
|
||
public string status { get; set; }
|
||
|
||
}
|
||
[Route("api/v1/admin/Task/Done")]
|
||
[HttpPost]
|
||
[Authorize]
|
||
public async Task<ActionResult<object>> FinishTask([FromBody] statusChange msg)
|
||
{
|
||
string userId = this.User.FindFirst(ClaimTypes.NameIdentifier)!.Value;
|
||
var user = await userManager.FindByIdAsync(userId);
|
||
|
||
if (!this.User.FindAll(ClaimTypes.Role).Any(a => a.Value == "nbadmin"))
|
||
{
|
||
return Ok(new error_mb { code = 401, message = "无权访问" });
|
||
}
|
||
var dateString = DateTime.Now;
|
||
using (TestDbContext sub = new TestDbContext())
|
||
{
|
||
var task = sub.T_Task.Find(msg.taskid);
|
||
long isPassed = long.Parse(msg.status);
|
||
if(isPassed == 2)
|
||
{
|
||
task.status = "2";
|
||
//user.Integral += task.money;
|
||
var user_done = await userManager.FindByIdAsync(task.userId.ToString());
|
||
user_done.Integral += task.money;
|
||
}
|
||
if (isPassed == 3)
|
||
{
|
||
task.status = "3";
|
||
}
|
||
task.lastOperateTime = dateString.ToString();
|
||
task.approvalPerson = user.chinaname;
|
||
await userManager.UpdateAsync(user);
|
||
await sub.SaveChangesAsync();
|
||
var result = new
|
||
{
|
||
approvalPerson = user.chinaname,
|
||
status = task.status,
|
||
taskId = msg.taskid,
|
||
code = 200,
|
||
message = "成功修改"
|
||
};
|
||
return Ok(result);
|
||
}
|
||
}
|
||
|
||
[Route("api/v1/Tasks")]
|
||
[HttpGet]
|
||
[Authorize]
|
||
public async Task<ActionResult<List<TaskDB>>> GetTasks([FromQuery] string userid = null)
|
||
{
|
||
TestDbContext test = new TestDbContext();
|
||
|
||
var query = test.T_Task.AsQueryable();
|
||
|
||
if (!string.IsNullOrEmpty(userid))
|
||
{
|
||
long idNum = long.Parse(userid);
|
||
query = query.Where(n => n.userId == idNum);
|
||
}
|
||
|
||
//return Ok("用户不存在");
|
||
return query.OrderByDescending(a => a.userId).ToList();
|
||
}
|
||
|
||
[Route("api/v1/admin/FindTasks")]
|
||
[HttpGet]
|
||
[Authorize]
|
||
public async Task<ActionResult<object>> FindTasks([FromQuery] string chinaname = null,string status = null,short page = 1,short limit = 10)
|
||
{
|
||
//string encodedChinaname = HttpUtility.UrlEncode(chinaname);
|
||
|
||
if (!this.User.FindAll(ClaimTypes.Role).Any(a => a.Value == "nbadmin"))
|
||
{
|
||
return Ok(new error_mb { code = 401, message = "无权访问" });
|
||
}
|
||
using (TestDbContext sub = new TestDbContext())
|
||
{
|
||
//List <TaskDB> taskDBs = new List<TaskDB>();
|
||
|
||
var query = sub.T_Task.AsQueryable();
|
||
|
||
if (!string.IsNullOrEmpty(chinaname))
|
||
{
|
||
query = query.Where(n => n.chinaname.Contains(chinaname));
|
||
}
|
||
|
||
if (!string.IsNullOrEmpty(status))
|
||
{
|
||
query = query.Where(n => n.status == status);
|
||
}
|
||
|
||
// var customOrder = new[] { "1","0","3","2" };
|
||
|
||
var TotalRecords = await query.CountAsync();
|
||
|
||
var Tasks = await query
|
||
.OrderByDescending(t => t.status == "1" ? 3 :
|
||
t.status == "0" ? 2 :
|
||
t.status == "3" ? 1 :
|
||
t.status == "2" ? 0 :
|
||
int.MaxValue)
|
||
.Skip((page - 1) * limit)
|
||
.Take(limit)
|
||
.ToListAsync();
|
||
|
||
var result = new
|
||
{
|
||
rows = Tasks ,
|
||
total = TotalRecords,
|
||
};
|
||
return Ok(result);
|
||
}
|
||
}
|
||
|
||
|
||
}
|
||
}
|