summaryrefslogtreecommitdiffstats
path: root/dnsdist-nghttp2.hh
blob: 6e38f28cc383f1c12d76b5821b59414a7c118fe2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
 * This file is part of PowerDNS or dnsdist.
 * Copyright -- PowerDNS.COM B.V. and its contributors
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * In addition, for the avoidance of any doubt, permission is granted to
 * link this program with OpenSSL and to (re)distribute the binaries
 * produced as the result of such linking.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 */
#pragma once

#include <memory>
#include <mutex>
#include <vector>

#include "dnsdist-tcp.hh"
#include "stat_t.hh"

struct CrossProtocolQuery;

class DoHClientCollection
{
public:
  DoHClientCollection(size_t numberOfThreads);

  uint64_t getThreadsCount() const
  {
    return d_numberOfThreads;
  }

  bool passCrossProtocolQueryToThread(std::unique_ptr<CrossProtocolQuery>&& cpq);
  void addThread();

private:
  struct DoHWorkerThread;

  std::mutex d_mutex;
  /* we only alter that vector at configuration time, and then
     it is never modified at runtime, so we don't take a lock
     after the configuration phase */
  std::vector<DoHWorkerThread> d_clientThreads;
  pdns::stat_t d_pos{0};
  uint64_t d_numberOfThreads{0};
};

extern std::unique_ptr<DoHClientCollection> g_dohClientThreads;
extern std::atomic<uint64_t> g_dohStatesDumpRequested;
extern std::optional<uint16_t> g_outgoingDoHWorkerThreads;

class TLSCtx;

bool initDoHWorkers();
bool setupDoHClientProtocolNegotiation(std::shared_ptr<TLSCtx>& ctx);

/* opens a new HTTP/2 connection to the supplied backend (attached to the supplied multiplexer), sends the query,
   waits for the response to come back or an error to occur then notifies the sender, closing the connection. */
bool sendH2Query(const std::shared_ptr<DownstreamState>& ds, std::unique_ptr<FDMultiplexer>& mplexer, std::shared_ptr<TCPQuerySender>& sender, InternalQuery&& query, bool healthCheck);
size_t handleH2Timeouts(FDMultiplexer& mplexer, const struct timeval& now);
size_t clearH2Connections();

void setDoHDownstreamCleanupInterval(uint16_t max);
void setDoHDownstreamMaxIdleTime(uint16_t max);
void setDoHDownstreamMaxIdleConnectionsPerBackend(size_t max);