You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@servicemix.apache.org by gn...@apache.org on 2008/01/13 18:54:56 UTC

svn commit: r611610 - in /servicemix/smx4/nmr/trunk: bundles/ jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/ jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/ jbi/deployer/src/main/resources/META-INF/spring/

Author: gnodet
Date: Sun Jan 13 09:54:55 2008
New Revision: 611610

URL: http://svn.apache.org/viewvc?rev=611610&view=rev
Log:
SMX4NMR-5: write a jbi protocol url handler to install the jbi artifact, patch provided by Jeff Yu

Added:
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Connection.java
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/JBIDeploymentListener.java
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Transformer.java
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/URLHandler.java
Removed:
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/JBIDeploymentListener.java
Modified:
    servicemix/smx4/nmr/trunk/bundles/   (props changed)
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/FileUtil.java
    servicemix/smx4/nmr/trunk/jbi/deployer/src/main/resources/META-INF/spring/servicemix-jbi-deployer.xml

Propchange: servicemix/smx4/nmr/trunk/bundles/
------------------------------------------------------------------------------
--- svn:ignore (added)
+++ svn:ignore Sun Jan 13 09:54:55 2008
@@ -0,0 +1,7 @@
+target
+*.iml
+*.ipr
+*.iws
+.classpath
+.project
+.settings

Added: servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Connection.java
URL: http://svn.apache.org/viewvc/servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Connection.java?rev=611610&view=auto
==============================================================================
--- servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Connection.java (added)
+++ servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Connection.java Sun Jan 13 09:54:55 2008
@@ -0,0 +1,72 @@
+/**
+ *
+ * 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.
+ */
+package org.apache.servicemix.jbi.deployer.handler;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.URL;
+import java.net.URLConnection;
+
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.apache.servicemix.jbi.deployer.impl.FileUtil;
+
+
+public class Connection extends URLConnection {
+	
+	private static Log logger = LogFactory.getLog(Connection.class);
+	
+	private URLHandler urlHandler;
+	
+	public Connection(URL url, URLHandler urlHandler) {
+		super(url);
+		this.urlHandler = urlHandler;
+	}
+
+
+	@Override
+	public void connect() throws IOException {
+		
+	}
+	
+	@Override
+	public InputStream getInputStream() throws IOException {
+		try {
+			connect();
+			InputStream targetInputStream = urlHandler.getJbiArtifactURL().openConnection().getInputStream();
+			File jbiZipFile = File.createTempFile("jbi", ".zip");
+			FileOutputStream jbiZip = new FileOutputStream(jbiZipFile);
+			
+			FileUtil.copyInputStream(targetInputStream, jbiZip);
+			jbiZip.close();
+			targetInputStream.close();
+			
+			File jbiBundle = File.createTempFile("jbi", ".jar");
+			Transformer.transformToOSGiBundle(jbiZipFile, jbiBundle);
+			return new FileInputStream(jbiBundle);
+		} catch (Exception e) {
+			logger.error("Error opening jbi protocol artifact", e);
+			throw (IOException) new IOException("Error opening jbi protocol artifact").initCause(e);
+		}
+	}
+	
+
+}

Added: servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/JBIDeploymentListener.java
URL: http://svn.apache.org/viewvc/servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/JBIDeploymentListener.java?rev=611610&view=auto
==============================================================================
--- servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/JBIDeploymentListener.java (added)
+++ servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/JBIDeploymentListener.java Sun Jan 13 09:54:55 2008
@@ -0,0 +1,78 @@
+/*
+ * 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.
+ */
+package org.apache.servicemix.jbi.deployer.handler;
+
+import java.io.File;
+import java.util.jar.Attributes;
+import java.util.jar.JarEntry;
+import java.util.jar.JarFile;
+import java.util.jar.Manifest;
+
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.apache.servicemix.jbi.deployer.impl.FileUtil;
+import org.apache.servicemix.runtime.filemonitor.DeploymentListener;
+
+
+public class JBIDeploymentListener implements DeploymentListener {
+	
+	private static final Log Logger = LogFactory.getLog(JBIDeploymentListener.class);
+	
+	public boolean canHandle(File artifact) {
+		try {
+            // Accept jars and zips
+            if (!artifact.getName().endsWith(".zip") &&
+                !artifact.getName().endsWith(".jar")) {
+                return false;
+            }
+			JarFile jar = new JarFile(artifact);
+			JarEntry entry = jar.getJarEntry("META-INF/jbi.xml");
+            // Only handle JBI artifacts
+            if (entry == null) {
+				return false;
+			}
+            // Only handle non OSGi bundles
+            Manifest m = jar.getManifest();
+            if (m.getMainAttributes().getValue(new Attributes.Name("Bundle-SymbolicName")) != null &&
+                m.getMainAttributes().getValue(new Attributes.Name("Bundle-Version")) != null) {
+                return false;
+            }
+            return true;
+		} catch (Exception e) {
+			return false;
+		}
+	}
+
+	
+	public File handle(File artifact, File tmpDir) {
+		try{
+			String bundleName = artifact.getName().substring(0, artifact.getName().length() -4 ) + ".jar";
+			File destFile = new File(tmpDir, bundleName);
+			if (destFile.exists()) {
+				destFile.delete();
+			}			
+			Transformer.transformToOSGiBundle(artifact, destFile);
+			return destFile;
+			
+		} catch (Exception e) {
+			Logger.error("Failed in transforming the JBI artifact to be OSGified. error is: " + e);
+			return null;
+		}
+	}
+
+
+}

