156 lines
4.6 KiB
C#
156 lines
4.6 KiB
C#
using IronIntel.Contractor.Users;
|
|
using Newtonsoft.Json;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using System.Web;
|
|
|
|
namespace IronIntel.Contractor.Site.Security
|
|
{
|
|
public class UserGroupBasePage : ContractorBasePage
|
|
{
|
|
protected void ProcessRequest(string methodName)
|
|
{
|
|
object result = null;
|
|
|
|
try
|
|
{
|
|
if (methodName != null)
|
|
{
|
|
switch (methodName.ToUpper())
|
|
{
|
|
case "GETGROUPS":
|
|
result = GetGroups();
|
|
break;
|
|
case "GETGROUPINFO":
|
|
result = GetGroupInfo();
|
|
break;
|
|
case "SAVEGROUP":
|
|
result = SaveGroup();
|
|
break;
|
|
case "DELETEGROUP":
|
|
result = DeleteGroup();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
result = ex.Message;
|
|
SystemParams.WriteLog("Error", "UserGroupBasePage.ProcessRequest", ex.Message, ex.ToString());
|
|
}
|
|
|
|
string json = JsonConvert.SerializeObject(result);
|
|
Response.Write(json);
|
|
Response.End();
|
|
}
|
|
|
|
protected override bool AllowCurrentLoginSessionEnter()
|
|
{
|
|
var f = base.AllowCurrentLoginSessionEnter();
|
|
if (!f)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
// check whether you are admin.
|
|
var session = GetCurrentLoginSession();
|
|
if (session == null || session.User == null)
|
|
{
|
|
return false;
|
|
}
|
|
var ui = UserManagement.GetUserByIID(session.User.UID);
|
|
return ui != null && ui.UserType >= UserTypes.Admin;
|
|
}
|
|
|
|
protected override bool ThrowIfNotAllowed { get { return true; } }
|
|
|
|
public UserGroupInfo[] GetGroups()
|
|
{
|
|
var groups = UserManagement.GetGroups().ToArray();
|
|
return groups;
|
|
}
|
|
|
|
public GroupDetail GetGroupInfo()
|
|
{
|
|
var iid = Request.Form["ClientData"];
|
|
UserGroupInfo group;
|
|
if (string.IsNullOrEmpty(iid))
|
|
{
|
|
group = new UserGroupInfo();
|
|
}
|
|
else
|
|
{
|
|
Guid guid;
|
|
if (!Guid.TryParse(iid, out guid))
|
|
{
|
|
throw new ArgumentException("Group ID is not valid.");
|
|
}
|
|
|
|
// 返回带 Users 数据的详细用户组对象
|
|
group = UserManagement.GetGroup(guid.ToString());
|
|
}
|
|
var users = UserManagement.GetUsers().OrderBy(u => u.ID).ToArray();
|
|
|
|
return new GroupDetail
|
|
{
|
|
GroupInfo = group,
|
|
Users = users
|
|
};
|
|
}
|
|
|
|
public string SaveGroup()
|
|
{
|
|
var content = Request.Form["ClientData"];
|
|
content = HttpUtility.HtmlDecode(content);
|
|
var item = JsonConvert.DeserializeObject<UserGroupInfo>(content);
|
|
|
|
// 保存组基本信息,与包含的全部用户
|
|
if (string.IsNullOrWhiteSpace(item.Name))
|
|
{
|
|
throw new ArgumentException("Group Name cannot be empty.");
|
|
}
|
|
item.Name = item.Name.Trim();
|
|
if (string.IsNullOrEmpty(item.ID))
|
|
{
|
|
// add
|
|
item.ID = Guid.NewGuid().ToString();
|
|
UserManagement.AddGroup(item);
|
|
}
|
|
else
|
|
{
|
|
UserManagement.UpdateGroup(item);
|
|
}
|
|
return "";
|
|
}
|
|
|
|
public string DeleteGroup()
|
|
{
|
|
var iid = Request.Form["ClientData"];
|
|
Guid guid;
|
|
if (!Guid.TryParse(iid, out guid))
|
|
{
|
|
throw new ArgumentException("Group ID is not valid.");
|
|
}
|
|
try
|
|
{
|
|
UserManagement.DeleteGroup(guid.ToString());
|
|
return "";
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
SystemParams.WriteLog("Error", "DeleteGroup", ex.Message, ex.ToString());
|
|
throw ex;
|
|
}
|
|
}
|
|
}
|
|
|
|
public class GroupDetail
|
|
{
|
|
public UserGroupInfo GroupInfo { get; set; }
|
|
public UserInfo[] Users { get; set; }
|
|
}
|
|
}
|