263 lines
7.8 KiB
C#
263 lines
7.8 KiB
C#
using Learun.Util;
|
||
using Learun.Util.SqlSugar;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Text;
|
||
|
||
namespace Learun.Application.IM
|
||
{
|
||
/// <summary>
|
||
/// 版 本 PIT-ADMS V7.0.3 敏捷开发框架
|
||
/// Copyright (c) 2013-2018 Hexagon PPM
|
||
/// 创建人:研发部
|
||
/// 日 期:2018.05.30
|
||
/// 描 述:即时通讯用户注册
|
||
/// </summary>
|
||
public class IMSysUserService
|
||
{
|
||
#region 仓储
|
||
Repository<IMSysUserEntity> _IMSysUserRepository => new Repository<IMSysUserEntity>();
|
||
#endregion
|
||
#region 构造函数和属性
|
||
|
||
private string fieldSql;
|
||
public IMSysUserService()
|
||
{
|
||
fieldSql = @"
|
||
t.F_Id,
|
||
t.F_Name,
|
||
t.F_Code,
|
||
t.F_Icon,
|
||
t.F_CreateDate,
|
||
t.F_CreateUserId,
|
||
t.F_CreateUserName,
|
||
t.F_Description,
|
||
t.F_DeleteMark
|
||
";
|
||
}
|
||
#endregion
|
||
|
||
#region 获取数据
|
||
|
||
/// <summary>
|
||
/// 获取列表数据
|
||
/// </summary>
|
||
/// <param name="keyWord">查询关键字</param>
|
||
/// <returns></returns>
|
||
public IEnumerable<IMSysUserEntity> GetList(string keyWord)
|
||
{
|
||
try
|
||
{
|
||
var strSql = new StringBuilder();
|
||
strSql.Append("SELECT ");
|
||
strSql.Append(fieldSql);
|
||
strSql.Append(" FROM LR_IM_SysUser t where t.F_DeleteMark = 0 ");
|
||
|
||
if (!string.IsNullOrEmpty(keyWord)) {
|
||
keyWord = "%" + keyWord + "%";
|
||
strSql.Append(" AND t.F_Name Like @keyWord ");
|
||
}
|
||
|
||
//return this.BaseRepository().FindList<IMSysUserEntity>(strSql.ToString(), new { keyWord = keyWord });
|
||
return SqlSugarHelper.Db.SqlQueryable<IMSysUserEntity>(strSql.ToString()).AddParameters(new { keyWord = keyWord }).ToList();
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取列表分页数据
|
||
/// <param name="pagination">分页参数</param>
|
||
/// <param name="keyWord">查询关键字</param>
|
||
/// <summary>
|
||
/// <returns></returns>
|
||
public IEnumerable<IMSysUserEntity> GetPageList(Pagination pagination, string keyWord)
|
||
{
|
||
try
|
||
{
|
||
var strSql = new StringBuilder();
|
||
strSql.Append("SELECT ");
|
||
strSql.Append(fieldSql);
|
||
strSql.Append(" FROM LR_IM_SysUser t where t.F_DeleteMark = 0 ");
|
||
|
||
if (!string.IsNullOrEmpty(keyWord))
|
||
{
|
||
keyWord = "%" + keyWord + "%";
|
||
strSql.Append(" AND t.F_Name Like @keyWord ");
|
||
}
|
||
|
||
//return this.BaseRepository().FindList<IMSysUserEntity>(strSql.ToString(), new { keyWord = keyWord }, pagination);
|
||
return SqlSugarHelper.Db.SqlQueryable<IMSysUserEntity>(strSql.ToString()).AddParameters(new { keyWord = keyWord }).ToPageList(pagination.page, pagination.rows);
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取实体数据
|
||
/// <param name="keyValue">主键</param>
|
||
/// <summary>
|
||
/// <returns></returns>
|
||
public IMSysUserEntity GetEntity(string keyValue)
|
||
{
|
||
try
|
||
{
|
||
return _IMSysUserRepository.GetById(keyValue);
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
/// <summary>
|
||
/// 获取实体数据byCode
|
||
/// </summary>
|
||
/// <param name="code"></param>
|
||
/// <returns></returns>
|
||
public IMSysUserEntity GetEntityByCode(string code)
|
||
{
|
||
try
|
||
{
|
||
return _IMSysUserRepository.GetFirst(t=>t.F_Code.Equals(code));
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
|
||
#endregion
|
||
|
||
#region 提交数据
|
||
|
||
/// <summary>
|
||
/// 删除实体数据(虚拟)
|
||
/// <param name="keyValue">主键</param>
|
||
/// <summary>
|
||
/// <returns></returns>
|
||
public void DeleteEntity(string keyValue)
|
||
{
|
||
try
|
||
{
|
||
IMSysUserEntity entity = new IMSysUserEntity();
|
||
entity.F_Id = keyValue;
|
||
entity.F_DeleteMark = 1;
|
||
_IMSysUserRepository.Update(entity);
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 保存实体数据(新增、修改)
|
||
/// <param name="keyValue">主键</param>
|
||
/// <summary>
|
||
/// <returns></returns>
|
||
public void SaveEntity(string keyValue, IMSysUserEntity entity)
|
||
{
|
||
try
|
||
{
|
||
if (!string.IsNullOrEmpty(keyValue))
|
||
{
|
||
entity.Modify(keyValue);
|
||
_IMSysUserRepository.Update(entity);
|
||
}
|
||
else
|
||
{
|
||
entity.Create();
|
||
_IMSysUserRepository.Insert(entity);
|
||
}
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
|
||
#endregion
|
||
|
||
#region 验证数据
|
||
/// <summary>
|
||
/// 规则编号不能重复
|
||
/// </summary>
|
||
/// <param name="code">编号</param>
|
||
/// <param name="keyValue">主键</param>
|
||
/// <returns></returns>
|
||
public bool ExistEnCode(string code, string keyValue)
|
||
{
|
||
try
|
||
{
|
||
var strSql = new StringBuilder();
|
||
strSql.Append(" SELECT t.F_Id FROM LR_IM_SysUser t WHERE t.F_DeleteMark = 0 AND t.F_Code = @code ");
|
||
if (!string.IsNullOrEmpty(keyValue))
|
||
{
|
||
strSql.Append(" AND t.F_Id != @keyValue ");
|
||
}
|
||
IMSysUserEntity entity = SqlSugarHelper.Db.Ado.SqlQuerySingle<IMSysUserEntity>(strSql.ToString(), new { code = code, keyValue = keyValue });
|
||
|
||
return entity == null ? true : false;
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
if (ex is ExceptionEx)
|
||
{
|
||
throw;
|
||
}
|
||
else
|
||
{
|
||
throw ExceptionEx.ThrowServiceException(ex);
|
||
}
|
||
}
|
||
}
|
||
#endregion
|
||
}
|
||
}
|