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 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142
|
/*
Copyright (C) 2021 The Falco 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.
*/
#pragma once
///////////////////////////////////////////////////////////////////////////////
// The protocol decoder interface
///////////////////////////////////////////////////////////////////////////////
class sinsp_protodecoder
{
public:
sinsp_protodecoder();
virtual ~sinsp_protodecoder()
{
}
//
// Allocate a new decoder of the same type.
// Every protodecoder plugin must implement this.
//
virtual sinsp_protodecoder* allocate_new() = 0;
//
// Allocate a new decoder of the same type.
// Every protodecoder plugin must implement this.
//
virtual void init() = 0;
//
// Return the protocol decoder name
//
const string& get_name()
{
return m_name;
}
//
// Called by the engine for each of the FDs that are added from proc
// (or from the file) at the beginning of a capture.
//
virtual void on_fd_from_proc(sinsp_fdinfo_t* fdinfo) = 0;
//
// Called by the engine after an event has been received and parsed.
//
virtual void on_event(sinsp_evt* evt, sinsp_pd_callback_type etype) = 0;
//
// These are not part of on_event for performance reasons
//
virtual void on_read(sinsp_evt* evt, char *data, uint32_t len);
virtual void on_write(sinsp_evt* evt, char *data, uint32_t len);
virtual void on_reset(sinsp_evt* evt);
//
// Used by the engine to retrieve the info line for the last event.
// Must return true if the line is valid.
//
virtual bool get_info_line(char** res) = 0;
protected:
//
// Interface for the plugins
//
void register_event_callback(sinsp_pd_callback_type etype);
void register_read_callback(sinsp_fdinfo_t* fdinfo);
void register_write_callback(sinsp_fdinfo_t* fdinfo);
void unregister_read_callback(sinsp_fdinfo_t* fdinfo);
void unregister_write_callback(sinsp_fdinfo_t* fdinfo);
string m_name;
sinsp* m_inspector;
private:
void set_inspector(sinsp* inspector);
friend class sinsp_protodecoder_list;
};
///////////////////////////////////////////////////////////////////////////////
// Global class that stores the list of protocol decoders and offers
// functions to work with it.
///////////////////////////////////////////////////////////////////////////////
class sinsp_protodecoder_list
{
public:
sinsp_protodecoder_list();
~sinsp_protodecoder_list();
void add_protodecoder(sinsp_protodecoder* protodecoder);
sinsp_protodecoder* new_protodecoder_from_name(const string& name, sinsp* inspector);
private:
vector<sinsp_protodecoder*> m_decoders_list;
};
///////////////////////////////////////////////////////////////////////////////
// Decoder classes
// NOTE: these should be moved to a separate file but, since we have only one
// for the moment, we keep it here
///////////////////////////////////////////////////////////////////////////////
class sinsp_decoder_syslog : public sinsp_protodecoder
{
public:
sinsp_decoder_syslog();
sinsp_protodecoder* allocate_new();
void init();
void on_fd_from_proc(sinsp_fdinfo_t* fdinfo);
void on_event(sinsp_evt* evt, sinsp_pd_callback_type etype);
void on_write(sinsp_evt* evt, char *data, uint32_t len);
void on_reset(sinsp_evt* evt);
bool get_info_line(char** res);
bool is_data_valid();
const char* get_severity_str();
const char* get_facility_str();
int32_t m_priority;
uint32_t m_facility;
uint32_t m_severity;
string m_msg;
private:
void decode_message(char *data, uint32_t len, char* pristr, uint32_t pristrlen);
string m_infostr;
};
|