Added: servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Transformer.java
URL: http://svn.apache.org/viewvc/servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Transformer.java?rev=611610&view=auto
==============================================================================
--- servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Transformer.java (added)
+++ servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/Transformer.java Sun Jan 13 09:54:55 2008
@@ -0,0 +1,75 @@
+/*
+ * 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.
+ */
+package org.apache.servicemix.jbi.deployer.handler;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.InputStream;
+import java.util.jar.Attributes;
+import java.util.jar.JarEntry;
+import java.util.jar.JarFile;
+import java.util.jar.JarInputStream;
+import java.util.jar.JarOutputStream;
+import java.util.jar.Manifest;
+
+import org.apache.servicemix.jbi.deployer.descriptor.Descriptor;
+import org.apache.servicemix.jbi.deployer.descriptor.DescriptorFactory;
+import org.apache.servicemix.jbi.deployer.impl.FileUtil;
+
+/**
+ * Helper class to transform JBI artifacts into OSGi bundles
+ */
+public class Transformer {
+
+    public static void transformToOSGiBundle(File jbiArtifact, File jbiBundle) throws Exception {
+    	JarFile jar = new JarFile(jbiArtifact);
+        Manifest m = jar.getManifest();
+        JarEntry jarEntry = jar.getJarEntry("META-INF/jbi.xml");
+        InputStream is = jar.getInputStream(jarEntry);
+        Descriptor desc = DescriptorFactory.buildDescriptor(is);
+
+        String version = m.getMainAttributes().getValue("Implementation-Version");
+        String name = m.getMainAttributes().getValue("Implementation-Title");
+
+        if (desc.getComponent() != null) {
+            name = desc.getComponent().getIdentification().getName();
+        } else if (desc.getSharedLibrary() != null) {
+        	name = desc.getSharedLibrary().getIdentification().getName();
+        } else if (desc.getServiceAssembly() != null) {
+        	name = desc.getServiceAssembly().getIdentification().getName();
+        }
+
+        m.getMainAttributes().put(new Attributes.Name("Bundle-SymbolicName"), name);
+        m.getMainAttributes().put(new Attributes.Name("Bundle-Version"), version);
+
+		JarInputStream jis = new JarInputStream(new FileInputStream(jbiArtifact));
+		JarOutputStream jos = new JarOutputStream(new FileOutputStream(jbiBundle), m);
+
+		JarEntry entry = jis.getNextJarEntry();
+		while (entry != null) {
+		    jos.putNextEntry(entry);
+		    FileUtil.copyInputStream(jis, jos);
+		    jos.closeEntry();
+		    entry = jis.getNextJarEntry();
+		}
+
+		jos.close();
+		jis.close();
+    }
+
+}

