PrivilegesServlet.java 6.29 KB
/*
 * Decompiled with CFR 0_118.
 * 
 * Could not load the following classes:
 *  com.day.cq.i18n.I18n
 *  javax.jcr.AccessDeniedException
 *  javax.jcr.RepositoryException
 *  javax.jcr.Session
 *  javax.jcr.UnsupportedRepositoryOperationException
 *  javax.jcr.Workspace
 *  javax.jcr.security.Privilege
 *  javax.servlet.ServletException
 *  javax.servlet.http.HttpServletRequest
 *  javax.servlet.http.HttpServletResponse
 *  org.apache.jackrabbit.api.JackrabbitWorkspace
 *  org.apache.jackrabbit.api.security.authorization.PrivilegeManager
 *  org.apache.sling.commons.json.JSONException
 *  org.apache.sling.commons.json.io.JSONWriter
 *  org.osgi.framework.BundleContext
 *  org.slf4j.Logger
 */
package com.day.crx.delite.impl.servlets;

import com.day.cq.i18n.I18n;
import com.day.crx.delite.impl.AbstractServlet;
import com.day.crx.delite.impl.support.RequestData;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.Writer;
import java.util.Arrays;
import javax.jcr.AccessDeniedException;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import javax.jcr.UnsupportedRepositoryOperationException;
import javax.jcr.Workspace;
import javax.jcr.security.Privilege;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.jackrabbit.api.JackrabbitWorkspace;
import org.apache.jackrabbit.api.security.authorization.PrivilegeManager;
import org.apache.sling.commons.json.JSONException;
import org.apache.sling.commons.json.io.JSONWriter;
import org.osgi.framework.BundleContext;
import org.slf4j.Logger;

public class PrivilegesServlet
extends AbstractServlet {
    public PrivilegesServlet(BundleContext bc) {
        super(bc);
    }

    protected void doService(HttpServletRequest req, HttpServletResponse res, Session session) throws ServletException, IOException {
        if (req.getMethod().equals("GET")) {
            this.doGet(req, res, session);
            return;
        }
        if (req.getMethod().equals("POST")) {
            if ("register".equals(req.getParameter("action"))) {
                this.register(req, res, session);
                return;
            }
            res.sendError(400, I18n.get((HttpServletRequest)req, (String)"Invalid action"));
            return;
        }
        res.sendError(405);
    }

    private void register(HttpServletRequest request, HttpServletResponse res, Session session) throws ServletException, IOException {
        res.setContentType("text/html");
        res.setCharacterEncoding("utf-8");
        RequestData req = new RequestData(request);
        String name = req.getParameter("name");
        boolean abs = "on".equals(req.getParameter("abstract"));
        String[] children = req.getParameterValues("children");
        try {
            if (!(session.getWorkspace() instanceof JackrabbitWorkspace)) {
                throw new UnsupportedRepositoryOperationException(I18n.get((HttpServletRequest)request, (String)"The repository does not support managing privileges"));
            }
            PrivilegeManager manager = ((JackrabbitWorkspace)session.getWorkspace()).getPrivilegeManager();
            manager.registerPrivilege(name, abs, children);
        }
        catch (UnsupportedRepositoryOperationException e) {
            this.logger.info("Unsupported repository operation", (Throwable)e);
            res.setStatus(501);
            res.getWriter().write(e.getMessage());
        }
        catch (RepositoryException e) {
            this.logger.error("Error occur registering privilege: " + name, (Throwable)e);
            res.setStatus(500);
            res.getWriter().write(e.getMessage());
        }
    }

    private void doGet(HttpServletRequest req, HttpServletResponse res, Session session) throws ServletException, IOException {
        try {
            if (!(session.getWorkspace() instanceof JackrabbitWorkspace)) {
                throw new UnsupportedRepositoryOperationException(I18n.get((HttpServletRequest)req, (String)"The repository does not support managing privileges"));
            }
            res.setContentType("application/json");
            res.setCharacterEncoding("UTF-8");
            JSONWriter writer = new JSONWriter((Writer)res.getWriter());
            PrivilegeManager manager = ((JackrabbitWorkspace)session.getWorkspace()).getPrivilegeManager();
            Privilege[] privileges = manager.getRegisteredPrivileges();
            Arrays.sort(privileges, new Comparator());
            writer.array();
            for (Privilege p : privileges) {
                PrivilegesServlet.print(p, writer);
            }
            writer.endArray();
        }
        catch (UnsupportedRepositoryOperationException e) {
            this.logger.info("Unsupported repository operation", (Throwable)e);
            res.sendError(501, e.getMessage());
        }
        catch (AccessDeniedException e) {
            this.logger.info("Access denied getting privilege manager", (Throwable)e);
            res.sendError(403);
        }
        catch (RepositoryException e) {
            this.logger.error("Error occur getting privileges", (Throwable)e);
            res.sendError(500, e.getMessage());
        }
        catch (JSONException e) {
            this.logger.error("Error occur getting privileges", (Throwable)e);
            res.sendError(500, e.getMessage());
        }
    }

    private static void print(Privilege privilege, JSONWriter writer) throws JSONException {
        writer.object();
        writer.key("type").value((Object)Privilege.class.getName());
        writer.key("name").value((Object)privilege.getName());
        writer.key("aggregate").value(privilege.isAggregate());
        writer.key("abstract").value(privilege.isAbstract());
        writer.key("declared").array();
        for (Privilege p : privilege.getDeclaredAggregatePrivileges()) {
            PrivilegesServlet.print(p, writer);
        }
        writer.endArray();
        writer.endObject();
    }

    /*
     * This class specifies class file version 49.0 but uses Java 6 signatures.  Assumed Java 6.
     */
    private class Comparator
    implements java.util.Comparator<Privilege> {
        private Comparator() {
        }

        @Override
        public int compare(Privilege o1, Privilege o2) {
            return o1.getName().compareTo(o2.getName());
        }
    }

}