@Override
  public Template save(Template entity) {
    String subject = "";
    String operate = OperateLog.OPERATE_CREATE;
    if (entity.isNew()) {
      subject = "新建模板:" + entity.getSubject();
    } else {
      subject = "更新模板:" + entity.getSubject();
      operate = OperateLog.OPERATE_UPDATE;
    }

    // 正常
    if (entity.getStatus() == BCConstants.STATUS_ENABLED) {
      Template oldTpl = this.templateDao.loadByCodeAndId(entity.getCode(), entity.getId());
      if (oldTpl != null) {
        this.operateLogService.saveWorkLog(
            Template.class.getSimpleName(),
            oldTpl.getId().toString(),
            "禁用旧模板:" + oldTpl.getSubject(),
            null,
            OperateLog.OPERATE_UPDATE);
        oldTpl.setStatus(BCConstants.STATUS_DISABLED);
        this.templateDao.save(oldTpl);
      }
    }
    entity = this.templateDao.save(entity);
    this.operateLogService.saveWorkLog(
        Template.class.getSimpleName(), entity.getId().toString(), subject, null, operate);
    return entity;
  }
 public void saveTpl(Template template) {
   Template oldTpl = this.templateDao.loadByCodeAndId(template.getCode(), template.getId());
   if (oldTpl != null) {
     oldTpl.setStatus(BCConstants.STATUS_DISABLED);
     this.templateDao.save(oldTpl);
   }
   this.templateDao.save(template);
 }
  private void sendEmail(SubscribeEvent event, List<Actor> actors, OperateLog worklog) {
    // 工作日志的详细内容
    String worklog_content = worklog.getContent();
    Email email = new Email();
    worklog_content += "发送方式:邮件[";

    String emailUid = this.idGeneratorService.nexttvak(Email.ATTACH_TYPE);
    email.setUid(emailUid);
    email.setStatus(Email.STATUS_SENDED);
    email.setType(Email.TYPE_NEW);
    email.setFileDate(Calendar.getInstance());
    email.setSendDate(Calendar.getInstance());
    email.setSubject(event.getSubject());
    worklog_content += "邮件主题: " + event.getSubject();

    Map<String, Object> args = new HashMap<String, Object>();
    args.put("content", event.getContent());

    // 根据事件的CODE 加上 “-EMAIL”后缀 查找模板中是否有配置 自定义的模板
    Template custom = this.templateService.loadByCode(event.getCode() + "-EMAIL");

    if (custom != null) {
      email.setContent(this.templateService.format(custom.getCode(), args));
    } else { // 使用默认的邮件模板
      email.setContent(this.templateService.format("BC-EMAIL-SYSTEMAUTOFORWARD", args));
    }
    worklog_content += ",邮件内容: " + event.getContent();
    // 系统管理员发送
    Actor admin = this.actorService.loadByCode("admin");
    email.setSender(admin);

    if (event.getAttachs() != null) {
      for (Attach attach : event.getAttachs()) {
        // 复制附件
        this.attachService.doCopy(
            attach.getPtype(), attach.getPuid(), Email.ATTACH_TYPE, emailUid, true);
      }
    }

    // 设置发送人
    Set<EmailTo> emailTos = new HashSet<EmailTo>();
    worklog_content += ",邮件接收人:";
    EmailTo et;
    int i = 0;
    for (Actor a : actors) {
      et = new EmailTo();
      et.setEmail(email);
      et.setRead(false);
      et.setReceiver(a);
      // 正常发送
      et.setType(EmailTo.TYPE_TO);
      et.setOrderNo(i);
      emailTos.add(et);

      if (i > 0) worklog_content += "、";
      worklog_content += a.getName();
      i++;
    }
    worklog_content += "]";
    worklog.setContent(worklog_content);
    email.setTos(emailTos);

    this.emailService.save(email);
  }
  public Attach getAttach(
      String subject,
      String code,
      Map<String, Object> args,
      String ptype,
      String puid,
      ActorHistory author,
      Map<String, Object> formatParamSql)
      throws Exception {
    Assert.hasText(subject, "subject is Empty");
    Assert.hasText(code, "code is Empty");
    Assert.hasText(ptype, "ptype is Empty");
    Assert.hasText(puid, "puid is Empty");

    Template template = this.templateDao.loadByCode(code);
    if (template == null) throw new CoreException("Template code:" + code + " not find entity!");

    if (args == null) args = new HashMap<String, Object>();

    if (author == null) {
      if (SystemContextHolder.get() == null) {
        author = this.actorHistoryService.loadByCode("admin");
      } else {
        author = SystemContextHolder.get().getUserHistory();
      }
    }

    Map<String, Object> args4Param = this.getMapParams(template.getId(), formatParamSql);

    if (args4Param != null)
      // 最终替换参数
      args.putAll(this.getMapParams(template.getId(), formatParamSql));

    // 生成附件
    Attach attach = new Attach();
    attach.setAuthor(author);
    attach.setFileDate(Calendar.getInstance());
    attach.setSubject(subject);
    attach.setAppPath(false);
    attach.setFormat(template.getTemplateType().getExtension());
    attach.setStatus(BCConstants.STATUS_ENABLED);
    attach.setPtype(ptype);
    attach.setPuid(puid);

    // 文件存储的相对路径(年月),避免超出目录内文件数的限制
    Calendar now = Calendar.getInstance();
    String datedir = new SimpleDateFormat("yyyyMM").format(now.getTime());

    // 要保存的物理文件
    String realpath; // 绝对路径名
    // uuid
    String fileName =
        UUID.randomUUID().toString().replace("-", "")
            + "."
            + template.getTemplateType().getExtension(); // 不含路径的文件名
    realpath = Attach.DATA_REAL_PATH + "/" + datedir + "/" + fileName;

    // 构建文件要保存到的目录
    File file = new File(realpath);
    if (!file.getParentFile().exists()) {
      if (logger.isInfoEnabled()) {
        logger.info("mkdir=" + file.getParentFile().getAbsolutePath());
      }
      file.getParentFile().mkdirs();
    }

    OutputStream out = new BufferedOutputStream(new FileOutputStream(file));

    this.formatTo(template.getCode(), args, out);

    // 设置附件大小
    attach.setSize(new File(realpath).length());

    // 设置附件相对路径
    attach.setPath(datedir + "/" + fileName);

    return this.attachService.save(attach);
  }