Exemple #1
0
  public static long getCurrentSiteID() {
    String id = (String) User.getValue("_CurrentSiteID");
    if (XString.isEmpty(id)) {
      if ("admin".equals(User.getUserName())) {
        LogUtil.error("请在站点管理->站点列表下先创建站点");
        return 0L;
      }
      LogUtil.error("用户:" + User.getUserName() + "没有任何站点的浏览权限,请先设置权限再登陆");
      return 0L;
    }

    return Long.parseLong(id);
  }
Exemple #2
0
 public boolean addJobs(long siteID, ArrayList list, String operation) {
   ZCDeployJobSet set = getJobs(siteID, list, operation);
   Transaction trans = new Transaction();
   trans.add(set, OperateType.INSERT);
   if (trans.commit()) {
     return true;
   }
   LogUtil.getLogger().info("添加部署任务时,数据库操作失败");
   return false;
 }
Exemple #3
0
  public boolean addOneJob(long configID, boolean immediate) {
    ZCDeployJobSchema job = new ZCDeployJobSchema();
    ZCDeployConfigSchema config = new ZCDeployConfigSchema();
    config.setID(configID);
    if (!config.fill()) {
      return false;
    }

    String staticDir =
        Config.getContextRealPath() + Config.getValue("Statical.TargetDir").replace('\\', '/');
    String sourcePath =
        staticDir + "/" + ApplicationPage.getCurrentSiteAlias() + config.getSourceDir();
    job.setID(NoUtil.getMaxID("DeployJobID"));
    job.setConfigID(config.getID());
    job.setSource(sourcePath);
    job.setMethod(config.getMethod());

    String targetDir = config.getTargetDir();
    if (XString.isEmpty(targetDir)) {
      targetDir = "/";
    } else if (!targetDir.endsWith("/")) {
      targetDir = targetDir + "/";
    }

    job.setTarget(targetDir);
    job.setSiteID(config.getSiteID());
    job.setHost(config.getHost());
    job.setPort(config.getPort());
    job.setUserName(config.getUserName());
    job.setPassword(config.getPassword());
    job.setStatus(0L);
    job.setAddTime(new Date());
    job.setAddUser(User.getUserName());

    Transaction trans = new Transaction();
    trans.add(job, OperateType.INSERT);
    if (trans.commit()) {
      if (immediate) {
        executeJob(config, job);
      }
      return true;
    }
    LogUtil.getLogger().info("添加部署任务时,数据库操作失败");
    return false;
  }
