zeek/src/analyzer/protocol/rpc/MOUNT.h
Devin Trejo 99e411f621 Add mount_proc_null, mount_proc_mnt, mount_proc_umnt,
mount_proc_umnt_all, mount_proc_not_implemented, mount_reply_status.
2018-01-11 11:57:17 -05:00

55 lines
1.8 KiB
C++

// See the file "COPYING" in the main distribution directory for copyright.
#ifndef ANALYZER_PROTOCOL_RPC_MOUNT_H
#define ANALYZER_PROTOCOL_RPC_MOUNT_H
#include "RPC.h"
#include "XDR.h"
#include "Event.h"
namespace analyzer { namespace rpc {
class MOUNT_Interp : public RPC_Interpreter {
public:
MOUNT_Interp(analyzer::Analyzer* arg_analyzer) : RPC_Interpreter(arg_analyzer) { }
protected:
int RPC_BuildCall(RPC_CallInfo* c, const u_char*& buf, int& n);
int RPC_BuildReply(RPC_CallInfo* c, BifEnum::rpc_status rpc_status,
const u_char*& buf, int& n, double start_time,
double last_time, int reply_len);
// Returns a new val_list that already has a conn_val, rpc_status and
// mount_status. These are the first parameters for each mount_* event
// ...
val_list* event_common_vl(RPC_CallInfo *c, BifEnum::rpc_status rpc_status,
BifEnum::MOUNT3::status_t mount_status,
double rep_start_time, double rep_last_time,
int reply_len);
// These methods parse the appropriate MOUNTv3 "type" out of buf. If
// there are any errors (i.e., buffer to short, etc), buf will be set
// to 0. However, the methods might still return an allocated Val * !
// So, you might want to Unref() the Val if buf is 0. Method names
// are based on the type names of RFC 1813.
EnumVal* mount3_auth_flavor(const u_char*& buf, int& n);
StringVal* mount3_fh(const u_char*& buf, int& n);
RecordVal* mount3_dirmntargs(const u_char*&buf, int &n);
StringVal* mount3_filename(const u_char*& buf, int& n);
RecordVal* mount3_mnt_reply(const u_char*& buf, int& n, BifEnum::MOUNT3::status_t status);
};
class MOUNT_Analyzer : public RPC_Analyzer {
public:
MOUNT_Analyzer(Connection* conn);
virtual void Init();
static analyzer::Analyzer* Instantiate(Connection* conn)
{ return new MOUNT_Analyzer(conn); }
};
} } // namespace analyzer::*
#endif