/*
* #%L
* restdoc-doclet
* %%
* 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.doclet;
import static org.apache.commons.lang.StringUtils.trimToNull;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Properties;
import org.apache.log4j.Logger;
/**
* This class manages properties of the web-application documentation was built
* on. The properties are packaged along with the web-application
* <i>generated</i> by documentation.
*/
public class RestDocumentationProperties {
/**
* Log4j logger for this class.
*/
public static final Logger LOGGER = Logger
.getLogger(RestDocumentationProperties.class);
/**
* The name of the file containing the properties.
*/
public static final String FILE = "rd.properties";
/**
* The property containing the artifact-identifier of the web-application
* the documentation was built on.
*/
public static final String ARTIFACT_ID = "project.artifactId";
/**
* The property containing the version of the web-application documentation
* was built on.
*/
public static final String VERSION = "project.version";
/**
* The property containing the build-name of the web-application
* documentation was built on.
*/
public static final String FINAL_NAME = "project.build.finalName";
/**
* The property containing the classifier used while building the
* web-application <i>generated</i> by documentation.
*/
public static final String CLASSIFIER = "project.rd.classifier";
/**
* The property containing the project scm url of the web-application
* documentation was built on.
*/
public static final String SCM_URL = "project.scm.url";
/**
* The property containing the project timestamp of the web-application
* documentation was built on.
*/
public static final String TIMESTAMP = "project.timestamp";
/**
* The artifact-identifier of the web-application documentation was built
* on.
*/
private String artifactId;
/**
* The version of the web-application documentation was built on.
*/
private String version;
/**
* The build-name of the web-application documentation was built on.
*/
private String finalName;
/**
* The classifier used while building the web-application <i>generated</i>
* by documentation.
*/
private String classifier;
/**
* The SCM URL of the web-application documentation was built on.
*/
private String scmUrl;
/**
* The timestamp of the web-application documentation was built on.
*/
private String timestamp;
/**
* No-argument constructor for this class to be used as a bean.
*/
public RestDocumentationProperties() {
super();
}
/**
* Constructs this class by loading the properties from an input-stream.
*
* @param inStream the input-stream where the properties have to be read.
* @throws IOException if the input-stream can't be read.
*/
public RestDocumentationProperties(final InputStream inStream)
throws IOException {
final Properties props = new Properties();
props.load(inStream);
artifactId = props.getProperty(ARTIFACT_ID);
LOGGER.debug(FILE + ": " + ARTIFACT_ID + '=' + artifactId);
version = props.getProperty(VERSION);
LOGGER.debug(FILE + ": " + VERSION + '=' + version);
finalName = props.getProperty(FINAL_NAME);
LOGGER.debug(FILE + ": " + FINAL_NAME + '=' + finalName);
classifier = props.getProperty(CLASSIFIER);
LOGGER.debug(FILE + ": " + CLASSIFIER + '=' + classifier);
scmUrl = props.getProperty(SCM_URL);
LOGGER.debug(FILE + ": " + SCM_URL + '=' + scmUrl);
timestamp = props.getProperty(TIMESTAMP);
LOGGER.debug(FILE + ": " + TIMESTAMP + '=' + timestamp);
}
/**
* Gets the artifact-identifier of the web-application documentation was
* built on.
*
* @return the artifact-identifier.
*/
public String getArtifactId() {
return artifactId;
}
/**
* Sets the artifact-identifier of the web-application documentation was
* built on.
*
* @param artifactId the artifact-identifier.
*/
public void setArtifactId(final String artifactId) {
this.artifactId = trimToNull(artifactId);
}
/**
* Gets the version of the web-application documentation was built on.
*
* @return the version.
*/
public String getVersion() {
return version;
}
/**
* Sets the version of the web-application documentation was built on.
*
* @param version the version.
*/
public void setVersion(final String version) {
this.version = trimToNull(version);
}
/**
* Gets the build-name of the web-application documentation was built on.
*
* @return the build-name.
*/
public String getFinalName() {
return finalName;
}
/**
* Sets the build-name of the web-application documentation was built on.
*
* @param finalName the build-name.
*/
public void setFinalName(final String finalName) {
this.finalName = trimToNull(finalName);
}
/**
* Gets the classifier used while building the web-application
* <i>generated</i> by documentation.
*
* @return the classifier used.
*/
public String getClassifier() {
return classifier;
}
/**
* Sets the classifier used while building the web-application
* <i>generated</i> by documentation.
*
* @param classifier the classifier used.
*/
public void setClassifier(final String classifier) {
this.classifier = classifier;
}
/**
* Gets the SCM URL used while building the web-application <i>generated</i>
* by documentation.
*
* @return SCM URL
*/
public String getScmUrl() {
return scmUrl;
}
/**
* Sets the SCM URL used while building the web-application <i>generated</i>
* by documentation.
*
* @param scmUrl
*/
public void setScmUrl(String scmUrl) {
this.scmUrl = scmUrl;
}
/**
* Gets the build timestamp used while building the web-application
* <i>generated</i> by documentation.
*
* @return build timestamp
*/
public String getTimestamp() {
return timestamp;
}
/**
* Sets the build timestamp used while building the web-application
* <i>generated</i> by documentation.
*
* @param timestamp
*/
public void setTimestamp(String timestamp) {
this.timestamp = timestamp;
}
/**
* Writes the properties in this object to an output-stream.
*
* @param out the output-stream the properties have to be written to.
* @throws IOException if the output-stream can't be written to.
*/
public void store(final OutputStream out) throws IOException {
final Properties props = new Properties();
props.put(ARTIFACT_ID, artifactId);
props.put(VERSION, version);
props.put(FINAL_NAME, finalName);
props.put(CLASSIFIER, classifier);
props.put(SCM_URL, scmUrl);
props.put(TIMESTAMP, timestamp);
props.store(out, "RESTDocumentation properies");
}
}