com.xpn.xwiki.doc.AbstractMandatoryDocumentInitializer.java Source code

Java tutorial

Introduction

Here is the source code for com.xpn.xwiki.doc.AbstractMandatoryDocumentInitializer.java

Source

/*
 * See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */
package com.xpn.xwiki.doc;

import javax.inject.Inject;
import javax.inject.Named;

import org.apache.commons.lang3.StringUtils;
import org.xwiki.component.phase.Initializable;
import org.xwiki.component.phase.InitializationException;
import org.xwiki.model.EntityType;
import org.xwiki.model.reference.DocumentReference;
import org.xwiki.model.reference.DocumentReferenceResolver;
import org.xwiki.model.reference.EntityReference;
import org.xwiki.model.reference.LocalDocumentReference;
import org.xwiki.model.reference.WikiReference;
import org.xwiki.sheet.SheetBinder;
import org.xwiki.wiki.descriptor.WikiDescriptorManager;

import com.xpn.xwiki.user.api.XWikiRightService;

/**
 * Base class for standard mandatory document initializers.
 *
 * @version $Id: ecd913168d2013e2fb01f00ce66c152cb3114924 $
 * @since 9.0RC1
 */
public abstract class AbstractMandatoryDocumentInitializer implements MandatoryDocumentInitializer, Initializable {
    /**
     * Used to associate a document with a document sheet.
     */
    @Inject
    @Named("document")
    protected SheetBinder documentSheetBinder;

    /**
     * Used to get the main wiki.
     */
    @Inject
    protected WikiDescriptorManager wikiDescriptorManager;

    @Inject
    protected DocumentReferenceResolver<EntityReference> resolver;

    /**
     * @see #getDocumentReference()
     */
    private EntityReference reference;

    private String title;

    /**
     * @param reference the reference of the document to update. Can be either local or absolute depending if the
     *            document is associated to a specific wiki or not
     */
    public AbstractMandatoryDocumentInitializer(EntityReference reference) {
        this(reference, null);
    }

    /**
     * @param reference the reference of the document to update. Can be either local or absolute depending if the
     *            document is associated to a specific wiki or not
     * @param title the title of the document
     */
    public AbstractMandatoryDocumentInitializer(EntityReference reference, String title) {
        this.reference = reference;
        this.title = title;
    }

    @Override
    public void initialize() throws InitializationException {
        // If a local reference was specified but isMainWikiOnly() is true, then convert to a main wiki reference.
        if (this.reference != null && this.reference.extractReference(EntityType.WIKI) == null
                && isMainWikiOnly()) {
            synchronized (this) {
                if (this.reference.extractReference(EntityType.WIKI) == null) {
                    // Convert to main wiki reference
                    EntityReference mainWikiEntityReference = this.resolver.resolve(this.reference,
                            new WikiReference(this.wikiDescriptorManager.getMainWikiId()));

                    this.reference = mainWikiEntityReference;
                }
            }
        }
    }

    @Override
    public EntityReference getDocumentReference() {
        return this.reference;
    }

    // Override

    @Override
    public boolean updateDocument(XWikiDocument document) {
        return updateDocumentFields(document, getTitle());
    }

    protected boolean updateTitle(XWikiDocument document) {
        if (StringUtils.isEmpty(document.getTitle())) {
            String returnedTitle = getTitle();

            if (!StringUtils.isEmpty(returnedTitle)) {
                document.setTitle(getTitle());
            }

            return true;
        }

        return false;
    }

    protected String getTitle() {
        return this.title;
    }

    /**
     * @return true if the passed reference should be resolved to the main wiki instead of the local one. The default is
     *         {@code false}. This is ignored if the passed reference already contains the wiki information.
     */
    protected boolean isMainWikiOnly() {
        return false;
    }

    // Helpers

    /**
     * Set the fields of the document passed as parameter. Can generate content for both XWiki Syntax 1.0 and XWiki
     * Syntax 2.0. If new documents are set to be created in XWiki Syntax 1.0 then generate XWiki 1.0 Syntax otherwise
     * generate XWiki Syntax 2.0.
     *
     * @param document the document
     * @param title the page title to set (if null or blank the title won't be set)
     * @return true if the document has been modified, false otherwise
     */
    protected boolean updateDocumentFields(XWikiDocument document, String title) {
        boolean needsUpdate = false;

        if (document.getCreatorReference() == null) {
            document.setCreator(XWikiRightService.SUPERADMIN_USER);
            needsUpdate = true;
        }
        if (document.getAuthorReference() == null) {
            document.setAuthorReference(document.getCreatorReference());
            needsUpdate = true;
        }

        if (document.getParentReference() == null) {
            // Use the current document's space homepage and default document name.
            EntityReference spaceReference = getDocumentReference().extractReference(EntityType.SPACE);
            DocumentReference fullReference = this.resolver.resolve(null, spaceReference);
            EntityReference localReference = new LocalDocumentReference(fullReference);
            document.setParentReference(localReference);
            needsUpdate = true;
        }

        if (StringUtils.isNotEmpty(title) && StringUtils.isBlank(document.getTitle())) {
            document.setTitle(title);
            needsUpdate = true;
        }

        if (!document.isHidden()) {
            document.setHidden(true);
            needsUpdate = true;
        }

        return needsUpdate;
    }

    /**
     * @param value the {@link Boolean} value to convert.
     * @return the converted <code>int</code> value.
     */
    protected int intFromBoolean(Boolean value) {
        return value == null ? -1 : (value.booleanValue() ? 1 : 0);
    }
}