001    /**
002    *
003    * Licensed to the Apache Software Foundation (ASF) under one or more
004    *  contributor license agreements.  See the NOTICE file distributed with
005    *  this work for additional information regarding copyright ownership.
006    *  The ASF licenses this file to You under the Apache License, Version 2.0
007    *  (the "License"); you may not use this file except in compliance with
008    *  the License.  You may obtain a copy of the License at
009    *
010    *     http://www.apache.org/licenses/LICENSE-2.0
011    *
012    *  Unless required by applicable law or agreed to in writing, software
013    *  distributed under the License is distributed on an "AS IS" BASIS,
014    *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015    *  See the License for the specific language governing permissions and
016    *  limitations under the License.
017    */ 
018    
019    package org.apache.geronimo.yoko;
020    
021    /**
022     * Implementation of the yoko StubInitializer class to provide instances 
023     * of RMIStubHandlers to Stub instances. 
024     */
025    public class RMIStubHandlerFactory implements org.apache.yoko.rmi.util.stub.StubInitializer {
026        public RMIStubHandlerFactory() {
027        }
028        
029        /**
030         * Provide an RMIStub instance with an RMIStubHandler instance.  This version
031         * instantiates a new handler for each stub instance because the handler 
032         * needs to be initialized with the appropriate execution context. 
033         * 
034         * @return An instance of StubHandler that hooks the RMI stub invocation into the openejb
035         *         context.
036         */
037        public Object getStubHandler() {
038            return new RMIStubHandler(); 
039        }
040    }
041