Added: servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/URLHandler.java
URL: http://svn.apache.org/viewvc/servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/URLHandler.java?rev=611610&view=auto
==============================================================================
--- servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/URLHandler.java (added)
+++ servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/handler/URLHandler.java Sun Jan 13 09:54:55 2008
@@ -0,0 +1,53 @@
+/**
+ *
+ * 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.
+ */
+package org.apache.servicemix.jbi.deployer.handler;
+
+import java.io.IOException;
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.net.URLConnection;
+
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.osgi.service.url.AbstractURLStreamHandlerService;
+
+
+public class URLHandler extends AbstractURLStreamHandlerService {
+	
+	private static Log logger = LogFactory.getLog(URLHandler.class);
+	
+	private static String SYNTAX = "jbi: jbi-jar-uri";
+	
+	private URL jbiArtifactURL;
+	
+	@Override
+	public URLConnection openConnection(URL url) throws IOException {
+		if (url.getPath() == null || url.getPath().trim().length() == 0) {
+			throw new MalformedURLException ("Path can not be null or empty. Syntax: " + SYNTAX );
+		}
+		jbiArtifactURL = new URL(url.getPath());
+		
+		logger.debug("JBI artifact URL is: [" + jbiArtifactURL + "]");
+		return new Connection(url, this);
+	}
+	
+	public URL getJbiArtifactURL() {
+		return jbiArtifactURL;
+	}
+
+}

Modified: servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/FileUtil.java
URL: http://svn.apache.org/viewvc/servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/FileUtil.java?rev=611610&r1=611609&r2=611610&view=diff
==============================================================================
--- servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/FileUtil.java (original)
+++ servicemix/smx4/nmr/trunk/jbi/deployer/src/main/java/org/apache/servicemix/jbi/deployer/impl/FileUtil.java Sun Jan 13 09:54:55 2008
@@ -25,11 +25,17 @@
 import java.io.InputStream;
 import java.io.OutputStream;
 import java.net.URL;
-import java.util.Enumeration;
+import java.util.jar.Attributes;
+import java.util.jar.JarEntry;
+import java.util.jar.JarFile;
+import java.util.jar.JarInputStream;
+import java.util.jar.JarOutputStream;
+import java.util.jar.Manifest;
 import java.util.zip.ZipEntry;
-import java.util.zip.ZipFile;
 import java.util.zip.ZipInputStream;
-import java.util.zip.ZipOutputStream;
+
+import org.apache.servicemix.jbi.deployer.descriptor.Descriptor;
+import org.apache.servicemix.jbi.deployer.descriptor.DescriptorFactory;
 
 /**
  * File utilities
@@ -71,7 +77,6 @@
             out.write(buffer, 0, len);
             len = in.read(buffer);
         }
-        out.close();
     }
 
     /**
@@ -132,7 +137,9 @@
                 throw new IOException("Could not create directory: " + file.getParentFile());
             }
             if (!entry.isDirectory()) {
-                copyInputStream(zip, new BufferedOutputStream(new FileOutputStream(file)));
+            	BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(file)); 
+                copyInputStream(zip, bos);
+                bos.close();
             } else {
                 if (!buildDirectory(file)) {
                     throw new IOException("Could not create directory: " + file);

Modified: servicemix/smx4/nmr/trunk/jbi/deployer/src/main/resources/META-INF/spring/servicemix-jbi-deployer.xml
URL: http://svn.apache.org/viewvc/servicemix/smx4/nmr/trunk/jbi/deployer/src/main/resources/META-INF/spring/servicemix-jbi-deployer.xml?rev=611610&r1=611609&r2=611610&view=diff
==============================================================================
--- servicemix/smx4/nmr/trunk/jbi/deployer/src/main/resources/META-INF/spring/servicemix-jbi-deployer.xml (original)
+++ servicemix/smx4/nmr/trunk/jbi/deployer/src/main/resources/META-INF/spring/servicemix-jbi-deployer.xml Sun Jan 13 09:54:55 2008
@@ -34,7 +34,16 @@
     </bean>
 
     <!-- Deployment listener -->
-    <bean id="listener" class="org.apache.servicemix.jbi.deployer.impl.JBIDeploymentListener" />
+    <bean id="listener" class="org.apache.servicemix.jbi.deployer.handler.JBIDeploymentListener" />
+    
+    <!-- JBI Handler -->
+    <bean id="jbiHandler" class="org.apache.servicemix.jbi.deployer.handler.URLHandler" />
+
+    <osgi:service ref="jbiHandler" interface="org.osgi.service.url.URLStreamHandlerService">
+    	<osgi:service-properties>
+            <entry key="url.handler.protocol" value="jbi"/>
+        </osgi:service-properties>
+    </osgi:service>
 
     <osgi:service ref="listener" interface="org.apache.servicemix.runtime.filemonitor.DeploymentListener" />