~ubuntu-branches/ubuntu/raring/eucalyptus/raring

« back to all changes in this revision

Viewing changes to clc/modules/msgs/src/main/java/com/eucalyptus/ws/handlers/BindingHandler.java

  • Committer: Package Import Robot
  • Author(s): Brian Thomason
  • Date: 2011-11-29 13:17:52 UTC
  • mfrom: (1.2.1 upstream)
  • mto: This revision was merged to the branch mainline in revision 185.
  • Revision ID: package-import@ubuntu.com-20111129131752-rq31al3ntutv2vvl
Tags: upstream-3.0.999beta1
ImportĀ upstreamĀ versionĀ 3.0.999beta1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*******************************************************************************
 
2
 *Copyright (c) 2009  Eucalyptus Systems, Inc.
 
3
 * 
 
4
 *  This program is free software: you can redistribute it and/or modify
 
5
 *  it under the terms of the GNU General Public License as published by
 
6
 *  the Free Software Foundation, only version 3 of the License.
 
7
 * 
 
8
 * 
 
9
 *  This file is distributed in the hope that it will be useful, but WITHOUT
 
10
 *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 
11
 *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 
12
 *  for more details.
 
13
 * 
 
14
 *  You should have received a copy of the GNU General Public License along
 
15
 *  with this program.  If not, see <http://www.gnu.org/licenses/>.
 
16
 * 
 
17
 *  Please contact Eucalyptus Systems, Inc., 130 Castilian
 
18
 *  Dr., Goleta, CA 93101 USA or visit <http://www.eucalyptus.com/licenses/>
 
19
 *  if you need additional information or have any questions.
 
20
 * 
 
21
 *  This file may incorporate work covered under the following copyright and
 
22
 *  permission notice:
 
23
 * 
 
24
 *    Software License Agreement (BSD License)
 
25
 * 
 
26
 *    Copyright (c) 2008, Regents of the University of California
 
27
 *    All rights reserved.
 
28
 * 
 
29
 *    Redistribution and use of this software in source and binary forms, with
 
30
 *    or without modification, are permitted provided that the following
 
31
 *    conditions are met:
 
32
 * 
 
33
 *      Redistributions of source code must retain the above copyright notice,
 
34
 *      this list of conditions and the following disclaimer.
 
35
 * 
 
36
 *      Redistributions in binary form must reproduce the above copyright
 
37
 *      notice, this list of conditions and the following disclaimer in the
 
38
 *      documentation and/or other materials provided with the distribution.
 
39
 * 
 
40
 *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
 
41
 *    IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 
42
 *    TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
 
43
 *    PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
 
44
 *    OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 
45
 *    EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 
46
 *    PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 
47
 *    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 
48
 *    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 
49
 *    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 
50
 *    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. USERS OF
 
51
 *    THIS SOFTWARE ACKNOWLEDGE THE POSSIBLE PRESENCE OF OTHER OPEN SOURCE
 
52
 *    LICENSED MATERIAL, COPYRIGHTED MATERIAL OR PATENTED MATERIAL IN THIS
 
53
 *    SOFTWARE, AND IF ANY SUCH MATERIAL IS DISCOVERED THE PARTY DISCOVERING
 
54
 *    IT MAY INFORM DR. RICH WOLSKI AT THE UNIVERSITY OF CALIFORNIA, SANTA
 
55
 *    BARBARA WHO WILL THEN ASCERTAIN THE MOST APPROPRIATE REMEDY, WHICH IN
 
56
 *    THE REGENTS' DISCRETION MAY INCLUDE, WITHOUT LIMITATION, REPLACEMENT
 
57
 *    OF THE CODE SO IDENTIFIED, LICENSING OF THE CODE SO IDENTIFIED, OR
 
58
 *    WITHDRAWAL OF THE CODE CAPABILITY TO THE EXTENT NEEDED TO COMPLY WITH
 
59
 *    ANY SUCH LICENSES OR RIGHTS.
 
60
 *******************************************************************************/
 
61
/*
 
62
 * Author: chris grzegorczyk <grze@eucalyptus.com>
 
63
 */
 
64
package com.eucalyptus.ws.handlers;
 
65
 
 
66
import org.apache.axiom.om.OMElement;
 
67
import org.apache.axiom.om.OMNamespace;
 
68
import org.apache.log4j.Logger;
 
69
import org.jboss.netty.channel.ChannelHandlerContext;
 
70
import org.jboss.netty.channel.ChannelPipelineCoverage;
 
71
import org.jboss.netty.channel.MessageEvent;
 
72
import com.eucalyptus.binding.Binding;
 
73
import com.eucalyptus.binding.BindingException;
 
74
import com.eucalyptus.binding.BindingManager;
 
75
import com.eucalyptus.http.MappingHttpMessage;
 
76
import com.eucalyptus.http.MappingHttpRequest;
 
77
import com.eucalyptus.http.MappingHttpResponse;
 
78
import com.eucalyptus.records.Logs;
 
79
import com.eucalyptus.util.Exceptions;
 
80
import com.eucalyptus.ws.WebServicesException;
 
81
import edu.ucsb.eucalyptus.msgs.BaseMessage;
 
82
import edu.ucsb.eucalyptus.msgs.EucalyptusErrorMessageType;
 
83
import edu.ucsb.eucalyptus.msgs.ExceptionResponseType;
 
84
 
 
85
@ChannelPipelineCoverage( "all" )
 
