001    /**
002     *
003     * Copyright 2005 LogicBlaze, Inc.
004     *
005     * Licensed under the Apache License, Version 2.0 (the "License");
006     * you may not use this file except in compliance with the License.
007     * You may obtain a copy of the License at
008     *
009     * http://www.apache.org/licenses/LICENSE-2.0
010     *
011     * Unless required by applicable law or agreed to in writing, software
012     * distributed under the License is distributed on an "AS IS" BASIS,
013     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014     * See the License for the specific language governing permissions and
015     * limitations under the License.
016     *
017     **/
018    package org.logicblaze.lingo;
019    
020    import org.springframework.remoting.support.RemoteInvocation;
021    import org.aopalliance.intercept.MethodInvocation;
022    
023    /**
024     * Extends the Spring remote invocation bean to add the extra Lingo metadata
025     *
026     * @version $Revision: 1.1 $
027     */
028    public class LingoInvocation extends RemoteInvocation {
029        private MethodMetadata metadata;
030    
031        public LingoInvocation(MethodInvocation methodInvocation, MethodMetadata metadata) {
032            super(methodInvocation);
033            this.metadata = metadata;
034        }
035    
036        public LingoInvocation(String s, Class[] classes, Object[] objects, MethodMetadata metadata) {
037            super(s, classes, objects);
038            this.metadata = metadata;
039        }
040    
041        /**
042         * Returns the metadata associated with this invocation, such as whether or not it should
043         * be considered a one-way invocation, which parameters should be considered remote (listeners)
044         * versus which objects should be passed by value etc.
045         *
046         * @return
047         */
048        public MethodMetadata getMetadata() {
049            return metadata;
050        }
051    }