Package com.dotmarketing.fixtask.tasks

Source Code of com.dotmarketing.fixtask.tasks.FixTask00005CheckHTMLPagesInconsistencies

package com.dotmarketing.fixtask.tasks;


import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.dotmarketing.beans.FixAudit;
import com.dotmarketing.common.db.DotConnect;
import com.dotmarketing.db.DbConnectionFactory;
import com.dotmarketing.db.HibernateUtil;
import com.dotmarketing.exception.DotDataException;
import com.dotmarketing.exception.DotRuntimeException;
import com.dotmarketing.fixtask.FixTask;
import com.dotmarketing.portlets.cmsmaintenance.ajax.FixAssetsProcessStatus;
import com.dotmarketing.portlets.cmsmaintenance.factories.CMSMaintenanceFactory;
import com.dotmarketing.util.Config;
import com.dotmarketing.util.ConfigUtils;
import com.dotmarketing.util.Logger;
import com.dotcms.repackage.com.thoughtworks.xstream.XStream;
import com.dotcms.repackage.com.thoughtworks.xstream.io.xml.DomDriver;


public class FixTask00005CheckHTMLPagesInconsistencies  implements FixTask {
 

  private List <Map<String, String>>  modifiedData= new  ArrayList <Map<String,String>>();
 

  public List <Map <String,Object>> executeFix() throws DotDataException, DotRuntimeException {

     List <Map <String,Object>> returnValue = new ArrayList <Map <String,Object>>();
    Logger.info(CMSMaintenanceFactory.class,
        "Beginning fixAssetsInconsistencies");

    int counter = 0;

    final String fix2HtmlPageQuery = "select c.* from htmlpage c, inode i where i.inode = c.inode and c.identifier = ? order by mod_date desc";
    final String fix3HtmlPageQuery = "update htmlpage_version_info set working_inode = ? where identifier = ?";

    if (!FixAssetsProcessStatus.getRunning()) {
      FixAssetsProcessStatus.startProgress();
      FixAssetsProcessStatus.setDescription("task 5: check the working and live versions of html pages for inconsistencies");     
      HibernateUtil.startTransaction();
      try {
        DotConnect db = new DotConnect();

        String query = "select distinct ident.* " + "from identifier ident, "
            + "inode i, " + "htmlpage c "
            + "where ident.id = c.identifier and "
            + "ident.id not in (select ident.id "
            + "from identifier ident, " + "inode i, " + "htmlpage c, " + "htmlpage_version_info hvi "
            + "where c.identifier = ident.id and "
            + "i.inode = c.inode and " + "hvi.working_inode = c.inode) and " 
            + "i.type = 'htmlpage' and " + "i.inode = c.inode";

        Logger.debug(CMSMaintenanceFactory.class,
            "Running query for html pages: " + query);
        db.setSQL(query);
        List<HashMap<String, String>> htmlpageIds = db.getResults();
       
        Logger.debug(CMSMaintenanceFactory.class, "Found "
            + htmlpageIds.size() + " Html pages");
        int total = htmlpageIds.size();

        Logger.info(CMSMaintenanceFactory.class,
            "Total number of assets: " + total);
        FixAssetsProcessStatus.setTotal(total);

        String identifierInode;
        List<HashMap<String, String>> versions;
        HashMap<String, String> version;
        //String versionWorking;
        String DbConnFalseBoolean = DbConnectionFactory.getDBFalse()
            .trim().toLowerCase();

        char DbConnFalseBooleanChar;
        if (DbConnFalseBoolean.charAt(0) == '\'')
          DbConnFalseBooleanChar = DbConnFalseBoolean.charAt(1);
        else
          DbConnFalseBooleanChar = DbConnFalseBoolean.charAt(0);

        String inode;

        // Check the working and live versions of html pages
        Logger.info(CMSMaintenanceFactory.class,
            "Verifying working and live versions for "
                + htmlpageIds.size() + " htmlpages");
        for (HashMap<String, String> identifier : htmlpageIds) {
          identifierInode = identifier.get("id");

          Logger.debug(CMSMaintenanceFactory.class,
              "identifier inode " + identifierInode);
          Logger.debug(CMSMaintenanceFactory.class, "Running query: "
              + fix2HtmlPageQuery);

          db.setSQL(fix2HtmlPageQuery);
          db.addParam(identifierInode);
          versions = db.getResults();
          modifiedData.addAll(versions);
         
          if (0 < versions.size()) {
            version = versions.get(0);
            //versionWorking = version.get("working").trim().toLowerCase();

            // Logger.info("Step 5 versionWorking: " +
            // versionWorking);

            inode = version.get("inode");
            Logger.debug(CMSMaintenanceFactory.class,
                "Non Working HTML page inode : " + inode);
            Logger.debug(CMSMaintenanceFactory.class,
                "Running query: " + fix3HtmlPageQuery);
            db.setSQL(fix3HtmlPageQuery);           
            db.addParam(inode);
            db.addParam(identifierInode);
            db.getResult();

            FixAssetsProcessStatus.addAError();
            counter++;
          }

          FixAssetsProcessStatus.addActual();
        }
        getModifiedData();
        FixAudit Audit= new FixAudit();
        Audit.setTableName("htmlpage");
        Audit.setDatetime(new Date());
        Audit.setRecordsAltered(total);
        Audit.setAction("Check the working and live versions of html pages for inconsistencies and fix them");
        HibernateUtil.save(Audit);       
        HibernateUtil.commitTransaction();
        returnValue.add( FixAssetsProcessStatus.getFixAssetsMap());
        FixAssetsProcessStatus.stopProgress();
        Logger.debug(CMSMaintenanceFactory.class,
            "Ending fixAssetsInconsistencies");
      } catch (Exception e) {
        Logger.debug(CMSMaintenanceFactory.class,
            "There was a problem fixing asset inconsistencies", e);
        Logger.warn(CMSMaintenanceFactory.class,
            "There was a problem fixing asset inconsistencies", e);       
        HibernateUtil.rollbackTransaction();
        FixAssetsProcessStatus.stopProgress();
        FixAssetsProcessStatus.setActual(-1);
      }
    }

     return returnValue;
  }

