SNode.C
Loading...
Searching...
No Matches
BasicAuthentication.cpp
Go to the documentation of this file.
1/*
2 * SNode.C - A Slim Toolkit for Network Communication
3 * Copyright (C) Volker Christian <me@vchrist.at>
4 * 2020, 2021, 2022, 2023, 2024, 2025
5 *
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Lesser General Public License as published
8 * by the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20/*
21 * MIT License
22 *
23 * Permission is hereby granted, free of charge, to any person obtaining a copy
24 * of this software and associated documentation files (the "Software"), to deal
25 * in the Software without restriction, including without limitation the rights
26 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
27 * copies of the Software, and to permit persons to whom the Software is
28 * furnished to do so, subject to the following conditions:
29 *
30 * The above copyright notice and this permission notice shall be included in
31 * all copies or substantial portions of the Software.
32 *
33 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
39 * THE SOFTWARE.
40 */
41
42#include "express/middleware/BasicAuthentication.h"
43
44#ifndef DOXYGEN_SHOULD_SKIP_THIS
45
46#include "utils/base64.h"
47#include "web/http/http_utils.h"
48
49#include <list>
50#include <utility>
51
52#endif /* DOXYGEN_SHOULD_SKIP_THIS */
53
54namespace express::middleware {
55
56 BasicAuthentication::BasicAuthentication(const std::string& userName, const std::string& password, const std::string& realm) {
57 std::string userNamePassword = userName + ":" + password;
58 const std::string credentials =
59 base64::base64_encode(reinterpret_cast<unsigned char*>(userNamePassword.data()), userNamePassword.length());
60
61 use([realm, credentials] MIDDLEWARE(req, res, next) {
62 const std::string authCredentials = httputils::str_split(req->get("Authorization"), ' ').second;
63
64 if (authCredentials == credentials) {
65 next();
66 } else {
67 if (authCredentials.empty()) {
68 res->set("WWW-Authenticate", "Basic realm=\"" + realm + "\"");
69 }
70 res->sendStatus(401);
71 }
72 });
73 }
74
76 BasicAuthentication::instance(const std::string& userName, const std::string& password, const std::string& realm) {
77 // Keep the created authentication middleware alive
78 static std::list<std::shared_ptr<class BasicAuthentication>> basicAuthentications;
79
80 BasicAuthentication* basicAuthentication = new BasicAuthentication(userName, password, realm);
81 basicAuthentications.push_back(std::shared_ptr<BasicAuthentication>(basicAuthentication));
82
83 return *basicAuthentication;
84 }
85
86 class BasicAuthentication& BasicAuthentication(const std::string& userName, const std::string& password, const std::string& realm) {
87 return BasicAuthentication::instance(userName, password, realm);
88 }
89
90} // namespace express::middleware
#define MIDDLEWARE(req, res, next)
Definition Router.h:63
void operator()(const std::string &how="") const
Definition Next.cpp:56
const std::string & get(const std::string &key, int i=0) const
Definition Request.cpp:93
Response & set(const std::string &field, const std::string &value, bool overwrite=true)
Definition Response.cpp:125
void sendStatus(int state)
Definition Response.cpp:91
friend class BasicAuthentication & BasicAuthentication(const std::string &userName, const std::string &password, const std::string &realm)
BasicAuthentication(const std::string &userName, const std::string &password, const std::string &realm)
static class BasicAuthentication & instance(const std::string &userName, const std::string &password, const std::string &realm)
std::string base64_encode(const unsigned char *bytes_to_encode, std::size_t length)
Definition base64.cpp:69
std::pair< std::string, std::string > str_split(const std::string &base, char c_middle)