first commit
This commit is contained in:
88
DOAN.ServiceCore/Services/SmsCodeLogService.cs
Normal file
88
DOAN.ServiceCore/Services/SmsCodeLogService.cs
Normal file
@@ -0,0 +1,88 @@
|
||||
using Infrastructure;
|
||||
using Infrastructure.Attribute;
|
||||
using DOAN.Infrastructure.Helper;
|
||||
using DOAN.Model;
|
||||
using DOAN.Model.Dto;
|
||||
using DOAN.Model.Models;
|
||||
using DOAN.Repository;
|
||||
using DOAN.ServiceCore.Model;
|
||||
|
||||
namespace DOAN.ServiceCore.Services
|
||||
{
|
||||
/// <summary>
|
||||
/// 短信验证码记录Service业务层处理
|
||||
/// </summary>
|
||||
[AppService(ServiceType = typeof(ISmsCodeLogService), ServiceLifetime = LifeTime.Transient)]
|
||||
public class SmsCodeLogService : BaseService<SmsCodeLog>, ISmsCodeLogService
|
||||
{
|
||||
/// <summary>
|
||||
/// 查询短信验证码记录列表
|
||||
/// </summary>
|
||||
/// <param name="parm"></param>
|
||||
/// <returns></returns>
|
||||
public PagedInfo<SmsCodeLogDto> GetList(SmscodeLogQueryDto parm)
|
||||
{
|
||||
var predicate = Expressionable.Create<SmsCodeLog>();
|
||||
|
||||
predicate = predicate.AndIF(parm.Userid != null, it => it.Userid == parm.Userid);
|
||||
predicate = predicate.AndIF(parm.PhoneNum != null, it => it.PhoneNum == parm.PhoneNum);
|
||||
predicate = predicate.AndIF(parm.BeginAddTime == null, it => it.AddTime >= DateTime.Now.ToShortDateString().ParseToDateTime());
|
||||
predicate = predicate.AndIF(parm.BeginAddTime != null, it => it.AddTime >= parm.BeginAddTime);
|
||||
predicate = predicate.AndIF(parm.EndAddTime != null, it => it.AddTime <= parm.EndAddTime);
|
||||
predicate = predicate.AndIF(parm.SendType != null, it => it.SendType == parm.SendType);
|
||||
var response = Queryable()
|
||||
//.OrderBy("Id desc")
|
||||
.Where(predicate.ToExpression())
|
||||
.ToPage<SmsCodeLog, SmsCodeLogDto>(parm);
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 获取详情
|
||||
/// </summary>
|
||||
/// <param name="Id"></param>
|
||||
/// <returns></returns>
|
||||
public SmsCodeLog GetInfo(long Id)
|
||||
{
|
||||
var response = Queryable()
|
||||
.Where(x => x.Id == Id)
|
||||
.First();
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 添加短信验证码记录
|
||||
/// </summary>
|
||||
/// <param name="model"></param>
|
||||
/// <returns></returns>
|
||||
public SmsCodeLog AddSmscodeLog(SmsCodeLog model)
|
||||
{
|
||||
model.AddTime = Context.GetDate();
|
||||
|
||||
var smsCode = RandomHelper.GenerateNum(6);
|
||||
var smsContent = $"验证码{smsCode},有效期10分钟。";
|
||||
|
||||
var oneMinus = Queryable().Any(f => f.PhoneNum == model.PhoneNum && SqlFunc.DateDiff(DateType.Minute, f.AddTime, model.AddTime) <= 1);
|
||||
if (oneMinus)
|
||||
{
|
||||
throw new CustomException("请稍后再试");
|
||||
}
|
||||
var oneMinusIP = Queryable().Any(f => f.UserIP == model.UserIP && SqlFunc.DateDiff(DateType.Minute, f.AddTime, model.AddTime) <= 1);
|
||||
if (oneMinusIP)
|
||||
{
|
||||
throw new CustomException("请稍后再试");
|
||||
}
|
||||
model.SmsCode = smsCode;
|
||||
model.SmsContent = smsContent;
|
||||
model.Id = Context.Insertable(model).ExecuteReturnSnowflakeId();
|
||||
//TODO 发送验证码
|
||||
|
||||
CacheService.SetPhoneCode(model.PhoneNum.ToString(), smsCode);
|
||||
|
||||
return model;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user