1/* 2 * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26package com.sun.xml.internal.ws.addressing.model; 27 28import com.sun.istack.internal.NotNull; 29import com.sun.istack.internal.Nullable; 30import com.sun.xml.internal.ws.api.message.Packet; 31import com.sun.xml.internal.ws.resources.AddressingMessages; 32 33import javax.xml.ws.WebServiceException; 34import javax.xml.namespace.QName; 35 36/** 37 * This exception signals that a particular WS-Addressing header is missing in a SOAP message. 38 * 39 * @author Rama Pulavarthi 40 */ 41public class MissingAddressingHeaderException extends WebServiceException { 42 private final QName name; 43 private transient final Packet packet; 44 45 /** 46 * 47 * @param name QName of the missing WS-Addressing Header 48 */ 49 public MissingAddressingHeaderException(@NotNull QName name) { 50 this(name,null); 51 } 52 53 public MissingAddressingHeaderException(@NotNull QName name, @Nullable Packet p) { 54 super(AddressingMessages.MISSING_HEADER_EXCEPTION(name)); 55 this.name = name; 56 this.packet = p; 57 } 58 59 /** 60 * Gets the QName of the missing WS-Addressing Header. 61 * 62 * @return 63 * never null. 64 */ 65 public QName getMissingHeaderQName() { 66 return name; 67 } 68 69 /** 70 * The {@link Packet} in which a header was missing. 71 * 72 * <p> 73 * This object can be used to deep-inspect the problematic SOAP message. 74 */ 75 public Packet getPacket() { 76 return packet; 77 } 78} 79