mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-10-31 10:18:42 +08:00 
			
		
		
		
	邮件模块修改注释、注解、修改泛型方法
This commit is contained in:
		| @@ -52,7 +52,7 @@ public class MailAccountController { | ||||
|     @ApiOperation("删除邮箱账号") | ||||
|     @ApiImplicitParam(name = "id", value = "编号", required = true, dataTypeClass = Long.class) | ||||
|     @PreAuthorize("@ss.hasPermission('system:mail-account:delete')") | ||||
|     public CommonResult<Boolean> deleteMailAccount(@Valid @RequestParam Long id) { // TODO @wangjingyi:不需要 @Valid 这里。了解下 Validator | ||||
|     public CommonResult<Boolean> deleteMailAccount(@RequestParam Long id) { | ||||
|         mailAccountService.delete(id); | ||||
|         return success(true); | ||||
|     } | ||||
| @@ -83,11 +83,4 @@ public class MailAccountController { | ||||
|         return success(MailAccountConvert.INSTANCE.convertList02(list)); | ||||
|     } | ||||
|  | ||||
|     @PostMapping("/send") | ||||
|     @ApiOperation("发送邮件") | ||||
|     @PreAuthorize("@ss.hasPermission('system:mail-account:send')") | ||||
|     public CommonResult<Boolean> sendMail(MailReqVO mailReqVO){ // TODO @wangjingyi:应该是测试短信模板,做到 MailTemplateController 里。参考下短信那的做法哈 | ||||
|         mailAccountService.sendMail(mailReqVO); | ||||
|         return success(true); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -28,6 +28,7 @@ import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||
| @RestController | ||||
| @RequestMapping("/system/mail-log") | ||||
| public class MailLogController { | ||||
|  | ||||
|     @Autowired | ||||
|     private MailLogService mailLogService; | ||||
|  | ||||
|   | ||||
| @@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.system.controller.admin.mail; | ||||
|  | ||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.send.MailReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplateBaseVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplateCreateReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplatePageReqVO; | ||||
| @@ -27,8 +28,9 @@ import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||
| @RestController | ||||
| @RequestMapping("/system/mail-template") | ||||
| public class MailTemplateController { | ||||
|  | ||||
|     @Autowired | ||||
|     MailTemplateService mailTempleService; // TODO @wangjingyi:private;和上面要空一行; | ||||
|     MailTemplateService mailTempleService; | ||||
|  | ||||
|     @PostMapping("/create") | ||||
|     @ApiOperation("创建邮箱模版") | ||||
| @@ -64,7 +66,7 @@ public class MailTemplateController { | ||||
|  | ||||
|     @GetMapping("/page") | ||||
|     @ApiOperation("获得邮箱模版分页") | ||||
|     @PreAuthorize("@ss.hasPermission('system:mail-account:query')") | ||||
|     @PreAuthorize("@ss.hasPermission('system:mail-template:query')") | ||||
|     public CommonResult<PageResult<MailTemplateBaseVO>> getMailTemplatePage(@Valid MailTemplatePageReqVO pageReqVO) { | ||||
|         PageResult<MailTemplateDO> pageResult = mailTempleService.getMailTemplatePage(pageReqVO); | ||||
|         return success(MailTemplateConvert.INSTANCE.convertPage(pageResult)); | ||||
| @@ -78,4 +80,12 @@ public class MailTemplateController { | ||||
|         list.sort(Comparator.comparing(MailTemplateDO::getId)); | ||||
|         return success(MailTemplateConvert.INSTANCE.convertList02(list)); | ||||
|     } | ||||
|  | ||||
|     @PostMapping("/send") | ||||
|     @ApiOperation("发送邮件") | ||||
|     @PreAuthorize("@ss.hasPermission('system:mail-template:send')") | ||||
|     public CommonResult<Boolean> sendMail(@Valid @RequestBody MailReqVO mailReqVO){ | ||||
|         mailTempleService.sendMail(mailReqVO); | ||||
|         return success(true); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -3,6 +3,9 @@ package cn.iocoder.yudao.module.system.controller.admin.mail.vo.account; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
|  | ||||
| import javax.validation.constraints.NotNull; | ||||
|  | ||||
| @ApiModel("管理后台 - 邮箱账号基类 Base VO") | ||||
| @Data | ||||
| public class MailAccountBaseVO { | ||||
| @@ -11,6 +14,7 @@ public class MailAccountBaseVO { | ||||
|     private String from; | ||||
|  | ||||
|     @ApiModelProperty(value = "用户名" , required = true , example = "yudao") | ||||
|     @NotNull(message = "用户名必填") | ||||
|     private String username; | ||||
|  | ||||
|     @ApiModelProperty(value = "密码" , required = true , example = "123456") | ||||
|   | ||||
| @@ -9,7 +9,7 @@ import java.util.List; | ||||
|  | ||||
| @ApiModel("管理后台 - 邮件发送 Req VO") | ||||
| @Data | ||||
| public class MailReqVO { // TODO @wangjingyi:1)参数校验;2)ReqVO | ||||
| public class MailReqVO { | ||||
|  | ||||
|     @ApiModelProperty(value = "邮箱" , required = true , example = "yudaoyuanma@123.com") | ||||
|     @NotNull(message = "邮箱账号不能为空") | ||||
|   | ||||
| @@ -4,6 +4,8 @@ import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
|  | ||||
| import javax.validation.constraints.NotNull; | ||||
|  | ||||
| @ApiModel("管理后台 - 邮箱模版基类 Base VO") | ||||
| @Data | ||||
| public class MailTemplateBaseVO { | ||||
| @@ -14,6 +16,7 @@ public class MailTemplateBaseVO { | ||||
|     private String name; | ||||
|  | ||||
|     @ApiModelProperty("标识") | ||||
|     @NotNull(message = "邮箱模版code不能为空") | ||||
|     private String code; | ||||
|  | ||||
|     @ApiModelProperty("发件人") | ||||
|   | ||||
| @@ -11,34 +11,45 @@ import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
|  | ||||
| @TableName(value = "system_mail_account", autoResultMap = true) | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @ApiModel(value="MailAccount对象", description="邮箱账号") // TODO @wangjingyi:不需要 swagger 注解 | ||||
| @TableName(value = "system_mail_account", autoResultMap = true) // TODO @wangjingyi:这个放在最上面,关键字段 | ||||
| public class MailAccountDO extends BaseDO implements Serializable { | ||||
|  | ||||
|     // TODO @wangjingyi:每个字段的注释;字段名,如果一直,不用 @TableField | ||||
|  | ||||
|     @TableId | ||||
|     /** | ||||
|      * 主键 | ||||
|      */ | ||||
|     private Long id; | ||||
|  | ||||
|     @TableField("from") | ||||
|     /** | ||||
|      * 邮箱 | ||||
|      */ | ||||
|     private String from; | ||||
|  | ||||
|     @TableField("username") | ||||
|     /** | ||||
|      * 用户名 | ||||
|      */ | ||||
|     private String username; | ||||
|  | ||||
|     @TableField("password") | ||||
|     /** | ||||
|      * 密码 | ||||
|      */ | ||||
|     private String password; | ||||
|  | ||||
|     @TableField("host") | ||||
|     /** | ||||
|      * 主机 | ||||
|      */ | ||||
|     private String host; | ||||
|  | ||||
|     @TableField("port") | ||||
|     /** | ||||
|      * 端口 | ||||
|      */ | ||||
|     private Integer port; | ||||
|  | ||||
|     @TableField("sslEnable") | ||||
|     /** | ||||
|      * 是否开启ssl | ||||
|      */ | ||||
|     private Boolean sslEnable; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -5,6 +5,8 @@ import java.sql.Timestamp; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import java.io.Serializable; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| @@ -18,44 +20,65 @@ import lombok.experimental.Accessors; | ||||
|  * @author wangjingyi | ||||
|  * @since 2022-03-21 | ||||
|  */ | ||||
| @TableName(value = "system_mail_log", autoResultMap = true) | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @ApiModel(value="SystemMailLog对象", description="") | ||||
| public class MailLogDO extends BaseDO implements Serializable { | ||||
|  | ||||
|     private static final long serialVersionUID = 1L; | ||||
|     @TableId | ||||
|     /** | ||||
|      * 主键 | ||||
|      */ | ||||
|     private Long id; | ||||
|  | ||||
|     @TableField("account_code") | ||||
|     /** | ||||
|      * 邮箱账号编号 | ||||
|      */ | ||||
|     private String accountCode; | ||||
|  | ||||
|     @TableField("from") | ||||
|     /** | ||||
|      * 邮箱账号 | ||||
|      */ | ||||
|     private String from; | ||||
|  | ||||
|     @TableField("template_id") | ||||
|     /** | ||||
|      * 模版主键 | ||||
|      */ | ||||
|     private String templateId; | ||||
|  | ||||
|     @TableField("template_code") | ||||
|     /** | ||||
|      * 模版编号 | ||||
|      */ | ||||
|     private String templateCode; | ||||
|  | ||||
|     @TableField("title") | ||||
|     /** | ||||
|      * 标题 | ||||
|      */ | ||||
|     private String title; | ||||
|  | ||||
|     @TableField("content") | ||||
|     /** | ||||
|      * 内容 | ||||
|      */ | ||||
|     private String content; | ||||
|  | ||||
|     @TableField("to") | ||||
|     /** | ||||
|      * 收件人 | ||||
|      */ | ||||
|     private String to; | ||||
|  | ||||
|     @TableField("sendTime") | ||||
|     /** | ||||
|      * 发送时间 | ||||
|      */ | ||||
|     private Timestamp sendTime; | ||||
|  | ||||
|     @TableField("sendStatus") | ||||
|     /** | ||||
|      * 发送状态 | ||||
|      */ | ||||
|     private Boolean sendStatus; | ||||
|  | ||||
|     @TableField("sendResult") | ||||
|     /** | ||||
|      * 发送结果 | ||||
|      */ | ||||
|     private String sendResult; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -5,6 +5,8 @@ import com.baomidou.mybatisplus.annotation.IdType; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import java.io.Serializable; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| @@ -19,35 +21,50 @@ import lombok.experimental.Accessors; | ||||
|  * @author wangjingyi | ||||
|  * @since 2022-03-21 | ||||
|  */ | ||||
| @TableName(value = "system_mail_template", autoResultMap = true) | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| @Accessors(chain = true) | ||||
| @ApiModel(value="SystemMailTemplate对象", description="") | ||||
| public class MailTemplateDO extends BaseDO implements Serializable { | ||||
|  | ||||
|     private static final long serialVersionUID = 1L; | ||||
|     @TableId | ||||
|     /** | ||||
|      * 主键 | ||||
|      */ | ||||
|     private Long id; | ||||
|  | ||||
|     @TableField("name") | ||||
|     /** | ||||
|      * 模版名称 | ||||
|      */ | ||||
|     private String name; | ||||
|  | ||||
|     @TableField("code") | ||||
|     /** | ||||
|      * 模版编号 | ||||
|      */ | ||||
|     private String code; | ||||
|  | ||||
|     @TableField("username") | ||||
|     /** | ||||
|      * 用户名 | ||||
|      */ | ||||
|     private String username; | ||||
|  | ||||
|     @TableField("title") | ||||
|     /** | ||||
|      * 标题 | ||||
|      */ | ||||
|     private String title; | ||||
|  | ||||
|     @TableField("content") | ||||
|     /** | ||||
|      * 内容 | ||||
|      */ | ||||
|     private String content; | ||||
|  | ||||
|     @TableField("status") | ||||
|     /** | ||||
|      * 状态 | ||||
|      */ | ||||
|     private String status; | ||||
|  | ||||
|     @TableField("remark") | ||||
|     /** | ||||
|      * 备注 | ||||
|      */ | ||||
|     private String remark; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -22,12 +22,9 @@ public interface MailAccountMapper extends BaseMapperX<MailAccountDO> { | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     // TODO @wangjingyi:不要提供这样的泛的方法,而是明确的查询方法 | ||||
|     default MailAccountDO selectByParams(Map params){ | ||||
|     default MailAccountDO selectByUserName(String userName){ | ||||
|         QueryWrapperX queryWrapperX = new QueryWrapperX<MailAccountDO>(); | ||||
|         params.forEach((k , v)->{ | ||||
|             queryWrapperX.eqIfPresent((String) k, v); | ||||
|         }); | ||||
|         return this.selecOne(queryWrapperX); | ||||
|         queryWrapperX.eqIfPresent("username", userName); | ||||
|         return this.selectOne(queryWrapperX); | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -22,4 +22,7 @@ public interface MailTemplateMapper extends BaseMapperX<MailTemplateDO> { | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     default MailTemplateDO selectOneByCode(String code){ | ||||
|         return selectOne("code" , code); | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -7,6 +7,7 @@ import cn.iocoder.yudao.module.system.controller.admin.mail.vo.account.MailAccou | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.send.MailReqVO; | ||||
| import cn.iocoder.yudao.module.system.dal.dataobject.mail.MailAccountDO; | ||||
|  | ||||
| import javax.validation.Valid; | ||||
| import java.util.List; | ||||
|  | ||||
|  | ||||
| @@ -22,46 +23,47 @@ public interface MailAccountService { | ||||
|  | ||||
|     /** | ||||
|      * 创建邮箱账号 // TODO @wangjingyi:方法描述,和参数要空行 | ||||
|      * @param createReqVO | ||||
|      * @return | ||||
|      * | ||||
|      * @param createReqVO 邮箱账号信息 | ||||
|      * @return 编号 | ||||
|      */ | ||||
|     Long create(MailAccountCreateReqVO createReqVO); | ||||
|     Long create(@Valid MailAccountCreateReqVO createReqVO); | ||||
|  | ||||
|     /** | ||||
|      * 修改邮箱账号 | ||||
|      * @param updateReqVO | ||||
|      * | ||||
|      * @param updateReqVO 邮箱账号信息 | ||||
|      */ | ||||
|     void update(MailAccountUpdateReqVO updateReqVO); | ||||
|     void update(@Valid MailAccountUpdateReqVO updateReqVO); | ||||
|  | ||||
|     /** | ||||
|      * 删除邮箱账号 | ||||
|      * @param id | ||||
|      * | ||||
|      * @param id 编号 | ||||
|      */ | ||||
|     void delete(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 获取邮箱账号信息 | ||||
|      * @param id | ||||
|      * @return | ||||
|      * | ||||
|      * @param id 编号 | ||||
|      * @return 邮箱账号信息 | ||||
|      */ | ||||
|     MailAccountDO getMailAccount(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 获取邮箱账号分页信息 | ||||
|      * @param pageReqVO | ||||
|      * @return | ||||
|      * | ||||
|      * @param pageReqVO 邮箱账号分页参数 | ||||
|      * @return 邮箱账号分页信息 | ||||
|      */ | ||||
|     PageResult<MailAccountDO> getMailAccountPage(MailAccountPageReqVO pageReqVO); | ||||
|  | ||||
|     /** | ||||
|      * 获取邮箱数组信息 | ||||
|      * @return | ||||
|      * | ||||
|      * @return 邮箱账号信息数组 | ||||
|      */ | ||||
|     List<MailAccountDO> getMailAccountList(); | ||||
|  | ||||
|     /** | ||||
|      * 发送邮件 | ||||
|      * @param mailReqVO | ||||
|      */ | ||||
|     void sendMail(MailReqVO mailReqVO); | ||||
| } | ||||
|   | ||||
| @@ -1,11 +1,13 @@ | ||||
| package cn.iocoder.yudao.module.system.service.mail; | ||||
|  | ||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.send.MailReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplateCreateReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplatePageReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplateUpdateReqVO; | ||||
| import cn.iocoder.yudao.module.system.dal.dataobject.mail.MailTemplateDO; | ||||
|  | ||||
| import javax.validation.Valid; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
| @@ -16,44 +18,52 @@ import java.util.List; | ||||
|  */ | ||||
| public interface MailTemplateService { | ||||
|  | ||||
|     // TODO @wangjingyi:注释,完整;参数校验还是要做的; | ||||
|  | ||||
|     /** | ||||
|      * 邮箱模版创建 | ||||
|      * @param createReqVO | ||||
|      * @return | ||||
|      * @param createReqVO 邮箱信息 | ||||
|      * @return 编号 | ||||
|      */ | ||||
|     Long create(MailTemplateCreateReqVO createReqVO); | ||||
|     Long create(@Valid MailTemplateCreateReqVO createReqVO); | ||||
|  | ||||
|     /** | ||||
|      * 邮箱模版修改 | ||||
|      * @param updateReqVO | ||||
|      * @param updateReqVO 邮箱信息 | ||||
|      */ | ||||
|     void update(MailTemplateUpdateReqVO updateReqVO); | ||||
|     void update(@Valid MailTemplateUpdateReqVO updateReqVO); | ||||
|  | ||||
|     /** | ||||
|      * 邮箱模版删除 | ||||
|      * @param id | ||||
|      * @param id 编号 | ||||
|      */ | ||||
|     void delete(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 获取邮箱模版 | ||||
|      * @param id | ||||
|      * @return | ||||
|      * | ||||
|      * @param id 编号 | ||||
|      * @return 邮件模版 | ||||
|      */ | ||||
|     MailTemplateDO getMailTemplate(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 获取邮箱模版分页 | ||||
|      * @param pageReqVO | ||||
|      * @return | ||||
|      * | ||||
|      * @param pageReqVO 模版信息 | ||||
|      * @return 邮箱模版分页信息 | ||||
|      */ | ||||
|     PageResult<MailTemplateDO> getMailTemplatePage(MailTemplatePageReqVO pageReqVO); | ||||
|  | ||||
|     /** | ||||
|      * 获取邮箱模板数组 | ||||
|      * @return | ||||
|      * | ||||
|      * @return 模版数组 | ||||
|      */ | ||||
|     List<MailTemplateDO> getMailTemplateList(); | ||||
|  | ||||
|     /** | ||||
|      * 发送邮件 | ||||
|      * | ||||
|      * @param mailReqVO 邮件发送信息 | ||||
|      */ | ||||
|     void sendMail(MailReqVO mailReqVO); | ||||
| } | ||||
|   | ||||
| @@ -15,6 +15,7 @@ import cn.iocoder.yudao.module.system.dal.mysql.mail.MailAccountMapper; | ||||
| import cn.iocoder.yudao.module.system.dal.mysql.mail.MailTemplateMapper; | ||||
| import cn.iocoder.yudao.module.system.service.mail.MailAccountService; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import java.util.HashMap; | ||||
| @@ -33,7 +34,7 @@ import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.MAIL_ACCOU | ||||
|  * @since 2022-03-21 | ||||
|  */ | ||||
| @Service | ||||
| // TODO @wangjingyi:需要 @Validated 注解,开启参数校验 | ||||
| @Validated | ||||
| public class MailAccountServiceImpl implements MailAccountService { | ||||
|  | ||||
|     @Resource | ||||
| @@ -45,9 +46,7 @@ public class MailAccountServiceImpl implements MailAccountService { | ||||
|     @Override | ||||
|     public Long create(MailAccountCreateReqVO createReqVO) { | ||||
|         // username 要校验唯一 | ||||
|         Map<String , String> map = new HashMap<>(); | ||||
|         map.put("username" , createReqVO.getUsername()); | ||||
|         this.validateMailAccountOnly(map); | ||||
|         this.validateMailAccountOnlyByUserName(createReqVO.getUsername()); | ||||
|         MailAccountDO mailAccountDO = MailAccountConvert.INSTANCE.convert(createReqVO); | ||||
|         mailAccountMapper.insert(mailAccountDO); | ||||
|         return mailAccountDO.getId(); | ||||
| @@ -55,10 +54,8 @@ public class MailAccountServiceImpl implements MailAccountService { | ||||
|  | ||||
|     @Override | ||||
|     public void update(MailAccountUpdateReqVO updateReqVO) { | ||||
|         // username 要校验唯一 TODO @wangjingyi:不要用 map 参数 | ||||
|         Map<String , String> map = new HashMap<>(); | ||||
|         map.put("username" , updateReqVO.getUsername()); | ||||
|         this.validateMailAccountOnly(map); // TODO @wangjingyi:如果 username 是自己用呢,要排除下自己呀 | ||||
|         // username 要校验唯一 | ||||
|         this.validateMailAccountOnlyByUserName(updateReqVO.getUsername()); | ||||
|         MailAccountDO mailAccountDO = MailAccountConvert.INSTANCE.convert(updateReqVO); | ||||
|         // 校验是否存在 | ||||
|         this.validateMailAccountExists(mailAccountDO.getId()); | ||||
| @@ -87,35 +84,14 @@ public class MailAccountServiceImpl implements MailAccountService { | ||||
|         return mailAccountMapper.selectList(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void sendMail(MailReqVO mailReqVO) { | ||||
|         MailTemplateDO mailTemplateDO =  mailTemplateMapper.selectById(mailReqVO.getTemplateId()); | ||||
|         //查询账号信息 | ||||
|         MailAccountDO mailAccountDO = mailAccountMapper.selectOne( | ||||
|                 "from", mailReqVO.getFrom() | ||||
|         ); | ||||
|         String content = mailReqVO.getContent(); | ||||
|         Map<String , String> params = MailAccountConvert.INSTANCE.convertToMap(mailAccountDO , content); | ||||
|         content = StrUtil.format(mailTemplateDO.getContent(), params); | ||||
|  | ||||
|         // 后续功能 TODO :附件查询 | ||||
|         //List<String> fileIds = mailSendVO.getFileIds(); | ||||
|  | ||||
|         //装载账号信息 | ||||
|         MailAccount account  = MailAccountConvert.INSTANCE.convertAccount(mailAccountDO); | ||||
|  | ||||
|         //发送 | ||||
|         MailUtil.send(account , mailReqVO.getTos() , mailReqVO.getTitle() , content , false); | ||||
|     } | ||||
|  | ||||
|     private void validateMailAccountExists(Long id) { | ||||
|         if (mailAccountMapper.selectById(id) == null) { | ||||
|             throw exception(MAIL_ACCOUNT_NOT_EXISTS); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void validateMailAccountOnly(Map params){ | ||||
|         MailAccountDO mailAccountDO = mailAccountMapper.selectByParams(params); | ||||
|     private void validateMailAccountOnlyByUserName(String userName){ | ||||
|         MailAccountDO mailAccountDO = mailAccountMapper.selectByUserName(userName); | ||||
|         if (mailAccountDO != null) { | ||||
|             throw exception(MAIL_ACCOUNT_EXISTS); | ||||
|         } | ||||
|   | ||||
| @@ -9,6 +9,7 @@ import cn.iocoder.yudao.module.system.dal.mysql.mail.MailLogMapper; | ||||
| import cn.iocoder.yudao.module.system.service.mail.MailLogService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| @@ -19,6 +20,7 @@ import java.util.List; | ||||
|  * @since 2022-03-21 | ||||
|  */ | ||||
| @Service | ||||
| @Validated | ||||
| public class MailLogServiceImpl implements MailLogService { | ||||
|  | ||||
|     @Autowired | ||||
|   | ||||
| @@ -1,18 +1,28 @@ | ||||
| package cn.iocoder.yudao.module.system.service.mail.impl; | ||||
|  | ||||
|  | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import cn.hutool.extra.mail.MailAccount; | ||||
| import cn.hutool.extra.mail.MailUtil; | ||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.send.MailReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplateCreateReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplatePageReqVO; | ||||
| import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemplateUpdateReqVO; | ||||
| import cn.iocoder.yudao.module.system.convert.mail.MailAccountConvert; | ||||
| import cn.iocoder.yudao.module.system.convert.mail.MailTemplateConvert; | ||||
| import cn.iocoder.yudao.module.system.dal.dataobject.mail.MailAccountDO; | ||||
| import cn.iocoder.yudao.module.system.dal.dataobject.mail.MailTemplateDO; | ||||
| import cn.iocoder.yudao.module.system.dal.mysql.mail.MailAccountMapper; | ||||
| import cn.iocoder.yudao.module.system.dal.mysql.mail.MailTemplateMapper; | ||||
| import cn.iocoder.yudao.module.system.service.mail.MailAccountService; | ||||
| import cn.iocoder.yudao.module.system.service.mail.MailTemplateService; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import javax.validation.Valid; | ||||
| import java.util.HashMap; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
| @@ -28,29 +38,27 @@ import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.MAIL_TEMPL | ||||
|  * @since 2022-03-21 | ||||
|  */ | ||||
| @Service | ||||
| // TODO @wangjingyi:需要 @Validated 注解,开启参数校验 | ||||
| @Validated | ||||
| public class MailTemplateServiceImpl implements MailTemplateService { | ||||
|  | ||||
|     @Resource | ||||
|     private MailTemplateMapper mailTemplateMapper; | ||||
|     @Resource | ||||
|     private MailAccountMapper mailAccountMapper; | ||||
|  | ||||
|     @Override | ||||
|     public Long create(MailTemplateCreateReqVO createReqVO) { | ||||
|         // name 要校验唯一 | ||||
|         Map<String , String> map = new HashMap<>(); | ||||
|         map.put("name" , createReqVO.getName()); // TODO @wangjingyi:模板名重复没关系的;code 不能重复 | ||||
|         this.validateMailTemplateOnly(map); | ||||
|         // code 要校验唯一 | ||||
|         this.validateMailTemplateOnlyByCode(createReqVO.getCode()); | ||||
|         MailTemplateDO mailTemplateDO = MailTemplateConvert.INSTANCE.convert(createReqVO); | ||||
|         mailTemplateMapper.insert(mailTemplateDO); | ||||
|         return mailTemplateDO.getId(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void update(MailTemplateUpdateReqVO updateReqVO) { | ||||
|         // username 要校验唯一 | ||||
|         Map<String , String> map = new HashMap<>(); | ||||
|         map.put("username" , updateReqVO.getUsername());  // TODO @wangjingyi:模板名重复没关系的;code 不能重复 | ||||
|         this.validateMailTemplateOnly(map); | ||||
|     public void update(@Valid MailTemplateUpdateReqVO updateReqVO) { | ||||
|         // code 要校验唯一 | ||||
|         this.validateMailTemplateOnlyByCode(updateReqVO.getCode()); | ||||
|         MailTemplateDO mailTemplateDO = MailTemplateConvert.INSTANCE.convert(updateReqVO); | ||||
|         // 校验是否存在 | ||||
|         this.validateMailTemplateExists(mailTemplateDO.getId()); | ||||
| @@ -75,18 +83,35 @@ public class MailTemplateServiceImpl implements MailTemplateService { | ||||
|     @Override | ||||
|     public List<MailTemplateDO> getMailTemplateList() {return mailTemplateMapper.selectList();} | ||||
|  | ||||
|     @Override | ||||
|     public void sendMail(MailReqVO mailReqVO) { | ||||
|         MailTemplateDO mailTemplateDO =  mailTemplateMapper.selectById(mailReqVO.getTemplateId()); | ||||
|         //查询账号信息 | ||||
|         MailAccountDO mailAccountDO = mailAccountMapper.selectOne( | ||||
|                 "from", mailReqVO.getFrom() | ||||
|         ); | ||||
|         String content = mailReqVO.getContent(); | ||||
|         Map<String , String> params = MailAccountConvert.INSTANCE.convertToMap(mailAccountDO , content); | ||||
|         content = StrUtil.format(mailTemplateDO.getContent(), params); | ||||
|  | ||||
|         // 后续功能 TODO :附件查询 | ||||
|         //List<String> fileIds = mailSendVO.getFileIds(); | ||||
|  | ||||
|         //装载账号信息 | ||||
|         MailAccount account  = MailAccountConvert.INSTANCE.convertAccount(mailAccountDO); | ||||
|  | ||||
|         //发送 | ||||
|         MailUtil.send(account , mailReqVO.getTos() , mailReqVO.getTitle() , content , false); | ||||
|     } | ||||
|  | ||||
|     private void validateMailTemplateExists(Long id) { | ||||
|         if (mailTemplateMapper.selectById(id) == null) { | ||||
|             throw exception(MAIL_TEMPLATE_NOT_EXISTS); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void validateMailTemplateOnly(Map params){ | ||||
|         QueryWrapper queryWrapper = new QueryWrapper<MailTemplateDO>(); | ||||
|         params.forEach((k , v)->{ | ||||
|             queryWrapper.like(k , v); | ||||
|         }); | ||||
|         if (mailTemplateMapper.selectOne(queryWrapper) != null) { | ||||
|     private void validateMailTemplateOnlyByCode(String code){ | ||||
|         if (mailTemplateMapper.selectOneByCode(code) != null) { | ||||
|             throw exception(MAIL_TEMPLATE_EXISTS); | ||||
|         } | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 wangjingyi
					wangjingyi