Coverage Report

Created: 2025-11-24 06:34

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/h2o/lib/handler/configurator/throttle_resp.c
Line
Count
Source
1
/*
2
 * Copyright (c) 2016 Justin Zhu
3
 *
4
 * Permission is hereby granted, free of charge, to any person obtaining a copy
5
 * of this software and associated documentation files (the "Software"), to
6
 * deal in the Software without restriction, including without limitation the
7
 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
8
 * sell copies of the Software, and to permit persons to whom the Software is
9
 * furnished to do so, subject to the following conditions:
10
 *
11
 * The above copyright notice and this permission notice shall be included in
12
 * all copies or substantial portions of the Software.
13
 *
14
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
19
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
20
 * IN THE SOFTWARE.
21
 */
22
#include "h2o.h"
23
#include "h2o/configurator.h"
24
25
struct throttle_resp_config_vars_t {
26
    int on;
27
};
28
29
struct throttle_resp_configurator_t {
30
    h2o_configurator_t super;
31
    struct throttle_resp_config_vars_t *vars, _vars_stack[H2O_CONFIGURATOR_NUM_LEVELS + 1];
32
};
33
34
static int on_config_throttle_resp(h2o_configurator_command_t *cmd, h2o_configurator_context_t *ctx, yoml_t *node)
35
0
{
36
0
    struct throttle_resp_configurator_t *self = (void *)cmd->configurator;
37
38
0
    if ((self->vars->on = (int)h2o_configurator_get_one_of(cmd, node, "OFF,ON")) == -1)
39
0
        return -1;
40
0
    return 0;
41
0
}
42
43
static int on_config_enter(h2o_configurator_t *configurator, h2o_configurator_context_t *ctx, yoml_t *node)
44
0
{
45
0
    struct throttle_resp_configurator_t *self = (void *)configurator;
46
47
0
    ++self->vars;
48
0
    self->vars[0] = self->vars[-1];
49
0
    return 0;
50
0
}
51
52
static int on_config_exit(h2o_configurator_t *configurator, h2o_configurator_context_t *ctx, yoml_t *node)
53
0
{
54
0
    struct throttle_resp_configurator_t *self = (void *)configurator;
55
56
0
    if (ctx->pathconf != NULL && !h2o_configurator_at_extension_level(ctx) && self->vars->on)
57
0
        h2o_throttle_resp_register(ctx->pathconf);
58
59
0
    --self->vars;
60
0
    return 0;
61
0
}
62
63
void h2o_throttle_resp_register_configurator(h2o_globalconf_t *conf)
64
0
{
65
0
    struct throttle_resp_configurator_t *c = (void *)h2o_configurator_create(conf, sizeof(*c));
66
67
0
    c->super.enter = on_config_enter;
68
0
    c->super.exit = on_config_exit;
69
0
    h2o_configurator_define_command(&c->super, "throttle-response",
70
0
                                    H2O_CONFIGURATOR_FLAG_GLOBAL | H2O_CONFIGURATOR_FLAG_HOST | H2O_CONFIGURATOR_FLAG_PATH |
71
0
                                        H2O_CONFIGURATOR_FLAG_EXPECT_SCALAR,
72
0
                                    on_config_throttle_resp);
73
0
    c->vars = c->_vars_stack;
74
0
}