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 }