短信 code review 2020-02-25

This commit is contained in:
YunaiV 2021-02-25 01:24:06 +08:00
parent 2a4d9f43eb
commit cd2a01819b
10 changed files with 13 additions and 24 deletions

View File

@ -22,7 +22,7 @@ public abstract class AbstractSmsClient implements SmsClient {
protected final SmsChannelProperty channelVO;
/**
* 构造阿里云短信发送处理
* 构造阿里云短信发送处理 TODO FROM 芋艿 to zzf貌似注释不对
*
* @param property 阿里云短信配置
*/
@ -30,13 +30,12 @@ public abstract class AbstractSmsClient implements SmsClient {
this.channelVO = property;
}
public SmsChannelProperty getProperty() {
return channelVO;
}
@Override
public SmsResult send(String templateApiId, SmsBody smsBody, Collection<String> targets) {
public final SmsResult send(String templateApiId, SmsBody smsBody, Collection<String> targets) {
SmsResult result;
try {
beforeSend(templateApiId, smsBody, targets);
@ -50,13 +49,13 @@ public abstract class AbstractSmsClient implements SmsClient {
return result;
}
/**
* 发送消息
*
* @param templateApiId 短信模板唯一标识
* @param smsBody 消息内容
* @param targets 发送对象列表
* @throws Exception 调用发送失败抛出异常
* @return 短信发送结果
*/
public abstract SmsResult doSend(String templateApiId, SmsBody smsBody, Collection<String> targets) throws Exception;
@ -67,7 +66,7 @@ public abstract class AbstractSmsClient implements SmsClient {
protected void afterSend(String templateApiId, SmsBody smsBody, Collection<String> targets, SmsResult result) throws Exception {
}
// TODO FROM 芋艿 to zzf可以考虑抽到 SmsResult
SmsResult failResult(String message) {
SmsResult resultBody = new SmsResult();
resultBody.setSuccess(false);

View File

@ -58,16 +58,14 @@ public class AliyunSmsClient extends AbstractSmsClient {
acsClient = new DefaultAcsClient(profile);
}
@Override
public SmsResult doSend(String templateApiId, SmsBody smsBody, Collection<String> targets) throws Exception {
SendSmsRequest request = new SendSmsRequest();
request.setSysMethod(MethodType.POST);
request.setPhoneNumbers(StringUtils.join(targets, ","));
request.setPhoneNumbers(StringUtils.join(targets, ",")); // TODO FROM 芋艿 to zzf统一使用 Hutool 工具类嘿
request.setSignName(channelVO.getApiSignatureId());
request.setTemplateCode(templateApiId);
request.setTemplateParam(smsBody.getParamsStr());
// TODO FROM 芋艿 TO zzftry catch 咱是不是可以交给 abstract 来做这样异常处理重试限流等等都可以酱紫 DONE
SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
boolean result = OK.equals(sendSmsResponse.getCode());
@ -78,7 +76,7 @@ public class AliyunSmsClient extends AbstractSmsClient {
resultBody.setSuccess(result);
QuerySendDetailsRequest querySendDetailsRequest = new QuerySendDetailsRequest();
querySendDetailsRequest.setBizId(sendSmsResponse.getBizId());
// TODO FROM 芋艿 to zzf发送完之后基于短信平台回调去更新回执状态短信发送是否成功和最终用户收到是两个维度这块有困惑可以微信我给个截图哈
QuerySendDetailsResponse acsResponse = acsClient.getAcsResponse(querySendDetailsRequest);
List<SmsResultDetail> resultDetailList = new ArrayList<>(Integer.parseInt(acsResponse.getTotalCount()));
acsResponse.getSmsSendDetailDTOs().forEach(s -> {

View File

@ -42,7 +42,6 @@ public class SmsClientFactory {
* @return 客户端id(默认channelId)
*/
public Long createClient(SmsChannelProperty propertyVO) {
// TODO FROM 芋艿 TO zzf参数的校验可以考虑统一使用 validation DONE
AbstractSmsClient sender = createClient(SmsChannelEnum.getByCode(propertyVO.getCode()), propertyVO);
smsSenderMap.put(propertyVO.getId(), sender);
return propertyVO.getId();
@ -77,7 +76,7 @@ public class SmsClientFactory {
* 添加或修改短信模板信息缓存
*/
public void addOrUpdateTemplateCache(Collection<SmsTemplateProperty> templateProperties) {
templateProperties.forEach(s -> templatePropertyMap.put(s.getCode(), s));
templateProperties.forEach(s -> addOrUpdateTemplateCache(templateProperties));
}
@ -102,4 +101,5 @@ public class SmsClientFactory {
}
return smsTemplateProperty.getApiTemplateId();
}
}

View File

@ -14,7 +14,6 @@ public class SmsResult implements Serializable {
/**
* 是否成功(发送短信的请求是否成功)
*/
// TODO FROM 芋艿 to zzf未来要加一个 code将不同平台的短信失败的情况做一次统一的收敛 DONE
private Boolean success;
/**
@ -30,7 +29,6 @@ public class SmsResult implements Serializable {
/**
* 返回值
*/
// TODO FROM 芋艿 to zzf是不是统一各个平台的返回结果这样对调用方来说统一因为作为统一的短信客户端最好让上层不太需要知道太具体黑河诶 DONE
private List<SmsResultDetail> result;
}

View File

@ -4,7 +4,7 @@ import lombok.AllArgsConstructor;
import lombok.Getter;
/**
* 短信渠道枚举 TODO FROM 芋艿 TO zzf属于短信的枚举类可以放到 framework/sms DONE
* 短信渠道枚举
*
* @author zzf
* @date 2021/1/25 10:56
@ -16,7 +16,7 @@ public enum SmsChannelEnum {
ALI("ALI", "阿里"),
HUA_WEI("HUA_WEI", "华为"),
QI_NIU("QI_NIU", "七牛"),
TENCENT("TENCENT", "腾讯"); // TODO FROM 芋艿 to zzfTEN 有后鼻音哈要被马爸爸打了 DONE
TENCENT("TENCENT", "腾讯");
private final String code;
@ -30,4 +30,5 @@ public enum SmsChannelEnum {
}
return null;
}
}

View File

@ -7,8 +7,6 @@ import javax.validation.constraints.NotEmpty;
/**
* 渠道模板VO类
* TODO FROM 芋艿 TO zzf模板是不是不要提供到 client 里面而是交给 factory 统一维护就好不然模板修改时候刷新 client 会比较麻烦 DONE
*
*
* @author zzf
* @date 2021/1/25 17:03

View File

@ -37,12 +37,10 @@ public class SmsChannelController {
return success(service.getSmsChannelEnums());
}
@ApiOperation("添加消息渠道")
@PostMapping("/create")
public CommonResult<Long> add(@Validated @RequestBody SmsChannelCreateReqVO reqVO) {
return success(service.createSmsChannel(reqVO));
}
}

View File

@ -24,7 +24,7 @@ public class SmsSendConsumer extends AbstractChannelMessageListener<SmsSendMessa
@Override
public void onMessage(SmsSendMessage message) {
log.info("[onMessage][收到 发送短信 消息]");
log.info("[onMessage][收到 发送短信 消息]"); // TODO FROM 芋艿 to zzflog 如果要打这里要内容打上其他 Consumer 没打的原因是没内容
SmsResult send = sysSmsService.send(message.getSmsBody(), message.getTargetPhones());
}

View File

@ -18,9 +18,6 @@ import java.util.List;
*/
public interface SysSmsChannelService {
// TODO FROM 芋艿 to ZZFSmsChannelService=SysSmsChannelService增加 Sys 前缀算在系统模块里
// TODO FROM 芋艿 to ZZF方法名保持不去掉 Sms 前缀虽然长点嘿嘿
/**
* 初始化短信渠道
*/

View File

@ -42,6 +42,7 @@ public class SysSmsChannelServiceImpl implements SysSmsChannelService {
@Autowired
private SmsClientFactory clientFactory;
// TODO FROM 芋艿 to zzf方法要放在成员变量下面
/**
* 初始化短信客户端
*/
@ -65,7 +66,6 @@ public class SysSmsChannelServiceImpl implements SysSmsChannelService {
});
}
// TODO FROM 芋艿 to ZZFchannelMapper 保持命名统一 DONE
@Resource
private SysSmsChannelMapper channelMapper;