bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
SampleSayResponseHandler.cc
1// SampleSayResponseHandler.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 "config.h"
34
35#include "BESInfoList.h"
36#include "BESInfo.h"
37
38#include "SampleSayResponseHandler.h"
39#include "SampleResponseNames.h"
40
41using std::endl;
42using std::string;
43using std::ostream;
44
45SampleSayResponseHandler::SampleSayResponseHandler(const string &name) :
47{
48}
49
50SampleSayResponseHandler::~SampleSayResponseHandler()
51{
52}
53
55{
56 // This is an example. Here you would build the BESResponseObject
57 // object and set it to the _response protected data member
58 BESInfo *info = BESInfoList::TheList()->build_info();
59 d_response_object = info;
60
61 // Here is where your code would fill in the new response object
62 info->begin_response(SAY_RESPONSE, dhi);
63 string str = dhi.data[SAY_WHAT] + " " + dhi.data[SAY_TO];
64 info->add_tag("text", str);
65 info->end_response();
66}
67
69{
70 // Here is where you would transmit your response object using the
71 // specified transmitter object. This is the example using the BESInfo
72 // response object
73 if (d_response_object) {
74 BESInfo *info = dynamic_cast<BESInfo *>(d_response_object);
75
76 if (!info)
77 throw BESInternalError("Could not cast the BESResponse object to an Info object.", __FILE__, __LINE__);
78 info->transmit(transmitter, dhi);
79 }
80}
81
82void SampleSayResponseHandler::dump(ostream &strm) const
83{
84 strm << BESIndent::LMarg << "SampleSayResponseHandler::dump - (" << (void *) this << ")" << endl;
85 BESIndent::Indent();
87 BESIndent::UnIndent();
88}
89
91SampleSayResponseHandler::SampleSayResponseBuilder(const string &name)
92{
93 return new SampleSayResponseHandler(name);
94}
95
Structure storing information used by the BES to handle the request.
std::map< std::string, std::string > data
the map of string data that will be required for the current request.
informational response object
Definition BESInfo.h:63
virtual void transmit(BESTransmitter *transmitter, BESDataHandlerInterface &dhi)=0
transmit the informational object
virtual void begin_response(const std::string &response_name, BESDataHandlerInterface &dhi)
begin the informational response
Definition BESInfo.cc:120
exception thrown if internal error encountered
handler object that knows how to create a specific response object
void dump(std::ostream &strm) const override
dumps information about this object
virtual void dump(std::ostream &strm) const
dumps information about this object
virtual void execute(BESDataHandlerInterface &dhi)
knows how to build a requested response object
virtual void transmit(BESTransmitter *transmitter, BESDataHandlerInterface &dhi)
transmit the response object built by the execute command using the specified transmitter object