2020-10-22 14:59:36 +08:00
|
|
|
|
// ***********************************************************************
|
|
|
|
|
// Assembly : OpenAuth.App
|
|
|
|
|
// Author : 李玉宝
|
|
|
|
|
// Created : 06-06-2018
|
|
|
|
|
//
|
|
|
|
|
// Last Modified By : 李玉宝
|
|
|
|
|
// Last Modified On : 07-04-2018
|
|
|
|
|
// ***********************************************************************
|
|
|
|
|
// <copyright file="NormalAuthStrategy.cs" company="OpenAuth.App">
|
2021-07-22 19:33:55 +08:00
|
|
|
|
// Copyright (c) http://www.openauth.net.cn. All rights reserved.
|
2020-10-22 14:59:36 +08:00
|
|
|
|
// </copyright>
|
|
|
|
|
// <summary>
|
|
|
|
|
// 普通用户授权策略
|
|
|
|
|
// </summary>
|
|
|
|
|
// ***********************************************************************
|
|
|
|
|
|
|
|
|
|
|
2021-12-07 01:06:53 +08:00
|
|
|
|
using System;
|
2020-10-22 14:59:36 +08:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using Infrastructure;
|
|
|
|
|
using OpenAuth.App.Response;
|
2020-12-29 23:52:06 +08:00
|
|
|
|
using OpenAuth.Repository;
|
2020-10-22 14:59:36 +08:00
|
|
|
|
using OpenAuth.Repository.Domain;
|
|
|
|
|
using OpenAuth.Repository.Interface;
|
2023-12-23 15:42:50 +08:00
|
|
|
|
using SqlSugar;
|
2020-10-22 14:59:36 +08:00
|
|
|
|
|
|
|
|
|
namespace OpenAuth.App
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 普通用户授权策略
|
|
|
|
|
/// </summary>
|
2025-02-19 12:44:42 +08:00
|
|
|
|
public class NormalAuthStrategy : SqlSugarBaseApp<SysUser>, IAuthStrategy
|
2020-10-22 14:59:36 +08:00
|
|
|
|
{
|
|
|
|
|
|
2025-02-19 12:44:42 +08:00
|
|
|
|
protected SysUser _user;
|
2020-10-22 14:59:36 +08:00
|
|
|
|
|
|
|
|
|
private List<string> _userRoleIds; //用户角色GUID
|
|
|
|
|
private DbExtension _dbExtension;
|
|
|
|
|
|
|
|
|
|
public List<ModuleView> Modules
|
|
|
|
|
{
|
|
|
|
|
get {
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var moduleIds = SugarClient.Queryable<Relevance>().Where(
|
2020-10-22 14:59:36 +08:00
|
|
|
|
u =>
|
2024-12-13 09:48:07 +08:00
|
|
|
|
u.Key == Define.ROLEMODULE && _userRoleIds.Contains(u.FirstId)).Select(u => u.SecondId).ToList();
|
2024-07-18 21:52:02 +08:00
|
|
|
|
var elementIds = GetElementIds();
|
2023-12-23 15:42:50 +08:00
|
|
|
|
|
2024-07-18 21:52:02 +08:00
|
|
|
|
return SugarClient.Queryable<ModuleView>().Where(m =>moduleIds.Contains(m.Id))
|
|
|
|
|
.Includes(x=>x.Elements.Where(u=>elementIds.Contains(u.Id)).ToList()).ToList();
|
2023-12-23 15:42:50 +08:00
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public List<ModuleElement> ModuleElements
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
2024-07-18 21:52:02 +08:00
|
|
|
|
var elementIds = GetElementIds();
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var usermoduleelements = SugarClient.Queryable<ModuleElement>().Where(u => elementIds.Contains(u.Id));
|
2020-10-22 14:59:36 +08:00
|
|
|
|
return usermoduleelements.ToList();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-18 21:52:02 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// 获取角色可访问的菜单Id
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
private List<string> GetElementIds()
|
|
|
|
|
{
|
|
|
|
|
var elementIds = SugarClient.Queryable<Relevance>().Where(
|
|
|
|
|
u =>
|
2024-12-13 09:48:07 +08:00
|
|
|
|
u.Key == Define.ROLEELEMENT && _userRoleIds.Contains(u.FirstId)).Select(u => u.SecondId).ToList();
|
2024-07-18 21:52:02 +08:00
|
|
|
|
return elementIds;
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
public List<Role> Roles
|
|
|
|
|
{
|
2023-12-23 15:42:50 +08:00
|
|
|
|
get { return SugarClient.Queryable<Role>().Where(u => _userRoleIds.Contains(u.Id)).ToList(); }
|
2020-10-22 14:59:36 +08:00
|
|
|
|
}
|
|
|
|
|
|
2025-02-19 12:44:42 +08:00
|
|
|
|
public List<SysResource> Resources
|
2020-10-22 14:59:36 +08:00
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var resourceIds = SugarClient.Queryable<Relevance>().Where(
|
2020-10-22 14:59:36 +08:00
|
|
|
|
u =>
|
2024-12-13 09:48:07 +08:00
|
|
|
|
u.Key == Define.ROLERESOURCE && _userRoleIds.Contains(u.FirstId)).Select(u => u.SecondId).ToList();
|
2025-02-19 12:44:42 +08:00
|
|
|
|
return SugarClient.Queryable<SysResource>().Where(u => resourceIds.Contains(u.Id)).ToList();
|
2020-10-22 14:59:36 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-23 15:42:50 +08:00
|
|
|
|
public List<OrgView> Orgs
|
2020-10-22 14:59:36 +08:00
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var orgids = SugarClient.Queryable<Relevance>().Where(
|
|
|
|
|
u =>u.FirstId == _user.Id && u.Key == Define.USERORG).Select(u => u.SecondId).ToList();
|
|
|
|
|
return SugarClient.Queryable<SysOrg>().Where(org =>orgids.Contains(org.Id))
|
2025-02-19 12:44:42 +08:00
|
|
|
|
.LeftJoin<SysUser>((org, user) => org.ChairmanId ==user.Id)
|
2023-12-23 15:42:50 +08:00
|
|
|
|
.Select((org,user)=>new OrgView
|
|
|
|
|
{
|
|
|
|
|
Id = org.Id.SelectAll(),
|
|
|
|
|
ChairmanName = user.Name
|
|
|
|
|
}).ToList();
|
2020-10-22 14:59:36 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-19 12:44:42 +08:00
|
|
|
|
public SysUser User
|
2020-10-22 14:59:36 +08:00
|
|
|
|
{
|
|
|
|
|
get { return _user; }
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
_user = value;
|
2023-12-23 15:42:50 +08:00
|
|
|
|
_userRoleIds = SugarClient.Queryable<Relevance>().Where(u => u.FirstId == _user.Id && u.Key == Define.USERROLE)
|
|
|
|
|
.Select(u => u.SecondId).ToList();
|
2020-10-22 14:59:36 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-10-18 00:42:29 +08:00
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
|
2021-08-25 01:42:37 +08:00
|
|
|
|
public List<BuilderTableColumn> GetTableColumns(string moduleCode)
|
|
|
|
|
{
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var allprops = SugarClient.Queryable<BuilderTableColumn>()
|
|
|
|
|
.Where(u => u.TableName.ToLower() == moduleCode.ToLower());
|
2021-12-07 01:06:53 +08:00
|
|
|
|
//如果是子表,直接返回所有字段
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var builderTable = SugarClient.Queryable<BuilderTable>().First(u => u.TableName.ToLower() == moduleCode.ToLower());
|
2021-12-07 01:06:53 +08:00
|
|
|
|
if (builderTable == null)
|
|
|
|
|
{
|
|
|
|
|
throw new Exception($"代码生成器中找不到{moduleCode.ToLower()}的定义");
|
|
|
|
|
}
|
|
|
|
|
//如果是子表,因为不能在模块界面分配,所以直接返回所有字段,后期可以优化。
|
|
|
|
|
if (builderTable.ParentTableId != null)
|
|
|
|
|
{
|
|
|
|
|
return allprops.ToList();
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-25 01:42:37 +08:00
|
|
|
|
//如果是系统模块,直接返回所有字段。防止开发者把模块配置成系统模块,还在外层调用loginContext.GetProperties("xxxx");
|
2023-12-23 15:42:50 +08:00
|
|
|
|
bool? isSysModule = SugarClient.Queryable<Module>().First(u => u.Code == moduleCode)?.IsSys;
|
2021-08-25 01:42:37 +08:00
|
|
|
|
if (isSysModule!= null && isSysModule.Value)
|
|
|
|
|
{
|
|
|
|
|
return allprops.ToList();
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var props =SugarClient.Queryable<Relevance>().Where(u =>
|
2021-08-25 01:42:37 +08:00
|
|
|
|
u.Key == Define.ROLEDATAPROPERTY && _userRoleIds.Contains(u.FirstId) && u.SecondId == moduleCode)
|
2023-12-23 15:42:50 +08:00
|
|
|
|
.Select(u => u.ThirdId).ToList();
|
2021-08-25 01:42:37 +08:00
|
|
|
|
|
|
|
|
|
return allprops.Where(u => props.Contains(u.ColumnName)).ToList();
|
|
|
|
|
}
|
|
|
|
|
|
2022-02-21 00:39:55 +08:00
|
|
|
|
public List<BuilderTableColumn> GetTableColumnsFromDb(string moduleCode)
|
|
|
|
|
{
|
|
|
|
|
var allprops = _dbExtension.GetTableColumnsFromDb(moduleCode);
|
|
|
|
|
|
|
|
|
|
//如果是系统模块,直接返回所有字段。防止开发者把模块配置成系统模块,还在外层调用loginContext.GetProperties("xxxx");
|
2023-12-23 15:42:50 +08:00
|
|
|
|
bool? isSysModule = SugarClient.Queryable<Module>().First(u => u.Code == moduleCode)?.IsSys;
|
2022-02-21 00:39:55 +08:00
|
|
|
|
if (isSysModule!= null && isSysModule.Value)
|
|
|
|
|
{
|
|
|
|
|
return allprops.ToList();
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-23 15:42:50 +08:00
|
|
|
|
var props =SugarClient.Queryable<Relevance>().Where(u =>
|
2022-02-21 00:39:55 +08:00
|
|
|
|
u.Key == Define.ROLEDATAPROPERTY && _userRoleIds.Contains(u.FirstId) && u.SecondId == moduleCode)
|
2023-12-23 15:42:50 +08:00
|
|
|
|
.Select(u => u.ThirdId).ToList();
|
2022-02-21 00:39:55 +08:00
|
|
|
|
|
|
|
|
|
return allprops.Where(u => props.Contains(u.ColumnName)).ToList();
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-22 14:59:36 +08:00
|
|
|
|
//用户角色
|
|
|
|
|
|
2023-12-23 15:42:50 +08:00
|
|
|
|
public NormalAuthStrategy(ISqlSugarClient client,DbExtension dbExtension) : base(client, null)
|
2020-10-22 14:59:36 +08:00
|
|
|
|
{
|
|
|
|
|
_dbExtension = dbExtension;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|