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
|
// Copyright (c) Hercules Dev Team, licensed under GNU GPL.
// See the LICENSE file
// Portions Copyright (c) Athena Dev Teams
#ifndef _PC_GROUPS_H_
#define _PC_GROUPS_H_
/// PC permissions
enum e_pc_permission {
PC_PERM_NONE = 0, // #0
PC_PERM_TRADE = 0x000001, // #1
PC_PERM_PARTY = 0x000002,
PC_PERM_ALL_SKILL = 0x000004,
PC_PERM_USE_ALL_EQUIPMENT = 0x000008,
PC_PERM_SKILL_UNCONDITIONAL = 0x000010,
PC_PERM_JOIN_ALL_CHAT = 0x000020,
PC_PERM_NO_CHAT_KICK = 0x000040,
PC_PERM_HIDE_SESSION = 0x000080,
PC_PERM_WHO_DISPLAY_AID = 0x000100,
PC_PERM_RECEIVE_HACK_INFO = 0x000200, // #10
PC_PERM_WARP_ANYWHERE = 0x000400,
PC_PERM_VIEW_HPMETER = 0x000800,
PC_PERM_VIEW_EQUIPMENT = 0x001000,
PC_PERM_USE_CHECK = 0x002000,
PC_PERM_USE_CHANGEMAPTYPE = 0x004000,
PC_PERM_USE_ALL_COMMANDS = 0x008000,
PC_PERM_RECEIVE_REQUESTS = 0x010000,
PC_PERM_SHOW_BOSS = 0x020000,
PC_PERM_DISABLE_PVM = 0x040000,
PC_PERM_DISABLE_PVP = 0x080000, // #20
PC_PERM_DISABLE_CMD_DEAD = 0x100000,
PC_PERM_HCHSYS_ADMIN = 0x200000,
};
// Cached config settings for quick lookup
struct GroupSettings {
unsigned int id; // groups.[].id
int level; // groups.[].level
char *name; // copy of groups.[].name
unsigned int e_permissions; // packed groups.[].permissions
bool log_commands; // groups.[].log_commands
int index; // internal index of the group (contiguous range starting at 0) [Ind]
/// Following are used/available only during config reading
config_setting_t *commands; // groups.[].commands
config_setting_t *permissions; // groups.[].permissions
config_setting_t *inherit; // groups.[].inherit
bool inheritance_done; // have all inheritance rules been evaluated?
config_setting_t *root; // groups.[]
};
struct pc_groups_permission_table {
char *name;
unsigned int permission;
};
typedef struct GroupSettings GroupSettings;
struct pc_groups_interface {
/* */
DBMap* db; // id -> GroupSettings
DBMap* name_db; // name -> GroupSettings
/* */
struct pc_groups_permission_table *permissions;
unsigned char permission_count;
/* */
void (*init) (void);
void (*final) (void);
void (*reload) (void);
/* */
GroupSettings* (*get_dummy_group) (void);
bool (*exists) (int group_id);
GroupSettings* (*id2group) (int group_id);
bool (*has_permission) (GroupSettings *group, unsigned int permission);
bool (*should_log_commands) (GroupSettings *group);
const char* (*get_name) (GroupSettings *group);
int (*get_level) (GroupSettings *group);
int (*get_idx) (GroupSettings *group);
unsigned int (*add_permission) (const char *name);
};
struct pc_groups_interface *pcg;
void pc_groups_defaults(void);
#endif // _PC_GROUPS_H_
|