2024-11-28 13:36:05 +08:00
|
|
|
using Infrastructure;
|
|
|
|
|
using Infrastructure.Attribute;
|
2024-12-03 09:25:16 +08:00
|
|
|
using DOAN.Infrastructure.Helper;
|
|
|
|
|
using DOAN.Model;
|
|
|
|
|
using DOAN.Model.Dto;
|
|
|
|
|
using DOAN.Model.Models;
|
|
|
|
|
using DOAN.Repository;
|
|
|
|
|
using DOAN.ServiceCore.Model;
|
2024-11-28 13:36:05 +08:00
|
|
|
|
2024-12-03 09:25:16 +08:00
|
|
|
namespace DOAN.ServiceCore.Services
|
2024-11-28 13:36:05 +08:00
|
|
|
{
|
|
|
|
|
/// <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;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|