summaryrefslogtreecommitdiffstats
path: root/src/binlog.h
blob: 84fba3db6d3a6455491714360a77ccdf2c3bba58 (plain)
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
#ifndef RSPAMD_BINLOG_H
#define RSPAMD_BINLOG_H

#include "config.h"
#include "main.h"
#include "statfile.h"

/* How much records are in a single index */
#define BINLOG_IDX_LEN 200
#define METAINDEX_LEN 1024

/* Assume 8 bytes words */
struct rspamd_binlog_header {
	char magic[3];
	char version[2];
	char padding[3];
	uint64_t create_time;
};

struct rspamd_binlog_index {
	uint64_t time;
	uint64_t seek;
	uint32_t len;
};

struct rspamd_index_block {
	struct rspamd_binlog_index indexes[BINLOG_IDX_LEN];
	uint32_t last_index;
};

struct rspamd_binlog_metaindex {
	uint64_t indexes[METAINDEX_LEN];
	uint64_t last_index;
};

struct rspamd_binlog_element {
	uint32_t h1;
	uint32_t h2;
	float value;
} __attribute__((__packed__));

struct rspamd_binlog {
	char *filename;
	time_t rotate_time;
	int rotate_jitter;
	uint64_t cur_seq;
	int fd;
	memory_pool_t *pool;

	struct rspamd_binlog_header header;
	struct rspamd_binlog_metaindex *metaindex;
	struct rspamd_index_block *cur_idx;
};

struct classifier_config;

struct rspamd_binlog* binlog_open (memory_pool_t *pool, const char *path, time_t rotate_time, int rotate_jitter);
void binlog_close (struct rspamd_binlog *log);
gboolean binlog_insert (struct rspamd_binlog *log, GTree *nodes);
gboolean binlog_sync (struct rspamd_binlog *log, uint64_t from_rev, uint64_t from_time, GByteArray **rep);
void maybe_write_binlog (struct classifier_config *ccf, const char *symbol, GTree *nodes);

#endif