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

com.sun.enterprise.module.maven.HK2GenerateMojo Maven / Gradle / Ivy

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 2010-2011 Oracle and/or its affiliates. All rights reserved.
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License.  You can
 * obtain a copy of the License at
 * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
 * or packager/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at packager/legal/LICENSE.txt.
 *
 * GPL Classpath Exception:
 * Oracle designates this particular file as subject to the "Classpath"
 * exception as provided by Oracle in the GPL Version 2 section of the License
 * file that accompanied this code.
 *
 * Modifications:
 * If applicable, add the following below the License Header, with the fields
 * enclosed by brackets [] replaced by your own identifying information:
 * "Portions Copyright [year] [name of copyright owner]"
 *
 * Contributor(s):
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */
package com.sun.enterprise.module.maven;

import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.project.MavenProject;
import org.apache.maven.model.Dependency;
import org.apache.maven.artifact.Artifact;

import java.io.*;

import java.util.*;
import java.util.jar.*;

import com.sun.enterprise.module.ManifestConstants;
import com.sun.enterprise.module.common_impl.Jar;

import com.sun.hk2.component.InhabitantsFile;

/**
 * Generates a consolidated OSGI bundle with a consolidated 
 * HK2 header
 *
 * @goal hk2-generate
 * @phase prepare-package
 * 
 * @requiresProject true
 * @requiresDependencyResolution compile
 * @author Sivakumar Thyagarajan
 */
/* We use prepare-package as the phase as we need to perform this consolidation before the maven-bundle-plugin's bundle goal gets executed in the package phase.*/

public class HK2GenerateMojo extends AbstractMojo {

	/**
	 * Directory where the manifest will be written
	 * 
	 * @parameter expression="${manifestLocation}"
	 *            default-value="${project.build.outputDirectory}"
	 */
	protected File manifestLocation;

	/**
	 * The maven project.
	 * 
	 * @parameter expression="${project}"
	 * @required
	 * @readonly
	 */
	protected MavenProject project;

	public void execute() throws MojoExecutionException {
		if (project.getDependencyArtifacts() != null) {
			List consolidatedInhabitants = new ArrayList();

			// Create the consolidated inhabitant file contents by
			// going through all dependency artifacts
			for (Artifact a : (Set) project.getDependencyArtifacts()) {
				if (a.getScope() != null && a.getScope().equals("test"))
					continue;
				getLog().info("Dependency Artifact: " + a.getFile().toString());

				try {
					JarFile jf = new JarFile(a.getFile());
					JarEntry je = jf.getJarEntry(InhabitantsFile.PATH);
					if (je == null)
						continue;
					getLog().debug("Dependency Artifact " + a + " has Inhabitants File: " + je);

					Enumeration entries = jf.entries();
					while (entries.hasMoreElements()) {
						JarEntry entry = entries.nextElement();
						if (!entry.isDirectory()
								&& entry.getName().startsWith(
										InhabitantsFile.PATH)) {
							getLog().info("Entry: " + entry.getName());
							consolidatedInhabitants.addAll(loadInhabitants(jf,
									entry));
						}
					}
				} catch (IOException iex) {
					iex.printStackTrace();
				}
			}

		    writeToFile(consolidatedInhabitants);
		}
	}

	private List loadInhabitants(JarFile jf, JarEntry e)
			throws IOException {
		List l = new ArrayList();

		BufferedReader reader = null;
		try {
			DataInputStream in = new DataInputStream(jf.getInputStream(e));
			reader = new BufferedReader(new InputStreamReader(in));
			String line = null;
			while ((line = reader.readLine()) != null) {
				l.add(line);
			}

		} catch (IOException iex) {
			iex.printStackTrace();
		} finally {
			reader.close();
		}
		return l;
	}

	private void writeToFile(List consolidatedInhabitants) {
		// Write the consolidated inhabitant file contents
		// to manifestLocation
		
		//Create Manifest directory. 
		String inhabitantsDir = "" + manifestLocation + File.separatorChar
		+ "META-INF" + File.separatorChar + "inhabitants";
		boolean success = (new File(inhabitantsDir)).mkdirs();
		
		String fileLocation = inhabitantsDir + File.separatorChar + "default";
		getLog().info("Writing consolidated inhabitants to: " + fileLocation);

		BufferedWriter out = null;
		try {
			out = new BufferedWriter(new FileWriter(fileLocation));
			for (String s : consolidatedInhabitants) {
				out.write(s);
				out.newLine();
			}
		} catch (IOException iex) {
			iex.printStackTrace();
		} finally {
			try {
				out.close();
			} catch (IOException iex) {
				//ignore
			}
		}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy