summaryrefslogtreecommitdiff
path: root/src/map/log.h
blob: 66375ea4a4cb10bd6bdb7b20d0a0f6d2e07c3453 (plain) (blame)
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
// Copyright (c) Athena Dev Teams - Licensed under GNU GPL
// For more information, see LICENCE in the main folder

#ifndef _LOG_H_
#define _LOG_H_

//#include "map.h"
struct map_session_data;
struct mob_data;
struct item;

//New logs
void log_pick_pc(struct map_session_data *sd, const char *type, int nameid, int amount, struct item *itm);
void log_pick_mob(struct mob_data *md, const char *type, int nameid, int amount, struct item *itm);
void log_zeny(struct map_session_data *sd, char *type, struct map_session_data *src_sd, int amount);

void log_npc(struct map_session_data *sd, const char *message);
void log_chat(const char* type, int type_id, int src_charid, int src_accid, const char* map, int x, int y, const char* dst_charname, const char* message);
void log_atcommand(struct map_session_data *sd, const char *message);

//Old, but useful logs
void log_branch(struct map_session_data *sd);
void log_mvpdrop(struct map_session_data *sd, int monster_id, int *log_mvp);

int log_config_read(char *cfgName);

typedef enum log_what
{
	LOG_ALL                 = 0xFFFF,
	LOG_TRADES              = 0x0002,
	LOG_VENDING             = 0x0004,
	LOG_PLAYER_ITEMS        = 0x0008, // dropped/picked
	LOG_MONSTER_ITEMS       = 0x0010, // dropped/looted
	LOG_NPC_TRANSACTIONS    = 0x0020, // npc shops?
	LOG_SCRIPT_TRANSACTIONS = 0x0040,
	LOG_STOLEN_ITEMS        = 0x0080, // stolen from mobs
	LOG_USED_ITEMS          = 0x0100, // used by player
	LOG_MVP_PRIZE           = 0x0200,
	LOG_COMMAND_ITEMS       = 0x0400, // created/deleted through @/# commands
	LOG_STORAGE_ITEMS       = 0x0800, // placed/retrieved from storage
	LOG_GSTORAGE_ITEMS      = 0x1000, // placed/retrieved from guild storage
	LOG_MAILS               = 0x2000, // mail system transactions
	LOG_BUYING_STORE        = 0x4000, // buying store transactions
}
log_what;

extern struct Log_Config
{
	enum log_what enable_logs;
	int filter;
	bool sql_logs;
	int rare_items_log,refine_items_log,price_items_log,amount_items_log; //for filter
	int branch, drop, mvpdrop, zeny, gm, npc, chat;
	char log_branch[64], log_pick[64], log_zeny[64], log_mvpdrop[64], log_gm[64], log_npc[64], log_chat[64];
	char log_branch_db[32], log_pick_db[32], log_zeny_db[32], log_mvpdrop_db[32], log_gm_db[32], log_npc_db[32], log_chat_db[32];
}
log_config;

#endif /* _LOG_H_ */