bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
BESDelContainersResponseHandler.cc
1// BESDelContainersResponseHandler.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 "BESDelContainersResponseHandler.h"
34
35#if 0
36#include "BESSilentInfo.h"
37#endif
38
39#include "BESDefinitionStorageList.h"
40#include "BESDefinitionStorage.h"
41#include "BESDefine.h"
42#include "BESContainerStorageList.h"
43#include "BESContainerStorage.h"
44#include "BESContainer.h"
45#include "BESDataNames.h"
46#include "BESSyntaxUserError.h"
47#include "BESResponseNames.h"
48#include "BESDataHandlerInterface.h"
49
50using std::endl;
51using std::ostream;
52using std::string;
53
54BESDelContainersResponseHandler::BESDelContainersResponseHandler(const string &name) :
56{
57}
58
59BESDelContainersResponseHandler::~BESDelContainersResponseHandler()
60{
61}
62
84{
85#if 0
86 dhi.action_name = DELETE_CONTAINERS_STR;
87 BESInfo *info = new BESSilentInfo();
88 d_response_object = info;
89#endif
90
91 string store_name = dhi.data[STORE_NAME];
92 if (store_name == "") {
93 store_name = CATALOG /* DEFAULT jhrg 12/27/18 */;
94 }
95
96 BESContainerStorage *cp = BESContainerStorageList::TheList()->find_persistence(store_name);
97 if (cp) {
98 bool deleted = cp->del_containers();
99 if (!deleted) {
100 string line = (string) "Unable to delete containers from \"" + dhi.data[STORE_NAME] + "\" container store";
101 throw BESSyntaxUserError(line, __FILE__, __LINE__);
102 }
103 }
104 else {
105 string line = (string) "Container storage \"" + dhi.data[STORE_NAME] + "\" does not exist. " + "Unable to delete containers";
106 throw BESSyntaxUserError(line, __FILE__, __LINE__);
107 }
108}
109
123{
124#if 0
125 if( d_response_object )
126 {
127 BESInfo *info = dynamic_cast<BESInfo *>(d_response_object);
128 if( !info )
129 throw BESInternalError( "cast error", __FILE__, __LINE__ );
130 info->transmit( transmitter, dhi );
131 }
132#endif
133}
134
142{
143 strm << BESIndent::LMarg << "BESDelContainersResponseHandler::dump - (" << (void *) this << ")" << endl;
144 BESIndent::Indent();
146 BESIndent::UnIndent();
147}
148
150BESDelContainersResponseHandler::DelContainersResponseBuilder(const string &name)
151{
152 return new BESDelContainersResponseHandler(name);
153}
provides persistent storage for data storage information represented by a container.
virtual bool del_containers()=0
removes all container
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.
response handler that deletes all containers from a specified container store
virtual void transmit(BESTransmitter *transmitter, BESDataHandlerInterface &dhi)
transmit the response object built by the execute command using the specified transmitter object
virtual void dump(std::ostream &strm) const
dumps information about this object
virtual void execute(BESDataHandlerInterface &dhi)
executes the command to delete all containers from a specified container store.
informational response object
Definition BESInfo.h:63
virtual void transmit(BESTransmitter *transmitter, BESDataHandlerInterface &dhi)=0
transmit the informational object
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
error thrown if there is a user syntax error in the request or any other user error