// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。 // // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。 // // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任! namespace Admin.NET.Core; /// /// 系统用户机构视图 /// [SugarTable(null, "系统用户机构视图"), IgnoreTable] public class VSysUserOrg : ISqlSugarView { /// /// 用户Id /// [SugarColumn(ColumnDescription = "用户Id")] public long UserId { get; set; } /// /// 机构Id /// [SugarColumn(ColumnDescription = "机构Id")] public long OrgId { get; set; } /// /// 视图语句 /// public string GetQueryableSqlString(SqlSugarScopeProvider db) { return db.Union( // 获取用户表中的机构Id db.Queryable().IgnoreTenant() .Select(u => new VSysUserOrg { UserId = u.Id, OrgId = u.OrgId }), // 获取用户创建的机构Id db.Queryable().IgnoreTenant() .Where(u => u.CreateUserId != null) .Select(u => new VSysUserOrg { UserId = u.CreateUserId.Value, OrgId = u.Id }), // 获取用户扩展机构Id db.Queryable() .Select(u => new VSysUserOrg { UserId = u.UserId, OrgId = u.OrgId }), // 获取用户角色关联的机构Id db.Queryable() .InnerJoin((u, a) => u.RoleId == a.RoleId) .Select((u, a) => new VSysUserOrg { UserId = a.UserId, OrgId = u.OrgId }), // 获取包含全部数据权限的机构Id db.Queryable().IgnoreTenant() .FullJoin((u, a) => a.SysRole.DataScope == DataScopeEnum.All) .Select((u, a) => new VSysUserOrg { UserId = a.UserId, OrgId = u.Id }), // 超管获取全部机构Id db.Queryable().IgnoreTenant() .FullJoin((u, a) => a.AccountType == AccountTypeEnum.SuperAdmin) .Select((u, a) => new VSysUserOrg { UserId = a.Id, OrgId = u.Id })) .Where(u => u.OrgId != null && u.OrgId != 0) .ToMappedSqlString(); } }