Package com.iggroup.oss.restdoclet.plugin.io

Source Code of com.iggroup.oss.restdoclet.plugin.io.ConfigCopier

/*
* #%L
* restdoc-plugin
* %%
* Copyright (C) 2012 IG Group
* %%
* Licensed 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.
* #L%
*/
package com.iggroup.oss.restdoclet.plugin.io;

import static com.iggroup.oss.restdoclet.doclet.RestDocumentationProperties.FILE;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Calendar;

import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;

import com.iggroup.oss.restdoclet.doclet.RestDocumentationProperties;

/**
* Copies configuration files to the restdoc application
*/
public class ConfigCopier {

   /**
    * The files to be copied to <code>WEB-INF/classes</code> directory.
    */
   public static final String[] RESOURCE_CONFIGS = new String[] {};

   /**
    * The <code>target</code> directories of the module RestDocumentationMojo
    * is running on.
    */
   private transient DirectoryBuilder directories;

   /**
    * Constructs this copier with the <code>target</code> directories of the
    * module RestDocumentationMojo is running on.
    *
    * @param directories the <code>target</code> directories.
    */
   public ConfigCopier(final DirectoryBuilder directories) {
      this.directories = directories;
   }

   /**
    * Copies resource files
    *
    * @throws IOException if the files can't be copied.
    */
   public void copyResourceConfigs() throws IOException {
      for (String config : RESOURCE_CONFIGS) {
         IOUtils.copy(this.getClass().getResourceAsStream(config), new File(
            directories.getClassesDirectory(), config));
      }
   }

   /**
    * Facade method for copying copying configuration-files.
    *
    * @throws IOException if the files can't be copied.
    */
   public void copy() throws IOException {
      copyResourceConfigs();
   }

   /**
    * Creates properties of the restdoc meta data
    *
    * @param artifactId the artifact-identifier.
    * @param version the version.
    * @param finalName the build-name of the module.
    * @param classifier the classifier used while building documentation.
    * @param scmUrl the scm link to the source code
    * @throws IOException if the properties can't be written.
    */
   public void createProperties(final String artifactId, final String version,
                                final String finalName,
                                final String classifier, final String scmUrl)
      throws IOException {
      final RestDocumentationProperties props =
         new RestDocumentationProperties();
      props.setArtifactId(artifactId);
      props.setVersion(version);
      props.setFinalName(finalName);
      props.setClassifier(classifier);
      props.setScmUrl(scmUrl);
      props.setTimestamp(Calendar.getInstance().getTime().toString());
      props.store(new FileOutputStream(new File(directories
         .getClassesDirectory(), FILE)));
   }

   /**
    * {@inheritDoc}
    */
   @Override
   public String toString() {
      return new ToStringBuilder(this, ToStringStyle.SHORT_PREFIX_STYLE)
         .append("directories", directories).toString();
   }

}
TOP

Related Classes of com.iggroup.oss.restdoclet.plugin.io.ConfigCopier

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.