bes  Updated for version 3.17.0
BESShowErrorResponseHandler.cc
1 // BESShowErrorResponseHandler.cc
2 
3 // This file is part of bes, A C++ back-end server implementation framework
4 // for the OPeNDAP Data Access Protocol.
5 
6 // Copyright (c) 2004-2009 University Corporation for Atmospheric Research
7 // Author: Patrick West <pwest@ucar.edu> and Jose Garcia <jgarcia@ucar.edu>
8 //
9 // This library is free software; you can redistribute it and/or
10 // modify it under the terms of the GNU Lesser General Public
11 // License as published by the Free Software Foundation; either
12 // version 2.1 of the License, or (at your option) any later version.
13 //
14 // This library is distributed in the hope that it will be useful,
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 // Lesser General Public License for more details.
18 //
19 // You should have received a copy of the GNU Lesser General Public
20 // License along with this library; if not, write to the Free Software
21 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 //
23 // You can contact University Corporation for Atmospheric Research at
24 // 3080 Center Green Drive, Boulder, CO 80301
25 
26 // (c) COPYRIGHT University Corporation for Atmospheric Research 2004-2005
27 // Please read the full copyright statement in the file COPYRIGHT_UCAR.
28 //
29 // Authors:
30 // pwest Patrick West <pwest@ucar.edu>
31 // jgarcia Jose Garcia <jgarcia@ucar.edu>
32 
33 #include <sstream>
34 
35 using std::istringstream;
36 
37 #include "BESShowErrorResponseHandler.h"
38 #include "BESDataNames.h"
39 #include "BESInternalError.h"
40 #include "BESInternalFatalError.h"
41 #include "BESSyntaxUserError.h"
42 #include "BESForbiddenError.h"
43 #include "BESNotFoundError.h"
44 
45 BESShowErrorResponseHandler::BESShowErrorResponseHandler(const string &name) :
46  BESResponseHandler(name)
47 {
48 }
49 
50 BESShowErrorResponseHandler::~BESShowErrorResponseHandler()
51 {
52 }
53 
69 {
70  string etype_s = dhi.data[SHOW_ERROR_TYPE];
71  if (etype_s.empty()) {
72  string err = dhi.action + " error type missing";
73  throw BESSyntaxUserError(err, __FILE__, __LINE__);
74  }
75  istringstream strm(etype_s);
76  unsigned int etype = 0;
77  strm >> etype;
78  if (!etype || etype > 5) {
79  string err = dhi.action + " invalid error type, should be 1-5";
80  throw BESSyntaxUserError(err, __FILE__, __LINE__);
81  }
82 
83  switch (etype) {
84  case BES_INTERNAL_ERROR: {
85  string err = dhi.action + " Internal Error";
86  throw BESInternalError(err, __FILE__, __LINE__);
87  }
88  case BES_INTERNAL_FATAL_ERROR: {
89  string err = dhi.action + " Internal Fatal Error";
90  throw BESInternalFatalError(err, __FILE__, __LINE__);
91  }
92  case BES_SYNTAX_USER_ERROR: {
93  string err = dhi.action + " Syntax User Error";
94  throw BESSyntaxUserError(err, __FILE__, __LINE__);
95  }
96  case BES_FORBIDDEN_ERROR: {
97  string err = dhi.action + " Forbidden Error";
98  throw BESForbiddenError(err, __FILE__, __LINE__);
99  }
100  case BES_NOT_FOUND_ERROR: {
101  string err = dhi.action + " Not Found Error";
102  throw BESNotFoundError(err, __FILE__, __LINE__);
103  }
104  }
105 }
106 
120 {
121  string err = "An exception should have been thrown, nothing to transmit";
122  throw BESInternalError(err, __FILE__, __LINE__);
123 }
124 
131 void BESShowErrorResponseHandler::dump(ostream &strm) const
132 {
133  strm << BESIndent::LMarg << "BESShowErrorResponseHandler::dump - (" << (void *) this << ")" << endl;
134  BESIndent::Indent();
136  BESIndent::UnIndent();
137 }
138 
140 BESShowErrorResponseHandler::ResponseBuilder(const string &name)
141 {
142  return new BESShowErrorResponseHandler(name);
143 }
144 
error thrown if the resource requested cannot be found
exception thrown if an internal error is found and is fatal to the BES
exception thrown if inernal error encountered
response handler that throws the requested exception type
error thrown if there is a user syntax error in the request or any other user error ...
handler object that knows how to create a specific response object
virtual void dump(ostream &strm) const
dumps information about this object
virtual void dump(ostream &strm) const
dumps information about this object
error thrown if the BES is not allowed to access the resource requested
Structure storing information used by the BES to handle the request.
map< string, string > data
the map of string data that will be required for the current request.
virtual void execute(BESDataHandlerInterface &dhi)
throws a specific exception to test error handling in client
string action
the response object requested, e.g. das, dds
virtual void transmit(BESTransmitter *transmitter, BESDataHandlerInterface &dhi)
transmit the response object built by the execute command using the specified transmitter object ...