86
public class BindingHandler extends MessageStackHandler {
 
87
  private static Logger LOG = Logger.getLogger( BindingHandler.class );
 
88
  
 
89
  private Binding       binding;
 
90
  private String        namespace;
 
91
  private final Binding defaultBinding;
 
92
  
 
93
  public BindingHandler( ) {
 
94
    super( );
 
95
    this.defaultBinding = null;
 
96
    this.namespace = null;
 
97
  }
 
98
  
 
99
  public BindingHandler( final Binding binding ) {
 
100
    this.binding = binding;
 
101
    this.defaultBinding = binding;
 
102
    this.namespace = null;
 
103
  }
 
104
  
 
105
  @Override
 
106
  public void incomingMessage( final MessageEvent event ) throws Exception {
 
107
    if ( event.getMessage( ) instanceof MappingHttpMessage ) {
 
108
      MappingHttpMessage httpMessage = ( MappingHttpMessage ) event.getMessage( );
 
109
      BaseMessage msg = null;
 
110
      Class msgType = null;
 
111
      String namespace = null;
 
112
      try {
 
113
        OMElement elem = httpMessage.getOmMessage( );
 
114
        OMNamespace omNs = elem.getNamespace( );
 
115
        namespace = omNs.getNamespaceURI( );
 
116
        this.binding = BindingManager.getBinding( BindingManager.sanitizeNamespace( namespace ) );
 
117
        msgType = this.binding.getElementClass( httpMessage.getOmMessage( ).getLocalName( ) );
 
118
      } catch ( BindingException ex ) {
 
119
        if ( this.defaultBinding != null ) {
 
120
          this.namespace = namespace;
 
121
          this.binding = this.defaultBinding;
 
122
          try {
 
123
            msgType = this.binding.getElementClass( httpMessage.getOmMessage( ).getLocalName( ) );
 
124
          } catch ( Exception ex1 ) {
 
125
            throw new WebServicesException( "Failed to find binding for namespace: " + namespace
 
126
                                            + " due to: "
 
127
                                            + ex.getMessage( ), ex );
 
128
          }
 
129
        }
 
130
      } catch ( Exception e1 ) {
 
131
        LOG.error( e1.getMessage( ) + " while attempting to bind: " + httpMessage.getOmMessage( ) );
 
132
        Logs.extreme( ).error( httpMessage.getSoapEnvelope( ).toString( ), e1 );
 
133
        if ( this.binding == null ) {
 
134
          throw new WebServicesException( e1 );
 
135
        } else {
 
136
          throw new WebServicesException( "Failed to find binding for namespace: " + namespace
 
137
                                          + " due to: "
 
138
                                          + e1.getMessage( ), e1 );
 
139
        }
 
140
      }
 
141
      try {
 
142
        if ( httpMessage instanceof MappingHttpRequest ) {
 
143
          if ( msgType != null ) {
 
144
            msg = ( BaseMessage ) this.binding.fromOM( httpMessage.getOmMessage( ), msgType );
 
145
          } else {
 
146
            msg = ( BaseMessage ) this.binding.fromOM( httpMessage.getOmMessage( ) );
 
147
          }
 
148
        } else {
 
149
          msg = ( BaseMessage ) this.binding.fromOM( httpMessage.getOmMessage( ) );
 
150
        }
 
151
      } catch ( Exception e1 ) {
 
152
        try {
 
153
          msg = ( BaseMessage ) this.binding.fromOM( httpMessage.getOmMessage( ), this.namespace );
 
154
        } catch ( Exception ex ) {
 
155
          LOG.warn( "FAILED TO PARSE:\n" + httpMessage.getMessageString( ) );
 
156
          throw new WebServicesException( e1 );
 
157
        }
 
158
      }
 
159
      msg.setCorrelationId( httpMessage.getCorrelationId( ) );
 
160
      httpMessage.setMessage( msg );
 
161
    }
 
162
  }
 
163
  
 
164
  @Override
 
165
  public void outgoingMessage( final ChannelHandlerContext ctx, final MessageEvent event ) throws Exception {
 
166
    if ( event.getMessage( ) instanceof MappingHttpMessage ) {
 
167
      MappingHttpMessage httpMessage = ( MappingHttpMessage ) event.getMessage( );
 
168
      OMElement omElem;
 
169
      if ( httpMessage.getMessage( ) instanceof EucalyptusErrorMessageType || httpMessage.getMessage( ) == null ) {
 
170
        return;
 
171
      } else if ( httpMessage.getMessage( ) instanceof ExceptionResponseType ) {
 
172
        ExceptionResponseType msg = ( ExceptionResponseType ) httpMessage.getMessage( );
 
173
        String createFaultDetails = Logs.isExtrrreeeme( )
 
174
          ? Exceptions.string( msg.getException( ) )
 
175
          : msg.getException( ).getMessage( );
 
176
        omElem = Binding.createFault( msg.getRequestType( ), msg.getMessage( ), createFaultDetails );
 
177
        if ( httpMessage instanceof MappingHttpResponse ) {
 
178
          ( ( MappingHttpResponse ) httpMessage ).setStatus( msg.getHttpStatus( ) );
 
179
        }
 
180
      } else {
 
181
        Class targetClass = httpMessage.getMessage( ).getClass( );
 
182
        while ( !targetClass.getSimpleName( ).endsWith( "Type" ) ) {
 
183
          targetClass = targetClass.getSuperclass( );
 
184
        }
 
185
        Class responseClass = ClassLoader.getSystemClassLoader( ).loadClass( targetClass.getName( ) );
 
186
        try {
 
187
          omElem = this.binding.toOM( httpMessage.getMessage( ), this.namespace );
 
188
        } catch ( BindingException ex ) {
 
189
          omElem = BindingManager.getDefaultBinding( ).toOM( httpMessage.getMessage( ) );
 
190
        } catch ( Exception ex ) {
 
191
          Logs.exhaust( ).debug( ex, ex );
 
192
          throw ex;
 
193
        }
 
194
      }
 
195
      httpMessage.setOmMessage( omElem );
 
196
    }
 
197
  }
 
198
  
 
199
}