Exemple #4
0
  public boolean executeBatchJob(ZCDeployConfigSchema config, ZCDeployJobSet jobs) {
    if ((config == null) || (jobs.size() < 1)) {
      return false;
    }

    Transaction trans = new Transaction();
    String message = "";
    boolean connectFlag = true;

    String deployMethod = config.getMethod();
    if ("DIR".equals(deployMethod)) {
      for (int i = 0; i < jobs.size(); i++) {
        ZCDeployJobSchema job = jobs.get(i);

        ZCDeployLogSchema jobLog = new ZCDeployLogSchema();
        jobLog.setID(NoUtil.getMaxID("DeployLogID"));
        jobLog.setSiteID(job.getSiteID());
        jobLog.setJobID(job.getID());
        jobLog.setBeginTime(new Date());

        if (job.getStatus() == 3L) {
          job.setRetryCount(job.getRetryCount() + 1L);
        }

        String sourceFile = job.getSource();
        if (sourceFile.indexOf("template") != -1) {
          LogUtil.getLogger().info("模板文件" + sourceFile + "不复制,跳过");
          return true;
        }

        String target = job.getTarget();
        target = target.replace('\\', '/');
        String targetDir = target.substring(0, target.lastIndexOf("/"));
        File dir = new File(targetDir);
        if (!dir.exists()) {
          dir.mkdirs();
        }
        if (!targetDir.endsWith("/template")) {
          if ("delete".equalsIgnoreCase(job.getOperation())) {
            if (FileUtil.delete(target)) {
              message = "成功删除文件" + target;
              LogUtil.getLogger().info(message);
              job.setStatus(2L);
            } else {
              message = "失败:删除文件" + target;
              LogUtil.getLogger().info(message);
              job.setStatus(3L);
              Errorx.addError(message);
            }
          } else if (FileUtil.copy(sourceFile, target)) {
            message = "成功复制文件" + sourceFile + "到" + target;
            LogUtil.getLogger().info(message);
            job.setStatus(2L);
          } else {
            message = "失败:复制文件" + sourceFile + "到" + target;
            LogUtil.getLogger().info(message);
            job.setStatus(3L);
            Errorx.addError(message);
          }
        }

        jobLog.setMessage(message);
        jobLog.setEndTime(new Date());
        LogUtil.getLogger().info(message);

        trans.add(jobLog, OperateType.INSERT);
        trans.add(job, OperateType.UPDATE);
      }
    } else if ("FTP".equals(deployMethod)) {
      CommonFtp ftp = new CommonFtp();
      try {
        ftp.connect(
            config.getHost(), (int) config.getPort(), config.getUserName(), config.getPassword());
        connectFlag = true;
      } catch (IOException e1) {
        e1.printStackTrace();

        ZCDeployLogSchema jobLog = new ZCDeployLogSchema();
        jobLog.setID(NoUtil.getMaxID("DeployLogID"));
        jobLog.setSiteID(config.getSiteID());
        jobLog.setJobID(jobs.get(0).getID());
        jobLog.setBeginTime(new Date());
        jobLog.setEndTime(new Date());
        jobLog.setMessage(e1.getMessage());
        trans.add(jobLog, OperateType.INSERT);
        connectFlag = false;
      }
      if (connectFlag) {
        for (int i = 0; i < jobs.size(); i++) {
          ZCDeployJobSchema job = jobs.get(i);

          ZCDeployLogSchema jobLog = new ZCDeployLogSchema();
          jobLog.setID(NoUtil.getMaxID("DeployLogID"));
          jobLog.setSiteID(job.getSiteID());
          jobLog.setJobID(job.getID());
          jobLog.setBeginTime(new Date());

          if (job.getStatus() == 3L) {
            job.setRetryCount(job.getRetryCount() + 1L);
          }

          String target = job.getTarget();
          target = target.replace('\\', '/');
          if ("delete".equalsIgnoreCase(job.getOperation()))
            try {
              target = target.replaceAll("///", "/");
              if (ftp.delete(target)) {
                message = "FTP删除文件成功";
                job.setStatus(2L);
                jobLog.setMessage(message);
                jobLog.setEndTime(new Date());
                LogUtil.getLogger().info(message);

                trans.add(jobLog, OperateType.INSERT);
                trans.add(job, OperateType.UPDATE);
                break;
              }
              message = "FTP删除文件失败";
              job.setStatus(3L);
            } catch (Exception e) {
              job.setStatus(3L);
              message = e.getMessage();
              Errorx.addError(message);
            }
          else {
            try {
              String srcFile = job.getSource();
              srcFile = srcFile.replaceAll("///", "/");
              srcFile = srcFile.replaceAll("//", "/");
              String path = srcFile;
              ArrayList list = FileList.getAllFiles(path);
              if (list.size() == 0) {
                job.setStatus(3L);
                message = "文件不存在:" + path;
                Errorx.addError(message);
              } else {
                for (int j = 0; j < list.size(); j++) {
                  String name = (String) list.get(j);
                  if (name.indexOf("template") != -1) {
                    continue;
                  }
                  name = name.replace('\\', '/');
                  String targetName = name.replaceAll(path, "");
                  ftp.upload(name, target + targetName);
                }
                job.setStatus(2L);
                message = "FTP上传成功";
              }
            } catch (Exception e) {
              job.setStatus(3L);
              message = e.getMessage();
              Errorx.addError(message);
            }
          }
          label1106:
          jobLog.setMessage(message);
          jobLog.setEndTime(new Date());
          LogUtil.getLogger().info(message);

          trans.add(jobLog, OperateType.INSERT);
          trans.add(job, OperateType.UPDATE);
        }
      }
      ftp.disconnect();
    } else if ("SFTP".equals(deployMethod)) {
      SFtp sftp = new SFtp();
      try {
        sftp.connect(
            config.getHost(), (int) config.getPort(), config.getUserName(), config.getPassword());
        connectFlag = true;
      } catch (JSchException e1) {
        e1.printStackTrace();

        ZCDeployLogSchema jobLog = new ZCDeployLogSchema();
        jobLog.setID(NoUtil.getMaxID("DeployLogID"));
        jobLog.setSiteID(config.getSiteID());
        jobLog.setJobID(jobs.get(0).getID());
        jobLog.setBeginTime(new Date());
        jobLog.setEndTime(new Date());
        jobLog.setMessage(e1.getMessage());
        trans.add(jobLog, OperateType.INSERT);
        connectFlag = false;
      }
      if (connectFlag) {
        for (int i = 0; i < jobs.size(); i++) {
          ZCDeployJobSchema job = jobs.get(i);

          ZCDeployLogSchema jobLog = new ZCDeployLogSchema();
          jobLog.setID(NoUtil.getMaxID("DeployLogID"));
          jobLog.setSiteID(job.getSiteID());
          jobLog.setJobID(job.getID());
          jobLog.setBeginTime(new Date());

          if (job.getStatus() == 3L) {
            job.setRetryCount(job.getRetryCount() + 1L);
          }

          String target = job.getTarget();
          target = target.replace('\\', '/');
          if ("delete".equalsIgnoreCase(job.getOperation()))
            try {
              target = target.replaceAll("///", "/");
              if (sftp.delete(target)) {
                message = "SFTP删除文件成功";
                job.setStatus(2L);
                jobLog.setMessage(message);
                jobLog.setEndTime(new Date());
                LogUtil.getLogger().info(message);

                trans.add(jobLog, OperateType.INSERT);
                trans.add(job, OperateType.UPDATE);
              }
              message = "SFTP删除文件失败";
              job.setStatus(3L);
            } catch (Exception e) {
              job.setStatus(3L);
              message = e.getMessage();
              Errorx.addError(message);
            }
          else {
            try {
              String srcFile = job.getSource();
              srcFile = srcFile.replaceAll("///", "/");
              srcFile = srcFile.replaceAll("//", "/");
              String path = srcFile;
              ArrayList list = FileList.getAllFiles(path);
              if (list.size() == 0) {
                job.setStatus(3L);
                message = "文件不存在" + srcFile;
              } else {
                for (int j = 0; j < list.size(); j++) {
                  String name = (String) list.get(j);
                  if (name.indexOf("template") != -1) {
                    continue;
                  }
                  name = name.replace('\\', '/');
                  String targetName = name.replaceAll(path, "");
                  sftp.upload(name, target + targetName);
                }
                job.setStatus(2L);
                message = "SFTP上传成功";
              }
            } catch (Exception e) {
              job.setStatus(3L);
              message = e.getMessage();
              Errorx.addError(message);
            }
          }
          label1730:
          jobLog.setMessage(message);
          jobLog.setEndTime(new Date());
          LogUtil.getLogger().info(message);

          trans.add(jobLog, OperateType.INSERT);
          trans.add(job, OperateType.UPDATE);
        }
      }
      sftp.disconnect();
    }

    if (trans.commit()) {
      return true;
    }
    LogUtil.getLogger().info("添加部署任务时,数据库操作失败");
    Errorx.addError(message);
    return false;
  }