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.xml.internal.ws.resources.AddressingMessages;
29
30import javax.xml.ws.WebServiceException;
31import javax.xml.namespace.QName;
32
33/**
34 * This exception captures SOAP Fault information when a WS-Addressing 1.0 Message Addressing
35 * Property is invalid and cannot be processed.
36 *
37 * @author Rama Pulavarthi
38 */
39public class InvalidAddressingHeaderException extends WebServiceException {
40    private QName problemHeader;
41    private QName subsubcode;
42
43    /**
44     * Creates a InvalidAddressingHeader exception capturing information about the invalid
45     * Addressing Message Property and the reason in Subsubcode.
46     * @param problemHeader
47     *      represents the invalid Addressing Header.
48     * @param subsubcode
49     *      represents the reason why the Addressing header in question is invalid.
50     */
51    public InvalidAddressingHeaderException(QName problemHeader, QName subsubcode) {
52        super(AddressingMessages.INVALID_ADDRESSING_HEADER_EXCEPTION(problemHeader,subsubcode));
53        this.problemHeader = problemHeader;
54        this.subsubcode = subsubcode;
55    }
56
57    public QName getProblemHeader() {
58        return problemHeader;
59    }
60
61    public QName getSubsubcode() {
62        return subsubcode;
63    }
64}
65