| /* |
| * 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.felix.mosgi.jmx.registry.mx4j.tools.naming; |
| |
| import java.rmi.registry.LocateRegistry; |
| import java.rmi.registry.Registry; |
| import java.rmi.server.UnicastRemoteObject; |
| |
| import org.osgi.framework.BundleActivator; |
| import org.osgi.framework.BundleContext; |
| import org.osgi.framework.BundleException; |
| import org.osgi.framework.Constants; |
| import org.osgi.framework.ServiceReference; |
| import org.osgi.framework.ServiceRegistration; |
| |
| import javax.management.ObjectName; |
| |
| import org.osgi.service.log.LogService; |
| |
| import org.apache.felix.framework.cache.BundleCache; |
| |
| public class NamingService implements BundleActivator,NamingServiceIfc { |
| private String version=null; |
| private ObjectName namingServiceName=null; |
| |
| private ServiceRegistration sReg=null; |
| private Registry m_registry=null; |
| private BundleContext bc=null; |
| |
| public void start(BundleContext bc) throws Exception { |
| this.version=(String)bc.getBundle().getHeaders().get(Constants.BUNDLE_VERSION); |
| this.bc=bc; |
| String profile=bc.getProperty(BundleCache.CACHE_PROFILE_PROP); |
| if (profile==null){ |
| profile=System.getProperty(BundleCache.CACHE_PROFILE_PROP); |
| } |
| String rmiPortS=bc.getProperty("mosgi.jmxconsole.rmiport."+profile); |
| int rmiPort=1099; |
| if (rmiPortS!=null){ |
| rmiPort=Integer.parseInt(rmiPortS); |
| } |
| try { |
| this.log(LogService.LOG_INFO, "Running rmiregistry on "+rmiPort,null); |
| Thread.currentThread().setContextClassLoader(this.getClass().getClassLoader()); //!! Absolutely nececary for RMIClassLoading to work |
| m_registry=LocateRegistry.createRegistry(rmiPort); |
| //java.rmi.server.RemoteServer.setLog(System.out); |
| } catch (Exception e) { |
| this.bc=null; |
| throw new BundleException("Impossible to start rmiregistry"); |
| } |
| sReg=bc.registerService(NamingServiceIfc.class.getName(), this, null); |
| this.log(LogService.LOG_INFO, "RMI Registry started "+version,null); |
| } |
| |
| public void stop(BundleContext bc) throws Exception { |
| this.log(LogService.LOG_INFO, "Stopping RMI Registry "+version,null); |
| UnicastRemoteObject.unexportObject(m_registry, true); |
| this. m_registry = null; |
| sReg.unregister(); |
| this.sReg=null; |
| this.log(LogService.LOG_INFO, "RMI Stopped "+version,null); |
| this.bc=null; |
| } |
| |
| private void log(int prio, String message, Throwable t){ |
| if (this.bc!=null){ |
| ServiceReference logSR=this.bc.getServiceReference(LogService.class.getName()); |
| if (logSR!=null){ |
| ((LogService)this.bc.getService(logSR)).log(prio, message, t); |
| }else{ |
| System.out.println("No Log Service"); |
| } |
| }else{ |
| System.out.println(NamingService.class.getName()+": No bundleContext"); |
| } |
| } |
| } |