code review 邮件模块

pull/2/head
YunaiV 2022-03-30 21:46:54 +08:00
parent 1bf1d3ee6a
commit 7d9a6cb2ef
8 changed files with 30 additions and 28 deletions

View File

@ -48,12 +48,11 @@ public class MailAccountController {
return success(true);
}
@DeleteMapping("/delete")
@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) {
public CommonResult<Boolean> deleteMailAccount(@Valid @RequestParam Long id) { // TODO @wangjingyi不需要 @Valid 这里。了解下 Validator
mailAccountService.delete(id);
return success(true);
}
@ -87,7 +86,7 @@ public class MailAccountController {
@PostMapping("/send")
@ApiOperation("发送邮件")
@PreAuthorize("@ss.hasPermission('system:mail-account:send')")
public CommonResult<Boolean> sendMail(MailReqVO mailReqVO){
public CommonResult<Boolean> sendMail(MailReqVO mailReqVO){ // TODO @wangjingyi应该是测试短信模板做到 MailTemplateController 里。参考下短信那的做法哈
mailAccountService.sendMail(mailReqVO);
return success(true);
}

View File

@ -28,7 +28,7 @@ import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
@RequestMapping("/system/mail-template")
public class MailTemplateController {
@Autowired
MailTemplateService mailTempleService;
MailTemplateService mailTempleService; // TODO @wangjingyiprivate和上面要空一行
@PostMapping("/create")
@ApiOperation("创建邮箱模版")
@ -62,7 +62,6 @@ public class MailTemplateController {
return success(MailTemplateConvert.INSTANCE.convert(mailTemplateDO));
}
@GetMapping("/page")
@ApiOperation("获得邮箱模版分页")
@PreAuthorize("@ss.hasPermission('system:mail-account:query')")

View File

@ -1,26 +1,25 @@
package cn.iocoder.yudao.module.system.dal.dataobject.mail;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
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.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
import java.io.Serializable;
@Data
@EqualsAndHashCode(callSuper = true)
@Accessors(chain = true)
@ApiModel(value="MailAccount对象", description="邮箱账号")
@TableName(value = "system_mail_account", autoResultMap = true)
@ApiModel(value="MailAccount对象", description="邮箱账号") // TODO @wangjingyi不需要 swagger 注解
@TableName(value = "system_mail_account", autoResultMap = true) // TODO @wangjingyi这个放在最上面关键字段
public class MailAccountDO extends BaseDO implements Serializable {
private static final long serialVersionUID = 1L;
// TODO @wangjingyi每个字段的注释字段名如果一直不用 @TableField
@TableId
private Long id;

View File

@ -5,14 +5,10 @@ import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.QueryWrapperX;
import cn.iocoder.yudao.module.system.controller.admin.mail.vo.account.MailAccountPageReqVO;
import cn.iocoder.yudao.module.system.dal.dataobject.mail.MailAccountDO;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.apache.ibatis.annotations.Mapper;
import java.util.Map;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.MAIL_ACCOUNT_EXISTS;
@Mapper
public interface MailAccountMapper extends BaseMapperX<MailAccountDO> {
@ -26,11 +22,12 @@ public interface MailAccountMapper extends BaseMapperX<MailAccountDO> {
);
}
// TODO @wangjingyi不要提供这样的泛的方法而是明确的查询方法
default MailAccountDO selectByParams(Map params){
QueryWrapperX queryWrapperX = new QueryWrapperX<MailAccountDO>();
params.forEach((k , v)->{
queryWrapperX.eqIfPresent((String) k, v);
});
return this.selectOne(queryWrapperX);
return this.selecOne(queryWrapperX);
};
}

View File

@ -11,14 +11,17 @@ import java.util.List;
/**
* Service
* Service
*
* @author wangjingyi
* @since 2022-03-21
*/
public interface MailAccountService {
// TODO @wangjingyi注释完整参数校验还是要做的
/**
*
* // TODO @wangjingyi方法描述和参数要空行
* @param createReqVO
* @return
*/

View File

@ -15,6 +15,9 @@ import java.util.List;
* @since 2022-03-21
*/
public interface MailTemplateService {
// TODO @wangjingyi注释完整参数校验还是要做的
/**
*
* @param createReqVO

View File

@ -33,6 +33,7 @@ import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.MAIL_ACCOU
* @since 2022-03-21
*/
@Service
// TODO @wangjingyi需要 @Validated 注解,开启参数校验
public class MailAccountServiceImpl implements MailAccountService {
@Resource
@ -54,13 +55,13 @@ public class MailAccountServiceImpl implements MailAccountService {
@Override
public void update(MailAccountUpdateReqVO updateReqVO) {
// username 要校验唯一
// username 要校验唯一 TODO @wangjingyi不要用 map 参数
Map<String , String> map = new HashMap<>();
map.put("username" , updateReqVO.getUsername());
this.validateMailAccountOnly(map);
this.validateMailAccountOnly(map); // TODO @wangjingyi如果 username 是自己用呢,要排除下自己呀
MailAccountDO mailAccountDO = MailAccountConvert.INSTANCE.convert(updateReqVO);
// 校验是否存在
this.validateMailAccountExists(mailAccountDO.getId()); // TODO wangjingyi没有传递 id 噢
this.validateMailAccountExists(mailAccountDO.getId());
mailAccountMapper.updateById(mailAccountDO);
}

View File

@ -6,7 +6,6 @@ import cn.iocoder.yudao.module.system.controller.admin.mail.vo.template.MailTemp
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.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.MailTemplateMapper;
import cn.iocoder.yudao.module.system.service.mail.MailTemplateService;
@ -19,15 +18,17 @@ import java.util.List;
import java.util.Map;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.*;
import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.MAIL_TEMPLATE_EXISTS;
import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.MAIL_TEMPLATE_NOT_EXISTS;
/**
*
*
*
* @author wangjingyi
* @since 2022-03-21
*/
@Service
// TODO @wangjingyi需要 @Validated 注解,开启参数校验
public class MailTemplateServiceImpl implements MailTemplateService {
@Resource
@ -37,7 +38,7 @@ public class MailTemplateServiceImpl implements MailTemplateService {
public Long create(MailTemplateCreateReqVO createReqVO) {
// name 要校验唯一
Map<String , String> map = new HashMap<>();
map.put("name" , createReqVO.getName());
map.put("name" , createReqVO.getName()); // TODO @wangjingyi模板名重复没关系的code 不能重复
this.validateMailTemplateOnly(map);
MailTemplateDO mailTemplateDO = MailTemplateConvert.INSTANCE.convert(createReqVO);
mailTemplateMapper.insert(mailTemplateDO);
@ -48,7 +49,7 @@ public class MailTemplateServiceImpl implements MailTemplateService {
public void update(MailTemplateUpdateReqVO updateReqVO) {
// username 要校验唯一
Map<String , String> map = new HashMap<>();
map.put("username" , updateReqVO.getUsername());
map.put("username" , updateReqVO.getUsername()); // TODO @wangjingyi模板名重复没关系的code 不能重复
this.validateMailTemplateOnly(map);
MailTemplateDO mailTemplateDO = MailTemplateConvert.INSTANCE.convert(updateReqVO);
// 校验是否存在