77 lines
2.2 KiB
C#
77 lines
2.2 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 DataTablePermissionBasePage : ContractorBasePage
|
|
{
|
|
protected void ProcessRequest(string methodName)
|
|
{
|
|
object result = null;
|
|
|
|
try
|
|
{
|
|
if (methodName != null)
|
|
{
|
|
switch (methodName.ToUpper())
|
|
{
|
|
case "GETUSERS":
|
|
result = GetUsers();
|
|
break;
|
|
case "GETUSERGROUPS":
|
|
result = GetUserGroups();
|
|
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; } }
|
|
|
|
private UserInfo[] GetUsers()
|
|
{
|
|
var users = UserManagement.GetUnmanagementUsers().OrderBy(u => u.DisplayName).ToArray();
|
|
return users;
|
|
}
|
|
|
|
private UserGroupInfo[] GetUserGroups()
|
|
{
|
|
var groups = UserManagement.GetGroups();
|
|
return groups;
|
|
}
|
|
}
|
|
}
|