UploadedPackagesInventoryPrinter.java 6.92 KB
/*
 * Decompiled with CFR 0_118.
 * 
 * Could not load the following classes:
 *  javax.jcr.Session
 *  org.apache.felix.inventory.Format
 *  org.apache.felix.inventory.InventoryPrinter
 *  org.apache.felix.scr.annotations.Component
 *  org.apache.felix.scr.annotations.Properties
 *  org.apache.felix.scr.annotations.Property
 *  org.apache.felix.scr.annotations.Reference
 *  org.apache.felix.scr.annotations.Service
 *  org.apache.jackrabbit.vault.packaging.Dependency
 *  org.apache.jackrabbit.vault.packaging.DependencyUtil
 *  org.apache.jackrabbit.vault.packaging.JcrPackage
 *  org.apache.jackrabbit.vault.packaging.JcrPackageDefinition
 *  org.apache.jackrabbit.vault.packaging.JcrPackageManager
 *  org.apache.jackrabbit.vault.packaging.PackageId
 *  org.apache.jackrabbit.vault.packaging.Packaging
 *  org.apache.jackrabbit.vault.packaging.VersionRange
 *  org.apache.sling.api.resource.ResourceResolver
 *  org.apache.sling.api.resource.ResourceResolverFactory
 *  org.slf4j.Logger
 *  org.slf4j.LoggerFactory
 */
package com.adobe.granite.infocollector.impl;

import java.io.PrintWriter;
import java.util.Calendar;
import java.util.Collection;
import java.util.List;
import javax.jcr.Session;
import org.apache.felix.inventory.Format;
import org.apache.felix.inventory.InventoryPrinter;
import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Properties;
import org.apache.felix.scr.annotations.Property;
import org.apache.felix.scr.annotations.Reference;
import org.apache.felix.scr.annotations.Service;
import org.apache.jackrabbit.vault.packaging.Dependency;
import org.apache.jackrabbit.vault.packaging.DependencyUtil;
import org.apache.jackrabbit.vault.packaging.JcrPackage;
import org.apache.jackrabbit.vault.packaging.JcrPackageDefinition;
import org.apache.jackrabbit.vault.packaging.JcrPackageManager;
import org.apache.jackrabbit.vault.packaging.PackageId;
import org.apache.jackrabbit.vault.packaging.Packaging;
import org.apache.jackrabbit.vault.packaging.VersionRange;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.resource.ResourceResolverFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Component(name="com.adobe.granite.infocollector.UploadedPackages")
@Service(value={InventoryPrinter.class})
@Properties(value={@Property(name="felix.inventory.printer.name", value={"uploaded-packages"}), @Property(name="felix.inventory.printer.title", value={"Uploaded Packages"})})
public final class UploadedPackagesInventoryPrinter
implements InventoryPrinter {
    private final Logger logger;
    @Reference
    private Packaging packaging;
    @Reference
    private ResourceResolverFactory resourceResolverFactory;

    public UploadedPackagesInventoryPrinter() {
        this.logger = LoggerFactory.getLogger(this.getClass());
    }

    public void print(PrintWriter printWriter, Format format, boolean isZip) {
        try {
            Session session = (Session)this.resourceResolverFactory.getThreadResourceResolver().adaptTo(Session.class);
            JcrPackageManager packageManager = this.packaging.getPackageManager(session);
            List jcrPackages = packageManager.listPackages();
            DependencyUtil.sortPackages((Collection)jcrPackages);
            printWriter.println(String.format("Found %s uploaded packages%n", jcrPackages.size()));
            for (JcrPackage jcrPackage : jcrPackages) {
                JcrPackageDefinition definition = jcrPackage.getDefinition();
                printWriter.println(String.format("[%s] %s", new Object[]{definition.getId(), definition.getDescription()}));
                UploadedPackagesInventoryPrinter.printStatus(printWriter, jcrPackage.isValid(), "valid");
                UploadedPackagesInventoryPrinter.printStatus(printWriter, jcrPackage.isInstalled(), "installed");
                UploadedPackagesInventoryPrinter.printStatus(printWriter, jcrPackage.isSealed(), "sealed");
                UploadedPackagesInventoryPrinter.printOperation(printWriter, "Created", definition.getCreated(), definition.getCreatedBy());
                UploadedPackagesInventoryPrinter.printOperation(printWriter, "Last modified", definition.getLastModified(), definition.getLastModifiedBy());
                UploadedPackagesInventoryPrinter.printOperation(printWriter, "Last unpacked", definition.getLastUnpacked(), definition.getLastUnpackedBy());
                UploadedPackagesInventoryPrinter.printOperation(printWriter, "Last wrapped", definition.getLastWrapped(), definition.getLastWrappedBy());
                UploadedPackagesInventoryPrinter.printOperation(printWriter, "Last unwrapped", definition.getLastUnwrapped(), definition.getLastUnwrappedBy());
                Dependency[] dependencies = definition.getDependencies();
                if (dependencies != null && dependencies.length != 0) {
                    printWriter.println("    * Dependencies:");
                    for (int i = 0; i < dependencies.length; ++i) {
                        Dependency dependency = dependencies[i];
                        Object[] arrobject = new Object[4];
                        arrobject[0] = i == dependencies.length - 1 ? "\u2514\u2500\u2500" : "\u251c\u2500\u2500";
                        arrobject[1] = dependency.getGroup();
                        arrobject[2] = dependency.getName();
                        arrobject[3] = dependency.getRange();
                        printWriter.println(String.format("        %s %s:%s:%s", arrobject));
                    }
                }
                printWriter.println();
            }
        }
        catch (Exception e) {
            this.logger.error("Impossible to enlist all installed packages, please read the root cause", (Throwable)e);
        }
    }

    private static void printStatus(PrintWriter printWriter, boolean status, String statusLabel) {
        Object[] arrobject = new Object[2];
        arrobject[0] = status ? "" : "NOT ";
        arrobject[1] = statusLabel;
        printWriter.println(String.format("    * Package is %s%s", arrobject));
    }

    private static void printOperation(PrintWriter printWriter, String operation, Calendar date, String operator) {
        if (date != null && operator != null) {
            printWriter.println(String.format("    * %1$s on %2$tA %2$tm %2$tB, %2$tY at %2$tr by %3$s", operation, date, operator));
        }
    }

    protected void bindPackaging(Packaging packaging) {
        this.packaging = packaging;
    }

    protected void unbindPackaging(Packaging packaging) {
        if (this.packaging == packaging) {
            this.packaging = null;
        }
    }

    protected void bindResourceResolverFactory(ResourceResolverFactory resourceResolverFactory) {
        this.resourceResolverFactory = resourceResolverFactory;
    }

    protected void unbindResourceResolverFactory(ResourceResolverFactory resourceResolverFactory) {
        if (this.resourceResolverFactory == resourceResolverFactory) {
            this.resourceResolverFactory = null;
        }
    }
}