12c593315Sopenharmony_ci/* 22c593315Sopenharmony_ci * nghttp2 - HTTP/2 C Library 32c593315Sopenharmony_ci * 42c593315Sopenharmony_ci * Copyright (c) 2014 Tatsuhiro Tsujikawa 52c593315Sopenharmony_ci * 62c593315Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining 72c593315Sopenharmony_ci * a copy of this software and associated documentation files (the 82c593315Sopenharmony_ci * "Software"), to deal in the Software without restriction, including 92c593315Sopenharmony_ci * without limitation the rights to use, copy, modify, merge, publish, 102c593315Sopenharmony_ci * distribute, sublicense, and/or sell copies of the Software, and to 112c593315Sopenharmony_ci * permit persons to whom the Software is furnished to do so, subject to 122c593315Sopenharmony_ci * the following conditions: 132c593315Sopenharmony_ci * 142c593315Sopenharmony_ci * The above copyright notice and this permission notice shall be 152c593315Sopenharmony_ci * included in all copies or substantial portions of the Software. 162c593315Sopenharmony_ci * 172c593315Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 182c593315Sopenharmony_ci * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 192c593315Sopenharmony_ci * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 202c593315Sopenharmony_ci * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 212c593315Sopenharmony_ci * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 222c593315Sopenharmony_ci * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 232c593315Sopenharmony_ci * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 242c593315Sopenharmony_ci */ 252c593315Sopenharmony_ci#ifndef SHRPX_CONNECT_BLOCKER_H 262c593315Sopenharmony_ci#define SHRPX_CONNECT_BLOCKER_H 272c593315Sopenharmony_ci 282c593315Sopenharmony_ci#include "shrpx.h" 292c593315Sopenharmony_ci 302c593315Sopenharmony_ci#include <random> 312c593315Sopenharmony_ci#include <functional> 322c593315Sopenharmony_ci 332c593315Sopenharmony_ci#include <ev.h> 342c593315Sopenharmony_ci 352c593315Sopenharmony_cinamespace shrpx { 362c593315Sopenharmony_ci 372c593315Sopenharmony_ciclass ConnectBlocker { 382c593315Sopenharmony_cipublic: 392c593315Sopenharmony_ci ConnectBlocker(std::mt19937 &gen, struct ev_loop *loop, 402c593315Sopenharmony_ci std::function<void()> block_func, 412c593315Sopenharmony_ci std::function<void()> unblock_func); 422c593315Sopenharmony_ci ~ConnectBlocker(); 432c593315Sopenharmony_ci 442c593315Sopenharmony_ci // Returns true if making connection is not allowed. 452c593315Sopenharmony_ci bool blocked() const; 462c593315Sopenharmony_ci // Call this function if connect operation succeeded. This will 472c593315Sopenharmony_ci // reset sleep_ to minimum value. 482c593315Sopenharmony_ci void on_success(); 492c593315Sopenharmony_ci // Call this function if connect operations failed. This will start 502c593315Sopenharmony_ci // timer and blocks connection establishment with exponential 512c593315Sopenharmony_ci // backoff. 522c593315Sopenharmony_ci void on_failure(); 532c593315Sopenharmony_ci 542c593315Sopenharmony_ci size_t get_fail_count() const; 552c593315Sopenharmony_ci 562c593315Sopenharmony_ci // Peer is now considered offline. This effectively means that the 572c593315Sopenharmony_ci // connection is blocked until online() is called. 582c593315Sopenharmony_ci void offline(); 592c593315Sopenharmony_ci 602c593315Sopenharmony_ci // Peer is now considered online 612c593315Sopenharmony_ci void online(); 622c593315Sopenharmony_ci 632c593315Sopenharmony_ci // Returns true if peer is considered offline. 642c593315Sopenharmony_ci bool in_offline() const; 652c593315Sopenharmony_ci 662c593315Sopenharmony_ci void call_block_func(); 672c593315Sopenharmony_ci void call_unblock_func(); 682c593315Sopenharmony_ci 692c593315Sopenharmony_ciprivate: 702c593315Sopenharmony_ci std::mt19937 &gen_; 712c593315Sopenharmony_ci // Called when blocking is started 722c593315Sopenharmony_ci std::function<void()> block_func_; 732c593315Sopenharmony_ci // Called when unblocked 742c593315Sopenharmony_ci std::function<void()> unblock_func_; 752c593315Sopenharmony_ci ev_timer timer_; 762c593315Sopenharmony_ci struct ev_loop *loop_; 772c593315Sopenharmony_ci // The number of consecutive connection failure. Reset to 0 on 782c593315Sopenharmony_ci // success. 792c593315Sopenharmony_ci size_t fail_count_; 802c593315Sopenharmony_ci // true if peer is considered offline. 812c593315Sopenharmony_ci bool offline_; 822c593315Sopenharmony_ci}; 832c593315Sopenharmony_ci 842c593315Sopenharmony_ci} // namespace shrpx 852c593315Sopenharmony_ci 862c593315Sopenharmony_ci#endif // SHRPX_CONNECT_BLOCKER_H 87