using Competition.Common.Util;
using CompetitionAPI.Util;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using System.Text;
namespace CompetitionAPI.Controllers.back
{
[Route("api/[controller]")]
[ApiController]
public class GetExamRosterListController : Controller
{
Competition.Mysql.BLL.pow_exam_users exam_users_bll = new Competition.Mysql.BLL.pow_exam_users();
public GetExamRosterListController()
{
}
///
/// 获取已设置考试名单列表接口
///
/// 考试id
/// 姓名
/// 账号
/// 页码/param>
/// 每页数量/param>
///
[Authorize]
[HttpGet]
[APIFilter]
public JsonResult Index(int PageIndex, int PageSize, string ExamId, string Name = "", string Account = "")
{
try
{
var query = new StringBuilder(" T1.ExamId='" + ExamId + "' ");
var total_query = new StringBuilder(" T1.ExamId='" + ExamId + "' ");
if (!string.IsNullOrWhiteSpace(Name))
{
query.AppendFormat(" AND T2.real_name LIKE '%{0}%' ", Name);
total_query.AppendFormat(" AND T2.real_name LIKE '%{0}%' ", Name);
}
if (!string.IsNullOrWhiteSpace(Account))
{
query.AppendFormat(" AND T2.login_name LIKE '%{0}%' ", Account);
total_query.AppendFormat(" AND T2.login_name LIKE '%{0}%' ", Account);
}
var offset = (PageIndex - 1) * PageSize;
query.AppendFormat(" order by T1.CreateTime desc LIMIT {0} OFFSET {1} ", PageSize, offset);
var total = exam_users_bll.GetRecordUserCount(total_query.ToString());
var list = exam_users_bll.GetUserList(query.ToString());
return Json(Tool.GetJsonWithCode(APICode.Success, new { total = total, list = list }));
}
catch (Exception ex)
{
LogHelper.WriteLog(ex.Message + ",行号:" + ex.StackTrace);
return Json(Tool.GetJsonWithCode(APICode.Fail, "发生错误,请联系管理员。"));
}
}
}
}