Newer
Older
newfiber-termite / newfiber-system / newfiber-system-sms / src / main / java / com / newfiber / system / template / SmsTemplate.java
package com.newfiber.system.template;


import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.newfiber.system.domain.model.SmsCode;
import com.newfiber.system.domain.model.SmsData;
import com.newfiber.system.domain.model.SmsInfo;
import com.newfiber.system.domain.model.SmsResponse;
import java.util.Collection;
import java.util.Collections;
import org.springframework.util.StringUtils;

/**
 * 短信通用封装
 *
 * @author Chill
 */
public interface SmsTemplate {

	/**
	 * 缓存键值
	 *
	 * @param phone 手机号
	 * @param id    键值
	 * @return 缓存键值返回
	 */
	default String cacheKey(String phone, String id) {
		return phone + StringPool.COLON + id;
	}

	/**
	 * 发送短信
	 *
	 * @param smsInfo 短信信息
	 * @return 发送返回
	 */
	default boolean send(SmsInfo smsInfo) {
		return sendMulti(smsInfo.getSmsData(), smsInfo.getPhones());
	}

	/**
	 * 发送短信
	 *
	 * @param smsData 短信内容
	 * @param phone   手机号
	 * @return 发送返回
	 */
	default boolean sendSingle(SmsData smsData, String phone) {
		if (StringUtils.isEmpty(phone)) {
			return Boolean.FALSE;
		}
		return sendMulti(smsData, Collections.singletonList(phone));
	}

	/**
	 * 发送短信
	 *
	 * @param smsData 短信内容
	 * @param phones  手机号列表
	 * @return 发送返回
	 */
	default boolean sendMulti(SmsData smsData, Collection<String> phones) {
		SmsResponse response = sendMessage(smsData, phones);
		return response.isSuccess();
	}

	/**
	 * 发送短信
	 *
	 * @param smsData 短信内容
	 * @param phones  手机号列表
	 * @return 发送返回
	 */
	SmsResponse sendMessage(SmsData smsData, Collection<String> phones);

	/**
	 * 发送验证码
	 *
	 * @param smsData 短信内容
	 * @param phone   手机号
	 * @return 发送返回
	 */
	SmsCode sendValidate(SmsData smsData, String phone);

	/**
	 * 校验验证码
	 *
	 * @param smsCode 验证码内容
	 * @return 是否校验成功
	 */
	boolean validateMessage(SmsCode smsCode);

}