2017-04-03 15:56:17 +08:00
using Bootstrap.Security ;
2018-10-28 23:35:23 +08:00
using Bootstrap.Security.DataAccess ;
2018-10-21 10:02:59 +08:00
using Longbow ;
using Longbow.Data ;
2018-10-28 08:29:15 +08:00
using Longbow.Security.Cryptography ;
2017-04-03 15:56:17 +08:00
using System ;
2018-10-19 23:09:52 +08:00
using System.Collections.Generic ;
using System.Data ;
using System.Data.Common ;
2018-10-21 10:02:59 +08:00
using System.Data.SqlClient ;
using System.Linq ;
2016-11-06 16:01:14 +08:00
namespace Bootstrap.DataAccess
2016-10-22 16:58:31 +08:00
{
/// <summary>
/// 用户表实体类
/// </summary>
2017-04-03 15:56:17 +08:00
public class User : BootstrapUser
2016-10-22 16:58:31 +08:00
{
/// <summary>
/// 获得/设置 用户主键ID
/// </summary>
2018-10-30 13:07:29 +08:00
public string Id { get ; set ; }
2016-10-22 16:58:31 +08:00
/// <summary>
/// 获取/设置 密码
/// </summary>
public string Password { get ; set ; }
/// <summary>
2016-10-24 19:59:07 +08:00
/// 获取/设置 密码盐
2016-10-22 16:58:31 +08:00
/// </summary>
public string PassSalt { get ; set ; }
2016-10-24 01:01:29 +08:00
/// <summary>
2016-10-28 20:18:12 +08:00
/// 获取/设置 角色用户关联状态 checked 标示已经关联 '' 标示未关联
/// </summary>
public string Checked { get ; set ; }
2016-11-06 16:01:14 +08:00
/// <summary>
/// 获得/设置 用户注册时间
/// </summary>
public DateTime RegisterTime { get ; set ; }
/// <summary>
/// 获得/设置 用户被批复时间
/// </summary>
public DateTime ApprovedTime { get ; set ; }
2016-11-10 10:14:27 +08:00
/// <summary>
2016-11-11 14:47:54 +08:00
/// 获得/设置 用户批复人
/// </summary>
public string ApprovedBy { get ; set ; }
/// <summary>
2016-11-10 10:14:27 +08:00
/// 获得/设置 用户的申请理由
/// </summary>
public string Description { get ; set ; }
2016-11-11 14:32:52 +08:00
/// <summary>
2018-09-07 15:53:16 +08:00
/// 获得/设置 用户当前状态 0 表示管理员注册用户 1 表示用户注册 2 表示更改密码 3 表示更改个人皮肤 4 表示更改显示名称 5 批复新用户注册操作
2016-11-11 14:32:52 +08:00
/// </summary>
2018-09-07 15:53:16 +08:00
public UserStates UserStatus { get ; set ; }
2016-11-11 18:02:27 +08:00
/// <summary>
/// 获得/设置 通知描述 2分钟内为刚刚
/// </summary>
public string Period { get ; set ; }
2016-11-12 15:26:40 +08:00
/// <summary>
2016-11-16 20:06:28 +08:00
/// 获得/设置 新密码
/// </summary>
public string NewPassword { get ; set ; }
2017-01-03 19:47:37 +08:00
/// <summary>
2018-10-19 23:09:52 +08:00
/// 验证用户登陆账号与密码正确
/// </summary>
/// <param name="userName"></param>
/// <param name="password"></param>
/// <returns></returns>
public virtual bool Authenticate ( string userName , string password )
{
if ( string . IsNullOrEmpty ( userName ) & & string . IsNullOrEmpty ( password ) ) return false ;
string oldPassword = null ;
string passwordSalt = null ;
2018-11-02 12:43:21 +08:00
string sql = "select Password, PassSalt from Users where ApprovedTime is not null and UserName = @UserName" ;
2018-10-20 22:25:53 +08:00
var db = DbAccessManager . DBAccess ;
2018-10-19 23:09:52 +08:00
using ( DbCommand cmd = db . CreateCommand ( CommandType . Text , sql ) )
{
cmd . Parameters . Add ( db . CreateParameter ( "@UserName" , userName ) ) ;
using ( DbDataReader reader = db . ExecuteReader ( cmd ) )
{
if ( reader . Read ( ) )
{
oldPassword = ( string ) reader [ 0 ] ;
passwordSalt = ( string ) reader [ 1 ] ;
}
}
}
return ! string . IsNullOrEmpty ( passwordSalt ) & & oldPassword = = LgbCryptography . ComputeHash ( password , passwordSalt ) ;
}
/// <summary>
2018-10-21 10:02:59 +08:00
///
/// </summary>
/// <param name="userName"></param>
/// <param name="password"></param>
/// <param name="newPass"></param>
/// <returns></returns>
public virtual bool ChangePassword ( string userName , string password , string newPass )
{
bool ret = false ;
if ( Authenticate ( userName , password ) )
{
string sql = "Update Users set Password = @Password, PassSalt = @PassSalt where UserName = @userName" ;
var passSalt = LgbCryptography . GenerateSalt ( ) ;
var newPassword = LgbCryptography . ComputeHash ( newPass , passSalt ) ;
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@Password" , newPassword ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@PassSalt" , passSalt ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@userName" , userName ) ) ;
ret = DbAccessManager . DBAccess . ExecuteNonQuery ( cmd ) = = 1 ;
}
}
return ret ;
}
/// <summary>
2018-10-19 23:09:52 +08:00
/// 查询所有用户
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
2018-10-21 10:02:59 +08:00
public virtual IEnumerable < User > RetrieveUsers ( )
{
2018-10-28 15:03:59 +08:00
List < User > users = new List < User > ( ) ;
DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , "select ID, UserName, DisplayName, RegisterTime, ApprovedTime, ApprovedBy, Description from Users Where ApprovedTime is not null" ) ;
2018-10-21 10:02:59 +08:00
2018-10-28 15:03:59 +08:00
using ( DbDataReader reader = DbAccessManager . DBAccess . ExecuteReader ( cmd ) )
{
while ( reader . Read ( ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
users . Add ( new User ( )
2018-10-21 10:02:59 +08:00
{
2018-10-30 13:07:29 +08:00
Id = reader [ 0 ] . ToString ( ) ,
2018-10-28 15:03:59 +08:00
UserName = ( string ) reader [ 1 ] ,
DisplayName = ( string ) reader [ 2 ] ,
RegisterTime = LgbConvert . ReadValue ( reader [ 3 ] , DateTime . MinValue ) ,
ApprovedTime = LgbConvert . ReadValue ( reader [ 4 ] , DateTime . MinValue ) ,
ApprovedBy = reader . IsDBNull ( 5 ) ? string . Empty : ( string ) reader [ 5 ] ,
Description = ( string ) reader [ 6 ]
} ) ;
2018-10-21 10:02:59 +08:00
}
2018-10-28 15:03:59 +08:00
}
return users ;
2018-10-21 10:02:59 +08:00
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 查询所有的新注册用户
/// </summary>
/// <returns></returns>
2018-10-21 10:02:59 +08:00
public virtual IEnumerable < User > RetrieveNewUsers ( )
{
2018-11-02 12:43:21 +08:00
string sql = "select ID, UserName, DisplayName, RegisterTime, Description from Users Where ApprovedTime is null order by RegisterTime desc" ;
2018-10-28 15:03:59 +08:00
List < User > users = new List < User > ( ) ;
DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) ;
using ( DbDataReader reader = DbAccessManager . DBAccess . ExecuteReader ( cmd ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
while ( reader . Read ( ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
users . Add ( new User ( )
2018-10-21 10:02:59 +08:00
{
2018-10-30 13:07:29 +08:00
Id = reader [ 0 ] . ToString ( ) ,
2018-10-28 15:03:59 +08:00
UserName = ( string ) reader [ 1 ] ,
DisplayName = ( string ) reader [ 2 ] ,
RegisterTime = LgbConvert . ReadValue ( reader [ 3 ] , DateTime . MinValue ) ,
Description = ( string ) reader [ 4 ]
} ) ;
2018-10-21 10:02:59 +08:00
}
2018-10-28 15:03:59 +08:00
}
return users ;
2018-10-21 10:02:59 +08:00
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 删除用户
/// </summary>
/// <param name="value"></param>
2018-10-30 13:07:29 +08:00
public virtual bool DeleteUser ( IEnumerable < string > value )
2018-10-21 10:02:59 +08:00
{
bool ret = false ;
var ids = string . Join ( "," , value ) ;
2018-11-02 19:35:55 +08:00
using ( TransactionPackage transaction = DbAccessManager . DBAccess . BeginTransaction ( ) )
2018-10-21 10:02:59 +08:00
{
2018-11-02 19:35:55 +08:00
try
{
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , $"Delete from UserRole where UserID in ({ids})" ) )
{
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
cmd . CommandText = $"delete from UserGroup where UserID in ({ids})" ;
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
cmd . CommandText = $"delete from Users where ID in ({ids})" ;
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
transaction . CommitTransaction ( ) ;
ret = true ;
}
}
catch ( Exception ex )
{
transaction . RollbackTransaction ( ) ;
throw ex ;
}
2018-10-21 10:02:59 +08:00
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
2018-10-30 17:02:36 +08:00
/// 新建前台User View调用/注册用户调用
2018-10-19 23:09:52 +08:00
/// </summary>
/// <param name="p"></param>
/// <returns></returns>
2018-10-21 10:02:59 +08:00
public virtual bool SaveUser ( User p )
{
var ret = false ;
2018-11-02 19:35:55 +08:00
if ( string . IsNullOrEmpty ( p . Id ) & & p . Description . Length > 500 ) p . Description = p . Description . Substring ( 0 , 500 ) ;
2018-10-21 10:02:59 +08:00
if ( p . UserName . Length > 50 ) p . UserName = p . UserName . Substring ( 0 , 50 ) ;
p . PassSalt = LgbCryptography . GenerateSalt ( ) ;
p . Password = LgbCryptography . ComputeHash ( p . Password , p . PassSalt ) ;
2018-11-02 19:35:55 +08:00
2018-11-21 21:01:50 +08:00
var db = DbAccessManager . DBAccess ;
using ( TransactionPackage transaction = db . BeginTransaction ( ) )
2018-10-21 10:02:59 +08:00
{
2018-11-02 19:35:55 +08:00
try
{
2018-11-21 21:01:50 +08:00
using ( DbCommand cmd = db . CreateCommand ( CommandType . Text , "select UserName from Users Where UserName = @userName" ) )
2018-11-02 19:35:55 +08:00
{
2018-11-21 21:01:50 +08:00
cmd . Parameters . Add ( db . CreateParameter ( "@userName" , p . UserName ) ) ;
var un = db . ExecuteScalar ( cmd , transaction ) ;
2018-11-02 19:35:55 +08:00
if ( DbAdapterManager . ToObjectValue ( un ) = = null )
{
2018-11-21 21:01:50 +08:00
object approveTime = DBNull . Value ;
if ( p . ApprovedTime ! = DateTime . MinValue ) approveTime = p . ApprovedTime ;
cmd . CommandText = "Insert Into Users (UserName, Password, PassSalt, DisplayName, RegisterTime, ApprovedBy, ApprovedTime, Description) values (@userName, @password, @passSalt, @displayName, @registerTime, @approvedBy, @approveTime, @description)" ;
cmd . Parameters . Add ( db . CreateParameter ( "@password" , p . Password ) ) ;
cmd . Parameters . Add ( db . CreateParameter ( "@passSalt" , p . PassSalt ) ) ;
cmd . Parameters . Add ( db . CreateParameter ( "@registerTime" , DateTime . Now ) ) ;
cmd . Parameters . Add ( db . CreateParameter ( "@displayName" , p . DisplayName ) ) ;
cmd . Parameters . Add ( db . CreateParameter ( "@approvedBy" , DbAdapterManager . ToDBValue ( p . ApprovedBy ) ) ) ;
cmd . Parameters . Add ( db . CreateParameter ( "@approveTime" , approveTime ) ) ;
cmd . Parameters . Add ( db . CreateParameter ( "@description" , p . Description ) ) ;
db . ExecuteNonQuery ( cmd , transaction ) ;
2018-11-02 19:35:55 +08:00
cmd . CommandText = $"insert into UserRole (UserID, RoleID) select ID, (select ID from Roles where RoleName = 'Default') RoleId from Users where UserName = '{p.UserName}'" ;
cmd . Parameters . Clear ( ) ;
2018-11-21 21:01:50 +08:00
db . ExecuteNonQuery ( cmd , transaction ) ;
2018-11-02 19:35:55 +08:00
transaction . CommitTransaction ( ) ;
ret = true ;
}
}
}
catch ( Exception ex )
{
transaction . RollbackTransaction ( ) ;
throw ex ;
}
2018-10-21 10:02:59 +08:00
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
2018-10-30 17:02:36 +08:00
/// User List 视图保存按钮调用
2018-10-19 23:09:52 +08:00
/// </summary>
/// <param name="id"></param>
/// <param name="password"></param>
/// <param name="displayName"></param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual bool UpdateUser ( string id , string password , string displayName )
2018-10-21 10:02:59 +08:00
{
bool ret = false ;
string sql = "Update Users set Password = @Password, PassSalt = @PassSalt, DisplayName = @DisplayName where ID = @id" ;
var passSalt = LgbCryptography . GenerateSalt ( ) ;
var newPassword = LgbCryptography . ComputeHash ( password , passSalt ) ;
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@id" , id ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@DisplayName" , displayName ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@Password" , newPassword ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@PassSalt" , passSalt ) ) ;
ret = DbAccessManager . DBAccess . ExecuteNonQuery ( cmd ) = = 1 ;
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
///
/// </summary>
/// <param name="id"></param>
/// <param name="approvedBy"></param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual bool ApproveUser ( string id , string approvedBy )
2018-10-19 23:09:52 +08:00
{
2018-10-21 10:02:59 +08:00
var ret = false ;
2018-11-02 19:35:55 +08:00
var sql = "update Users set ApprovedTime = @ApproveTime, ApprovedBy = @approvedBy where ID = @id" ;
2018-10-21 10:02:59 +08:00
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
2018-10-19 23:09:52 +08:00
{
2018-10-21 10:02:59 +08:00
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@id" , id ) ) ;
2018-11-02 19:35:55 +08:00
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@ApproveTime" , DateTime . Now , DbType . DateTime ) ) ;
2018-10-21 10:02:59 +08:00
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@approvedBy" , approvedBy ) ) ;
ret = DbAccessManager . DBAccess . ExecuteNonQuery ( cmd ) = = 1 ;
2018-10-19 23:09:52 +08:00
}
return ret ;
}
/// <summary>
///
/// </summary>
/// <param name="id"></param>
/// <param name="rejectBy"></param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual bool RejectUser ( string id , string rejectBy )
2018-10-21 10:02:59 +08:00
{
var ret = false ;
2018-11-02 19:46:45 +08:00
using ( TransactionPackage transaction = DbAccessManager . DBAccess . BeginTransaction ( ) )
2018-10-21 10:02:59 +08:00
{
2018-11-02 19:46:45 +08:00
try
{
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , $"insert into RejectUsers (UserName, DisplayName, RegisterTime, RejectedBy, RejectedTime, RejectedReason) select UserName, DisplayName, Registertime, '{rejectBy}', @RejectTime, '未填写' from Users where ID = {id}" ) )
{
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@RejectTime" , DateTime . Now , DbType . DateTime ) ) ;
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
cmd . Parameters . Clear ( ) ;
cmd . CommandText = $"delete from UserRole where UserId = {id}" ;
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
cmd . CommandText = $"delete from UserGroup where UserId = {id}" ;
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
cmd . CommandText = $"delete from users where ID = {id}" ;
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
transaction . CommitTransaction ( ) ;
ret = true ;
}
}
catch ( Exception ex )
{
transaction . RollbackTransaction ( ) ;
throw ex ;
}
2018-10-21 10:02:59 +08:00
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 通过roleId获取所有用户
/// </summary>
/// <param name="roleId"></param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual IEnumerable < User > RetrieveUsersByRoleId ( string roleId )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
List < User > users = new List < User > ( ) ;
2018-11-02 12:43:21 +08:00
string sql = "select u.ID, u.UserName, u.DisplayName, case ur.UserID when u.ID then 'checked' else '' end status from Users u left join UserRole ur on u.ID = ur.UserID and RoleID = @RoleID where u.ApprovedTime is not null" ;
2018-10-28 15:03:59 +08:00
DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@RoleID" , roleId ) ) ;
using ( DbDataReader reader = DbAccessManager . DBAccess . ExecuteReader ( cmd ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
while ( reader . Read ( ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
users . Add ( new User ( )
2018-10-21 10:02:59 +08:00
{
2018-10-30 13:07:29 +08:00
Id = reader [ 0 ] . ToString ( ) ,
2018-10-28 15:03:59 +08:00
UserName = ( string ) reader [ 1 ] ,
DisplayName = ( string ) reader [ 2 ] ,
Checked = ( string ) reader [ 3 ]
} ) ;
2018-10-21 10:02:59 +08:00
}
2018-10-28 15:03:59 +08:00
}
return users ;
2018-10-21 10:02:59 +08:00
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 通过角色ID保存当前授权用户( 插入)
/// </summary>
2018-10-23 15:37:42 +08:00
/// <param name="roleId">角色ID</param>
2018-10-19 23:09:52 +08:00
/// <param name="userIds">用户ID数组</param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual bool SaveUsersByRoleId ( string roleId , IEnumerable < string > userIds )
2018-10-21 10:02:59 +08:00
{
bool ret = false ;
DataTable dt = new DataTable ( ) ;
dt . Columns . Add ( "RoleID" , typeof ( int ) ) ;
dt . Columns . Add ( "UserID" , typeof ( int ) ) ;
2018-10-23 15:37:42 +08:00
userIds . ToList ( ) . ForEach ( userId = > dt . Rows . Add ( roleId , userId ) ) ;
2018-10-21 10:02:59 +08:00
using ( TransactionPackage transaction = DbAccessManager . DBAccess . BeginTransaction ( ) )
{
try
{
//删除用户角色表该角色所有的用户
2018-10-23 15:37:42 +08:00
string sql = $"delete from UserRole where RoleID = {roleId}" ;
2018-10-21 10:02:59 +08:00
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
//批插入用户角色表
using ( SqlBulkCopy bulk = new SqlBulkCopy ( ( SqlConnection ) transaction . Transaction . Connection , SqlBulkCopyOptions . Default , ( SqlTransaction ) transaction . Transaction ) )
{
bulk . DestinationTableName = "UserRole" ;
bulk . ColumnMappings . Add ( "RoleID" , "RoleID" ) ;
bulk . ColumnMappings . Add ( "UserID" , "UserID" ) ;
bulk . WriteToServer ( dt ) ;
transaction . CommitTransaction ( ) ;
}
}
ret = true ;
}
catch ( Exception ex )
{
transaction . RollbackTransaction ( ) ;
throw ex ;
}
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 通过groupId获取所有用户
/// </summary>
/// <param name="groupId"></param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual IEnumerable < User > RetrieveUsersByGroupId ( string groupId )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
List < User > users = new List < User > ( ) ;
2018-11-02 12:43:21 +08:00
string sql = "select u.ID, u.UserName, u.DisplayName, case ur.UserID when u.ID then 'checked' else '' end status from Users u left join UserGroup ur on u.ID = ur.UserID and GroupID =@groupId where u.ApprovedTime is not null" ;
2018-10-28 15:03:59 +08:00
DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@GroupID" , groupId ) ) ;
using ( DbDataReader reader = DbAccessManager . DBAccess . ExecuteReader ( cmd ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
while ( reader . Read ( ) )
2018-10-21 10:02:59 +08:00
{
2018-10-28 15:03:59 +08:00
users . Add ( new User ( )
2018-10-21 10:02:59 +08:00
{
2018-10-30 13:07:29 +08:00
Id = reader [ 0 ] . ToString ( ) ,
2018-10-28 15:03:59 +08:00
UserName = ( string ) reader [ 1 ] ,
DisplayName = ( string ) reader [ 2 ] ,
Checked = ( string ) reader [ 3 ]
} ) ;
2018-10-21 10:02:59 +08:00
}
2018-10-28 15:03:59 +08:00
}
return users ;
2018-10-21 10:02:59 +08:00
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 通过部门ID保存当前授权用户( 插入)
/// </summary>
2018-10-23 15:37:42 +08:00
/// <param name="groupId">GroupID</param>
2018-10-19 23:09:52 +08:00
/// <param name="userIds">用户ID数组</param>
/// <returns></returns>
2018-10-30 13:07:29 +08:00
public virtual bool SaveUsersByGroupId ( string groupId , IEnumerable < string > userIds )
2018-10-21 10:02:59 +08:00
{
bool ret = false ;
DataTable dt = new DataTable ( ) ;
dt . Columns . Add ( "UserID" , typeof ( int ) ) ;
dt . Columns . Add ( "GroupID" , typeof ( int ) ) ;
2018-10-23 15:37:42 +08:00
userIds . ToList ( ) . ForEach ( userId = > dt . Rows . Add ( userId , groupId ) ) ;
2018-10-21 10:02:59 +08:00
using ( TransactionPackage transaction = DbAccessManager . DBAccess . BeginTransaction ( ) )
{
try
{
//删除用户角色表该角色所有的用户
string sql = "delete from UserGroup where GroupID = @GroupID" ;
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
2018-10-23 15:37:42 +08:00
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@GroupID" , groupId ) ) ;
2018-10-21 10:02:59 +08:00
DbAccessManager . DBAccess . ExecuteNonQuery ( cmd , transaction ) ;
//批插入用户角色表
using ( SqlBulkCopy bulk = new SqlBulkCopy ( ( SqlConnection ) transaction . Transaction . Connection , SqlBulkCopyOptions . Default , ( SqlTransaction ) transaction . Transaction ) )
{
bulk . DestinationTableName = "UserGroup" ;
bulk . ColumnMappings . Add ( "UserID" , "UserID" ) ;
bulk . ColumnMappings . Add ( "GroupID" , "GroupID" ) ;
bulk . WriteToServer ( dt ) ;
transaction . CommitTransaction ( ) ;
}
}
ret = true ;
}
catch ( Exception ex )
{
transaction . RollbackTransaction ( ) ;
throw ex ;
}
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 根据用户名修改用户头像
/// </summary>
/// <param name="userName"></param>
/// <param name="iconName"></param>
/// <returns></returns>
2018-10-21 10:02:59 +08:00
public virtual bool SaveUserIconByName ( string userName , string iconName )
{
bool ret = false ;
string sql = "Update Users set Icon = @iconName where UserName = @userName" ;
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@iconName" , iconName ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@userName" , userName ) ) ;
ret = DbAccessManager . DBAccess . ExecuteNonQuery ( cmd ) = = 1 ;
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
///
/// </summary>
2018-10-21 10:02:59 +08:00
/// <param name="userName"></param>
2018-10-19 23:09:52 +08:00
/// <param name="displayName"></param>
/// <returns></returns>
2018-10-21 10:02:59 +08:00
public virtual bool SaveDisplayName ( string userName , string displayName )
{
bool ret = false ;
string sql = "Update Users set DisplayName = @DisplayName where UserName = @userName" ;
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@DisplayName" , displayName ) ) ;
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@userName" , userName ) ) ;
ret = DbAccessManager . DBAccess . ExecuteNonQuery ( cmd ) = = 1 ;
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
/// 根据用户名更改用户皮肤
/// </summary>
/// <param name="userName"></param>
/// <param name="cssName"></param>
/// <returns></returns>
2018-10-21 10:02:59 +08:00
public virtual bool SaveUserCssByName ( string userName , string cssName )
{
bool ret = false ;
string sql = "Update Users set Css = @cssName where UserName = @userName" ;
using ( DbCommand cmd = DbAccessManager . DBAccess . CreateCommand ( CommandType . Text , sql ) )
{
2018-10-21 21:08:35 +08:00
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@cssName" , DbAdapterManager . ToDBValue ( cssName ) ) ) ;
2018-10-21 10:02:59 +08:00
cmd . Parameters . Add ( DbAccessManager . DBAccess . CreateParameter ( "@userName" , userName ) ) ;
ret = DbAccessManager . DBAccess . ExecuteNonQuery ( cmd ) = = 1 ;
}
return ret ;
}
2018-10-19 23:09:52 +08:00
/// <summary>
///
/// </summary>
2018-10-21 10:02:59 +08:00
/// <param name="userName"></param>
2018-10-19 23:09:52 +08:00
/// <returns></returns>
2018-10-28 23:35:23 +08:00
public virtual BootstrapUser RetrieveUserByUserName ( string userName ) = > DbHelper . RetrieveUserByUserName ( userName ) ;
2018-10-19 23:09:52 +08:00
/// <summary>
2017-01-03 19:47:37 +08:00
///
/// </summary>
/// <returns></returns>
public override string ToString ( )
{
return string . Format ( "{0} ({1})" , UserName , DisplayName ) ;
}
2016-10-22 16:58:31 +08:00
}
2018-09-07 15:53:16 +08:00
/// <summary>
///
/// </summary>
public enum UserStates
{
/// <summary>
///
/// </summary>
ChangePassword ,
/// <summary>
///
/// </summary>
ChangeTheme ,
/// <summary>
///
/// </summary>
ChangeDisplayName ,
/// <summary>
///
/// </summary>
ApproveUser ,
/// <summary>
///
/// </summary>
RejectUser
}
2016-10-22 16:58:31 +08:00
}