  public List <Map<String, String>> getModifiedData()  {
   
    if (modifiedData.size() > 0) {
      XStream _xstream = new XStream(new DomDriver());
      Date date = new Date();
      SimpleDateFormat sdf = new SimpleDateFormat("dd-MM-yyyy_HH-mm-ss");
      String lastmoddate = sdf.format(date);
      File _writing = null;

      if (!new File(ConfigUtils.getBackupPath()+File.separator+"fixes").exists()) {
        new File(ConfigUtils.getBackupPath()+File.separator+"fixes").mkdir();
      }
      _writing = new File(ConfigUtils.getBackupPath()+File.separator+"fixes" + java.io.File.separator + lastmoddate + "_"
          + "FixTask00005CheckHTMLPagesInconsistencies" + ".xml");

      BufferedOutputStream _bout = null;
      try {
        _bout = new BufferedOutputStream(new FileOutputStream(_writing));
      } catch (FileNotFoundException e) {

      }
      _xstream.toXML(modifiedData, _bout);
    }
    return modifiedData;
  }


  public boolean shouldRun() {
    DotConnect db = new DotConnect();

    String query = "select distinct ident.* " + "from identifier ident, "
        + "inode i, " + "htmlpage c "
        + "where ident.id = c.identifier and "
        + "ident.id not in (select ident.id " + "from identifier ident, "
        + "inode i, " + "htmlpage c, " + "htmlpage_version_info hvi "
        + "where c.identifier = ident.id and "
        + "i.inode = c.inode and " + "hvi.working_inode = c.inode) and "
        + "i.type = 'htmlpage' and " + "i.inode = c.inode";
    db.setSQL(query);
    List<HashMap<String, String>> htmlpageIds =null;
    try {
      htmlpageIds = db.getResults();
    } catch (DotDataException e) {
      Logger.error(this, e.getMessage(), e);
    }
    int total = htmlpageIds.size();
    if (total > 0)
      return true;
    else
      return false;
  }

}
TOP

Related Classes of com.dotmarketing.fixtask.tasks.FixTask00005CheckHTMLPagesInconsistencies

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.