using Bootstrap.Admin.Query;
using Bootstrap.DataAccess;
using Longbow.Web.Mvc;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
namespace Bootstrap.Admin.Controllers.Api
{
///
///
///
[Route("api/[controller]")]
public class UsersController : Controller
{
///
///
///
///
///
[HttpGet]
public QueryData Get(QueryUserOption value)
{
return value.RetrieveData();
}
///
///
///
///
[HttpPut]
public bool Put([FromBody]User value)
{
if (User.IsInRole("Administrators")) return false;
var ret = false;
if (value.UserStatus == UserStates.ChangeTheme)
{
return UserHelper.SaveUserCssByName(value.UserName, value.Css);
}
if (value.UserName.Equals(User.Identity.Name, System.StringComparison.OrdinalIgnoreCase))
{
if (value.UserStatus == UserStates.ChangeDisplayName)
ret = UserHelper.SaveDisplayName(value.UserName, value.DisplayName);
else if (value.UserStatus == UserStates.ChangePassword)
ret = UserHelper.ChangePassword(value.UserName, value.Password, value.NewPassword);
}
return ret;
}
///
///
///
///
///
///
[HttpPost("{id}")]
public IEnumerable Post(int id, [FromQuery]string type)
{
var ret = new List();
switch (type)
{
case "role":
ret = UserHelper.RetrieveUsersByRoleId(id).ToList();
break;
case "group":
ret = UserHelper.RetrieveUsersByGroupId(id).ToList();
break;
default:
break;
}
return ret;
}
///
///
///
///
[HttpPost]
public bool Post([FromBody]User value)
{
var ret = false;
if (value.Id == 0)
{
value.Description = string.Format("管理员{0}创建用户", User.Identity.Name);
value.ApprovedBy = User.Identity.Name;
ret = UserHelper.SaveUser(value);
}
else
{
ret = UserHelper.UpdateUser(value.Id, value.Password, value.DisplayName);
}
return ret;
}
///
///
///
///
///
///
///
[HttpPut("{id}")]
public bool Put(int id, [FromBody]IEnumerable userIds, [FromQuery]string type)
{
var ret = false;
switch (type)
{
case "role":
ret = UserHelper.SaveUsersByRoleId(id, userIds);
break;
case "group":
ret = UserHelper.SaveUsersByGroupId(id, userIds);
break;
default:
break;
}
return ret;
}
///
///
///
///
[HttpDelete]
public bool Delete([FromBody]IEnumerable value)
{
return UserHelper.DeleteUser(value);
}
///
///
///
///
[AllowAnonymous]
[HttpOptions]
public string Options()
{
return null;
}
}
}