blob: 08252b4c0b2d349ebd26d0eb6d9a52a450e09291 [file] [log] [blame]
Alexander Afanasyevfa2f6622016-12-25 12:28:00 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2013-2016, Regents of the University of California.
4 *
5 * This file is part of ChronoShare, a decentralized file sharing application over NDN.
6 *
7 * ChronoShare is free software: you can redistribute it and/or modify it under the terms
8 * of the GNU General Public License as published by the Free Software Foundation, either
9 * version 3 of the License, or (at your option) any later version.
10 *
11 * ChronoShare is distributed in the hope that it will be useful, but WITHOUT ANY
12 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13 * PARTICULAR PURPOSE. See the GNU General Public License for more details.
14 *
15 * You should have received copies of the GNU General Public License along with
16 * ChronoShare, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
17 *
18 * See AUTHORS.md for complete list of ChronoShare authors and contributors.
19 */
Zhenkai Zhua9a7e1d2013-02-25 18:29:07 -080020//
21// request_handler.hpp
22// ~~~~~~~~~~~~~~~~~~~
23//
24// Copyright (c) 2003-2012 Christopher M. Kohlhoff (chris at kohlhoff dot com)
25//
26// Distributed under the Boost Software License, Version 1.0. (See accompanying
27// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
28//
29
30#ifndef HTTP_REQUEST_HANDLER_HPP
31#define HTTP_REQUEST_HANDLER_HPP
32
33#include <string>
34#include <boost/noncopyable.hpp>
Zhenkai Zhud9429222013-02-25 22:34:09 -080035#include <QDir>
Zhenkai Zhua9a7e1d2013-02-25 18:29:07 -080036
37namespace http {
38namespace server {
39
40struct reply;
41struct request;
42
43/// The common handler for all incoming requests.
44class request_handler
45 : private boost::noncopyable
46{
47public:
48 /// Construct with a directory containing files to be served.
49 explicit request_handler(const std::string& doc_root);
50
51 /// Handle a request and produce a reply.
52 void handle_request(const request& req, reply& rep);
53
54private:
55 /// The directory containing the files to be served.
Zhenkai Zhud9429222013-02-25 22:34:09 -080056 QDir doc_root_;
Zhenkai Zhua9a7e1d2013-02-25 18:29:07 -080057
58 /// Perform URL-decoding on a string. Returns false if the encoding was
59 /// invalid.
60 static bool url_decode(const std::string& in, std::string& out);
61};
62
63} // namespace server
64} // namespace http
65
66#endif // HTTP_REQUEST_HANDLER_HPP