All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bsc.reporting.renderer.ScmRenderer Maven / Gradle / Ivy

Go to download

plugin that document a project (using maven site style) and send result to a live confluence site [http://www.atlassian.com/software/confluence/]

There is a newer version: 8.0-beta1
Show newest version
package org.bsc.reporting.renderer;

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
import org.apache.commons.lang.SystemUtils;
import org.apache.maven.doxia.sink.Sink;
import org.apache.maven.model.Model;
import org.apache.maven.model.Scm;
import org.apache.maven.plugin.logging.Log;
import org.apache.maven.scm.manager.NoSuchScmProviderException;
import org.apache.maven.scm.manager.ScmManager;
import org.apache.maven.scm.provider.cvslib.repository.CvsScmProviderRepository;
import org.apache.maven.scm.provider.git.repository.GitScmProviderRepository;
import org.apache.maven.scm.provider.hg.repository.HgScmProviderRepository;
import org.apache.maven.scm.provider.perforce.repository.PerforceScmProviderRepository;
import org.apache.maven.scm.provider.starteam.repository.StarteamScmProviderRepository;
import org.apache.maven.scm.provider.svn.repository.SvnScmProviderRepository;
import org.apache.maven.scm.repository.ScmRepository;
import org.apache.maven.scm.repository.ScmRepositoryException;
import org.codehaus.plexus.i18n.I18N;
import org.codehaus.plexus.util.StringUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.Locale;
import org.apache.maven.report.projectinfo.AbstractProjectInfoRenderer;
import org.bsc.reporting.sink.ConfluenceSink;

/**
 * Scm renderer class
 */
public class ScmRenderer extends AbstractProjectInfoRenderer {

    private Log log;

    private Model model;

    private ScmManager scmManager;

    /**
     * To support more SCM
     */
    private String anonymousConnection;

    private String devConnection;

    private String checkoutDirectoryName;

    private String webAccessUrl;

    private String scmTag;

    public ScmRenderer(Log log, 
                ScmManager scmManager, 
                Sink sink, 
                Model model, 
                I18N i18n, 
                Locale locale,
                String checkoutDirName, 
                String webAccessUrl, 
                String anonymousConnection, 
                String devConnection,
                String scmTag) {
        super(sink, i18n, locale);

        this.log = log;

        this.scmManager = scmManager;

        this.model = model;

        this.checkoutDirectoryName = checkoutDirName;

        this.webAccessUrl = webAccessUrl;

        this.anonymousConnection = anonymousConnection;

        this.devConnection = devConnection;

        this.scmTag = scmTag;
    }

    @Override
    protected String getI18Nsection() {
        return "scm";
    }

    @Override
    public void renderBody() {
        Scm scm = model.getScm();
        if (scm == null || StringUtils.isEmpty(anonymousConnection)
                && StringUtils.isEmpty(devConnection)
                && StringUtils.isEmpty(scm.getUrl())) {
            startSection(getTitle());

            paragraph(getI18nString("noscm"));

            endSection();

            return;
        }
        
        // fix issue #141
        startSection( "Source Control Management");

        ScmRepository anonymousRepository = getScmRepository(anonymousConnection);
        ScmRepository devRepository = getScmRepository(devConnection);

        // Overview section
        renderOverviewSection(anonymousRepository, devRepository);

        // Web access section
        renderWebAccessSection(webAccessUrl);

        // Anonymous access section if needed
        renderAnonymousAccessSection(anonymousRepository);

        // Developer access section
        renderDeveloperAccessSection(devRepository);

        // Access from behind a firewall section if needed
        renderAccessBehindFirewallSection(devRepository);

        // Access through a proxy section if needed
        renderAccessThroughProxySection(anonymousRepository, devRepository);
        
        endSection();
    }

    /**
     * Render the overview section
     *
     * @param anonymousRepository the anonymous repository
     * @param devRepository the developer repository
     */
    private void renderOverviewSection(ScmRepository anonymousRepository, ScmRepository devRepository) {
        startSection(getI18nString("overview.title"));

        if (isScmSystem(anonymousRepository, "clearcase") || isScmSystem(devRepository, "clearcase")) {
            sink.paragraph();
            linkPatternedText(getI18nString("clearcase.intro"));
            sink.paragraph_();
        } else if (isScmSystem(anonymousRepository, "cvs") || isScmSystem(devRepository, "cvs")) {
            sink.paragraph();
            linkPatternedText(getI18nString("cvs.intro"));
            sink.paragraph_();
        } else if (isScmSystem(anonymousRepository, "git") || isScmSystem(devRepository, "git")) {
            sink.paragraph();
            linkPatternedText(getI18nString("git.intro"));
            sink.paragraph_();
        } else if (isScmSystem(anonymousRepository, "hg") || isScmSystem(devRepository, "hg")) {
            sink.paragraph();
            linkPatternedText(getI18nString("hg.intro"));
            sink.paragraph_();
        } else if (isScmSystem(anonymousRepository, "perforce") || isScmSystem(devRepository, "perforce")) {
            sink.paragraph();
            linkPatternedText(getI18nString("perforce.intro"));
            sink.paragraph_();
        } else if (isScmSystem(anonymousRepository, "starteam") || isScmSystem(devRepository, "starteam")) {
            sink.paragraph();
            linkPatternedText(getI18nString("starteam.intro"));
            sink.paragraph_();
        } else if (isScmSystem(anonymousRepository, "svn") || isScmSystem(devRepository, "svn")) {
            sink.paragraph();
            linkPatternedText(getI18nString("svn.intro"));
            sink.paragraph_();
        } else {
            paragraph(getI18nString("general.intro"));
        }

        endSection();
    }

    /**
     * Render the web access section
     *
     * @param scmUrl The URL to the project's browsable repository.
     */
    private void renderWebAccessSection(final String scmUrl) {
        startSection(getI18nString("webaccess.title"));

        if (StringUtils.isEmpty(scmUrl)) {
            paragraph(getI18nString("webaccess.nourl"));
        } else {
            paragraph(getI18nString("webaccess.url"));
            
            ConfluenceSink.pushCommandBlock(sink, ConfluenceSink.Command.PANEL, new Runnable() {

                @Override
                public void run() {
                    verbatimLink(scmUrl, scmUrl);
                }
                
            });
        }

        endSection();
    }

    /**
     * Render the anonymous access section depending the repository.
     * 

* Note: ClearCase, Starteam et Perforce seems to have no anonymous access. *

* * @param anonymousRepository the anonymous repository */ private void renderAnonymousAccessSection(ScmRepository anonymousRepository) { if (isScmSystem(anonymousRepository, "clearcase") || isScmSystem(anonymousRepository, "perforce") || isScmSystem(anonymousRepository, "starteam") || StringUtils.isEmpty(anonymousConnection)) { return; } startSection(getI18nString("anonymousaccess.title")); if (anonymousRepository != null && isScmSystem(anonymousRepository, "cvs")) { CvsScmProviderRepository cvsRepo = (CvsScmProviderRepository) anonymousRepository.getProviderRepository(); anonymousAccessCVS(cvsRepo); } else if (anonymousRepository != null && isScmSystem(anonymousRepository, "git")) { GitScmProviderRepository gitRepo = (GitScmProviderRepository) anonymousRepository.getProviderRepository(); anonymousAccessGit(gitRepo); } else if (anonymousRepository != null && isScmSystem(anonymousRepository, "hg")) { HgScmProviderRepository hgRepo = (HgScmProviderRepository) anonymousRepository.getProviderRepository(); anonymousAccessMercurial(hgRepo); } else if (anonymousRepository != null && isScmSystem(anonymousRepository, "svn")) { SvnScmProviderRepository svnRepo = (SvnScmProviderRepository) anonymousRepository.getProviderRepository(); anonymousAccessSubversion(svnRepo); } else { paragraph(getI18nString("anonymousaccess.general.intro")); verbatimText(anonymousConnection.substring(4)); } endSection(); } /** * Render the developer access section * * @param devRepository the dev repository */ private void renderDeveloperAccessSection(ScmRepository devRepository) { if (StringUtils.isEmpty(devConnection)) { return; } startSection(getI18nString("devaccess.title")); if (devRepository != null && isScmSystem(devRepository, "clearcase")) { developerAccessClearCase(); } else if (devRepository != null && isScmSystem(devRepository, "cvs")) { CvsScmProviderRepository cvsRepo = (CvsScmProviderRepository) devRepository.getProviderRepository(); developerAccessCVS(cvsRepo); } else if (devRepository != null && isScmSystem(devRepository, "git")) { GitScmProviderRepository gitRepo = (GitScmProviderRepository) devRepository.getProviderRepository(); developerAccessGit(gitRepo); } else if (devRepository != null && isScmSystem(devRepository, "hg")) { HgScmProviderRepository hgRepo = (HgScmProviderRepository) devRepository.getProviderRepository(); developerAccessMercurial(hgRepo); } else if (devRepository != null && isScmSystem(devRepository, "perforce")) { PerforceScmProviderRepository perforceRepo = (PerforceScmProviderRepository) devRepository.getProviderRepository(); developerAccessPerforce(perforceRepo); } else if (devRepository != null && isScmSystem(devRepository, "starteam")) { StarteamScmProviderRepository starteamRepo = (StarteamScmProviderRepository) devRepository.getProviderRepository(); developerAccessStarteam(starteamRepo); } else if (devRepository != null && isScmSystem(devRepository, "svn")) { SvnScmProviderRepository svnRepo = (SvnScmProviderRepository) devRepository.getProviderRepository(); developerAccessSubversion(svnRepo); } else { paragraph(getI18nString("devaccess.general.intro")); verbatimText(devConnection.substring(4)); } endSection(); } /** * Render the access from behind a firewall section * * @param devRepository the dev repository */ private void renderAccessBehindFirewallSection(ScmRepository devRepository) { startSection(getI18nString("accessbehindfirewall.title")); if (devRepository != null && isScmSystem(devRepository, "svn")) { SvnScmProviderRepository svnRepo = (SvnScmProviderRepository) devRepository.getProviderRepository(); paragraph(getI18nString("accessbehindfirewall.svn.intro")); verbatimText("$ svn checkout " + svnRepo.getUrl() + " " + checkoutDirectoryName); } else if (devRepository != null && isScmSystem(devRepository, "cvs")) { linkPatternedText(getI18nString("accessbehindfirewall.cvs.intro")); } else { paragraph(getI18nString("accessbehindfirewall.general.intro")); } endSection(); } /** * Render the access from behind a firewall section * * @param anonymousRepository the anonymous repository * @param devRepository the dev repository */ private void renderAccessThroughProxySection(ScmRepository anonymousRepository, ScmRepository devRepository) { if (isScmSystem(anonymousRepository, "svn") || isScmSystem(devRepository, "svn")) { startSection(getI18nString("accessthroughtproxy.title")); paragraph(getI18nString("accessthroughtproxy.svn.intro1")); paragraph(getI18nString("accessthroughtproxy.svn.intro2")); paragraph(getI18nString("accessthroughtproxy.svn.intro3")); verbatimText("[global]" + SystemUtils.LINE_SEPARATOR + "http-proxy-host = your.proxy.name" + SystemUtils.LINE_SEPARATOR + "http-proxy-port = 3128" + SystemUtils.LINE_SEPARATOR); endSection(); } } // Clearcase /** * Create the documentation to provide an developer access with a * Clearcase SCM. For example, generate the following command * line: *

* cleartool checkout module *

*/ private void developerAccessClearCase() { paragraph(getI18nString("devaccess.clearcase.intro")); verbatimText("$ cleartool checkout "); } // CVS // CHECKSTYLE_OFF: LineLength /** * Create the documentation to provide an anonymous access with a * CVS SCM. For example, generate the following command line: *

* cvs -d :pserver:[email protected]:/home/cvspublic login *

*

* cvs -z3 -d :pserver:[email protected]:/home/cvspublic co * maven-plugins/dist *

* * @param cvsRepo * @see https://www.cvshome.org/docs/manual/cvs-1.12.12/cvs_16.html#SEC115 */ // CHECKSTYLE_ON: LineLength private void anonymousAccessCVS(CvsScmProviderRepository cvsRepo) { paragraph(getI18nString("anonymousaccess.cvs.intro")); verbatimText("$ cvs -d " + cvsRepo.getCvsRoot() + " login" + SystemUtils.LINE_SEPARATOR + "$ cvs -z3 -d " + cvsRepo.getCvsRoot() + " co " + cvsRepo.getModule()); } // Git private void gitClone(String url) { // in the future, git scm url should support both repository + path: at the moment, require a hack // to remove path added to repository int index = url.indexOf(".git/"); if (index > 0) { url = url.substring(0, index + 4); } boolean head = StringUtils.isEmpty(scmTag) || "HEAD".equals(scmTag); verbatimText("$ git clone " + (head ? "" : ("--branch " + scmTag + ' ')) + url); } /** * Create the documentation to provide an anonymous access with a * Git SCM. For example, generate the following command line: *

* git clone uri *

* * @param gitRepo */ private void anonymousAccessGit(GitScmProviderRepository gitRepo) { sink.paragraph(); linkPatternedText(getI18nString("anonymousaccess.git.intro")); sink.paragraph_(); gitClone(gitRepo.getFetchUrl()); } // Mercurial /** * Create the documentation to provide an anonymous access with a * Mercurial SCM. For example, generate the following command * line: *

* hg clone uri *

* * @param hgRepo */ private void anonymousAccessMercurial(HgScmProviderRepository hgRepo) { sink.paragraph(); linkPatternedText(getI18nString("anonymousaccess.hg.intro")); sink.paragraph_(); verbatimText("$ hg clone " + hgRepo.getURI()); } // CHECKSTYLE_OFF: LineLength /** * Create the documentation to provide an developer access with a * CVS SCM. For example, generate the following command line: *

* cvs -d :pserver:[email protected]:/home/cvs login *

*

* cvs -z3 -d :ext:[email protected]:/home/cvs co maven-plugins/dist *

* * @param cvsRepo * @see https://www.cvshome.org/docs/manual/cvs-1.12.12/cvs_16.html#SEC115 */ // CHECKSTYLE_ON: LineLength private void developerAccessCVS(CvsScmProviderRepository cvsRepo) { paragraph(getI18nString("devaccess.cvs.intro")); // Safety: remove the username if present String cvsRoot = StringUtils.replace(cvsRepo.getCvsRoot(), cvsRepo.getUser(), "username"); verbatimText("$ cvs -d " + cvsRoot + " login" + SystemUtils.LINE_SEPARATOR + "$ cvs -z3 -d " + cvsRoot + " co " + cvsRepo.getModule()); } // Git /** * Create the documentation to provide an developer access with a * Git SCM. For example, generate the following command line: *

* git clone repo *

* * @param gitRepo */ private void developerAccessGit(GitScmProviderRepository gitRepo) { sink.paragraph(); linkPatternedText(getI18nString("devaccess.git.intro")); sink.paragraph_(); gitClone(gitRepo.getPushUrl()); } // Mercurial /** * Create the documentation to provide an developer access with a * Mercurial SCM. For example, generate the following command * line: *

* hg clone repo *

* * @param hgRepo */ private void developerAccessMercurial(HgScmProviderRepository hgRepo) { sink.paragraph(); linkPatternedText(getI18nString("devaccess.hg.intro")); sink.paragraph_(); verbatimText("$ hg clone " + hgRepo.getURI()); } // Perforce // CHECKSTYLE_OFF: LineLength /** * Create the documentation to provide an developer access with a * Perforce SCM. For example, generate the following command * line: *

* p4 -H hostname -p port -u username -P password path *

*

* p4 -H hostname -p port -u username -P password path submit -c changement *

* * @param perforceRepo * @see http://www.perforce.com/ * perforce /doc.051/manuals/cmdref/index.html */ // CHECKSTYLE_ON: LineLength private void developerAccessPerforce(PerforceScmProviderRepository perforceRepo) { paragraph(getI18nString("devaccess.perforce.intro")); StringBuilder command = new StringBuilder(); command.append("$ p4"); if (!StringUtils.isEmpty(perforceRepo.getHost())) { command.append(" -H ").append(perforceRepo.getHost()); } if (perforceRepo.getPort() > 0) { command.append(" -p ").append(perforceRepo.getPort()); } command.append(" -u username"); command.append(" -P password"); command.append(" "); command.append(perforceRepo.getPath()); command.append(SystemUtils.LINE_SEPARATOR); command.append("$ p4 submit -c \"A comment\""); verbatimText(command.toString()); } // Starteam /** * Create the documentation to provide an developer access with a * Starteam SCM. For example, generate the following command * line: *

* stcmd co -x -nologo -stop -p myusername:mypassword@myhost:1234/projecturl * -is *

*

* stcmd ci -x -nologo -stop -p myusername:mypassword@myhost:1234/projecturl * -f NCI -is *

* * @param starteamRepo */ private void developerAccessStarteam(StarteamScmProviderRepository starteamRepo) { paragraph(getI18nString("devaccess.starteam.intro")); StringBuilder command = new StringBuilder(); // Safety: remove the username/password if present String fullUrl = StringUtils.replace(starteamRepo.getFullUrl(), starteamRepo.getUser(), "username"); fullUrl = StringUtils.replace(fullUrl, starteamRepo.getPassword(), "password"); command.append("$ stcmd co -x -nologo -stop -p "); command.append(fullUrl); command.append(" -is"); command.append(SystemUtils.LINE_SEPARATOR); command.append("$ stcmd ci -x -nologo -stop -p "); command.append(fullUrl); command.append(" -f NCI -is"); verbatimText(command.toString()); } // Subversion /** * Create the documentation to provide an anonymous access with a * Subversion SCM. For example, generate the following command * line: *

* svn checkout http://svn.apache.org/repos/asf/maven/components/trunk maven *

* * @param svnRepo * @see *
http://svnbook.red-bean.com/ */ private void anonymousAccessSubversion(SvnScmProviderRepository svnRepo) { paragraph(getI18nString("anonymousaccess.svn.intro")); verbatimText("$ svn checkout " + svnRepo.getUrl() + " " + checkoutDirectoryName); } /** * Create the documentation to provide an developer access with a * Subversion SCM. For example, generate the following command * line: *

* svn checkout https://svn.apache.org/repos/asf/maven/components/trunk * maven *

*

* svn commit --username your-username -m "A message" *

* * @param svnRepo * @see * http://svnbook.red-bean.com/ */ private void developerAccessSubversion(SvnScmProviderRepository svnRepo) { if (svnRepo.getUrl() != null) { if (svnRepo.getUrl().startsWith("https://")) { paragraph(getI18nString("devaccess.svn.intro1.https")); } else if (svnRepo.getUrl().startsWith("svn://")) { paragraph(getI18nString("devaccess.svn.intro1.svn")); } else if (svnRepo.getUrl().startsWith("svn+ssh://")) { paragraph(getI18nString("devaccess.svn.intro1.svnssh")); } else { paragraph(getI18nString("devaccess.svn.intro1.other")); } } StringBuilder sb = new StringBuilder(); sb.append("$ svn checkout ").append(svnRepo.getUrl()).append(" ").append(checkoutDirectoryName); verbatimText(sb.toString()); paragraph(getI18nString("devaccess.svn.intro2")); sb = new StringBuilder(); sb.append("$ svn commit --username your-username -m \"A message\""); verbatimText(sb.toString()); } /** * Return a SCM repository defined by a given url * * @param scmUrl an SCM URL * @return a valid SCM repository or null */ @SuppressWarnings("unchecked") public ScmRepository getScmRepository(String scmUrl) { if (StringUtils.isEmpty(scmUrl)) { return null; } ScmRepository repo = null; List messages = new ArrayList(); try { messages.addAll(scmManager.validateScmRepository(scmUrl)); } catch (Exception e) { messages.add(e.getMessage()); } if (messages.size() > 0) { StringBuilder sb = new StringBuilder(); boolean isIntroAdded = false; for (String msg : messages) { // Ignore NoSuchScmProviderException msg // See impl of AbstractScmManager#validateScmRepository() if (msg.startsWith("No such provider")) { continue; } if (!isIntroAdded) { sb.append("This SCM url '"); sb.append(scmUrl); sb.append("' is invalid due to the following errors:"); sb.append(SystemUtils.LINE_SEPARATOR); isIntroAdded = true; } sb.append(" * "); sb.append(msg); sb.append(SystemUtils.LINE_SEPARATOR); } if (StringUtils.isNotEmpty(sb.toString())) { sb.append("For more information about SCM URL Format, please refer to: " + "http://maven.apache.org/scm/scm-url-format.html"); throw new IllegalArgumentException(sb.toString()); } } try { repo = scmManager.makeScmRepository(scmUrl); } catch (NoSuchScmProviderException e) { if (log.isDebugEnabled()) { log.debug(e.getMessage(), e); } } catch (ScmRepositoryException e) { if (log.isDebugEnabled()) { log.debug(e.getMessage(), e); } } catch (Exception e) { // Should be already catched if (log.isDebugEnabled()) { log.debug(e.getMessage(), e); } } return repo; } /** * Convenience method that return true is the defined * SCM repository is a known provider. *

* Currently, we fully support ClearCase, CVS, Git, Perforce, Mercurial, * Starteam and Subversion by the maven-scm-providers component. *

* * @param scmRepository a SCM repository * @param scmProvider a SCM provider name * @return true if the provider of the given SCM repository is equal to the * given scm provider. * @see * maven-scm-providers */ private static boolean isScmSystem(ScmRepository scmRepository, String scmProvider) { if (StringUtils.isEmpty(scmProvider)) { return false; } if (scmRepository != null && scmProvider.equalsIgnoreCase(scmRepository.getProvider())) { return true; } return false; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy