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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* Fluent Bit
* ==========
* Copyright (C) 2015-2023 The Fluent Bit Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <fluent-bit/flb_input_plugin.h>
#include "in_elasticsearch.h"
#include "in_elasticsearch_config.h"
#include "in_elasticsearch_bulk_conn.h"
struct flb_in_elasticsearch *in_elasticsearch_config_create(struct flb_input_instance *ins)
{
int ret;
char port[8];
struct flb_in_elasticsearch *ctx;
ctx = flb_calloc(1, sizeof(struct flb_in_elasticsearch));
if (!ctx) {
flb_errno();
return NULL;
}
ctx->ins = ins;
mk_list_init(&ctx->connections);
/* Load the config map */
ret = flb_input_config_map_set(ins, (void *) ctx);
if (ret == -1) {
flb_free(ctx);
return NULL;
}
/* Listen interface (if not set, defaults to 0.0.0.0:9200) */
flb_input_net_default_listener("0.0.0.0", 9200, ins);
ctx->listen = flb_sds_create(ins->host.listen);
snprintf(port, sizeof(port) - 1, "%d", ins->host.port);
ctx->tcp_port = flb_sds_create(port);
/* HTTP Server specifics */
ctx->server = flb_calloc(1, sizeof(struct mk_server));
ctx->server->keep_alive = MK_TRUE;
/* monkey detects server->workers == 0 as the server not being initialized at the
* moment so we want to make sure that it stays that way!
*/
ret = flb_log_event_encoder_init(&ctx->log_encoder,
FLB_LOG_EVENT_FORMAT_DEFAULT);
if (ret != FLB_EVENT_ENCODER_SUCCESS) {
flb_plg_error(ctx->ins, "error initializing event encoder : %d", ret);
in_elasticsearch_config_destroy(ctx);
return ctx = NULL;
}
return ctx;
}
int in_elasticsearch_config_destroy(struct flb_in_elasticsearch *ctx)
{
flb_log_event_encoder_destroy(&ctx->log_encoder);
/* release all connections */
in_elasticsearch_bulk_conn_release_all(ctx);
if (ctx->collector_id != -1) {
flb_input_collector_delete(ctx->collector_id, ctx->ins);
ctx->collector_id = -1;
}
if (ctx->downstream != NULL) {
flb_downstream_destroy(ctx->downstream);
}
if (ctx->server) {
flb_free(ctx->server);
}
flb_sds_destroy(ctx->listen);
flb_sds_destroy(ctx->tcp_port);
flb_free(ctx);
return 0;
}
|