ServerCachesServlet.java 5.15 KB
/*
 * Decompiled with CFR 0_118.
 * 
 * Could not load the following classes:
 *  com.day.cq.commons.TidyJSONWriter
 *  com.day.cq.commons.servlets.AbstractPredicateServlet
 *  com.day.cq.commons.servlets.HtmlStatusResponseHelper
 *  com.day.cq.wcm.msm.api.LiveCopy
 *  javax.jcr.RangeIterator
 *  javax.jcr.Session
 *  javax.servlet.ServletException
 *  javax.servlet.http.HttpServletResponse
 *  org.apache.commons.collections.Predicate
 *  org.apache.felix.scr.annotations.Reference
 *  org.apache.felix.scr.annotations.sling.SlingServlet
 *  org.apache.sling.api.SlingHttpServletRequest
 *  org.apache.sling.api.SlingHttpServletResponse
 *  org.apache.sling.api.resource.Resource
 *  org.apache.sling.api.resource.ResourceResolver
 *  org.apache.sling.api.servlets.HtmlResponse
 *  org.slf4j.Logger
 *  org.slf4j.LoggerFactory
 */
package com.day.cq.wcm.msm.impl.servlets;

import com.day.cq.commons.TidyJSONWriter;
import com.day.cq.commons.servlets.AbstractPredicateServlet;
import com.day.cq.commons.servlets.HtmlStatusResponseHelper;
import com.day.cq.wcm.msm.api.LiveCopy;
import com.day.cq.wcm.msm.impl.LiveCopyManagerImpl;
import com.day.cq.wcm.msm.impl.LiveCopyServiceImpl;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.io.Writer;
import javax.jcr.RangeIterator;
import javax.jcr.Session;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.collections.Predicate;
import org.apache.felix.scr.annotations.Reference;
import org.apache.felix.scr.annotations.sling.SlingServlet;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.servlets.HtmlResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Deprecated
@SlingServlet(paths={"/libs/wcm/msm/content/commands/servercaches"}, methods={"POST", "GET"})
public class ServerCachesServlet
extends AbstractPredicateServlet {
    private final Logger log = LoggerFactory.getLogger(ServerCachesServlet.class);
    private static final String TIDY_PARAM = "tidy";
    @Reference
    private LiveCopyServiceImpl liveCopyService = null;

    protected void doGet(SlingHttpServletRequest req, SlingHttpServletResponse resp, Predicate predicate) throws ServletException, IOException {
        this.log.info("The Request to Flush the LiveCopyCache is deprecated. Remove usage if you have not been requesting from MSM ControlCenter");
        LiveCopyManagerImpl lcm = this.liveCopyService.createLiveCopyManager(req.getResourceResolver());
        StringWriter buf = new StringWriter();
        TidyJSONWriter w = new TidyJSONWriter((Writer)buf);
        w.setTidy("true".equals(req.getParameter("tidy")));
        try {
            w.object();
            w.key("livecopiesCacheSize").value((long)this.liveCopyService.getIndexSize());
            w.key("livecopiesCache");
            w.array();
            RangeIterator itr = lcm.getAll();
            while (itr.hasNext()) {
                w.value((Object)((LiveCopy)itr.next()).getPath());
            }
            w.endArray();
            w.endObject();
        }
        catch (Exception e) {
            throw new ServletException((Throwable)e);
        }
        resp.setContentType("application/json");
        resp.setCharacterEncoding("utf-8");
        resp.getWriter().print(buf.getBuffer().toString());
    }

    protected void doPost(SlingHttpServletRequest req, SlingHttpServletResponse response) throws ServletException, IOException {
        HtmlResponse htmlResponse;
        this.log.info("The Request to Flush the LiveCopyCache is deprecated. Remove usage if you have not been requesting from MSM ControlCenter");
        String cmd = req.getParameter("cmd");
        try {
            if ("flush".equals(cmd)) {
                if (((Session)req.getResourceResolver().adaptTo(Session.class)).hasPermission(req.getResource().getPath(), "set_property")) {
                    this.liveCopyService.setIndexDirty();
                    htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)true, (String)"Caches flushed.");
                } else {
                    htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)false, (String)"Not Allowed.");
                }
            } else {
                htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)true, (String)"No command.");
            }
        }
        catch (Exception e) {
            this.log.error("Error while flushing caches.", (Throwable)e);
            htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)false, (String)("Error while flushing caches: " + e.getMessage()));
        }
        htmlResponse.send((HttpServletResponse)response, true);
    }

    protected void bindLiveCopyService(LiveCopyServiceImpl liveCopyServiceImpl) {
        this.liveCopyService = liveCopyServiceImpl;
    }

    protected void unbindLiveCopyService(LiveCopyServiceImpl liveCopyServiceImpl) {
        if (this.liveCopyService == liveCopyServiceImpl) {
            this.liveCopyService = null;
        }
    }
}