/usr/include/atheme/privs.h is in atheme-services 7.2.9-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | /*
* Copyright (C) 2005 Jilles Tjoelker, et al.
* Rights to this code are as documented in doc/LICENSE.
*
* Fine grained services operator privileges
*
*/
#ifndef PRIVS_H
#define PRIVS_H
#define PRIV_NONE NULL
/* nickserv/userserv */
#define PRIV_USER_AUSPEX "user:auspex"
#define PRIV_USER_ADMIN "user:admin"
#define PRIV_USER_SENDPASS "user:sendpass"
#define PRIV_USER_VHOST "user:vhost"
#define PRIV_USER_FREGISTER "user:fregister"
/* chanserv */
#define PRIV_CHAN_AUSPEX "chan:auspex"
#define PRIV_CHAN_ADMIN "chan:admin"
#define PRIV_CHAN_CMODES "chan:cmodes"
#define PRIV_JOIN_STAFFONLY "chan:joinstaffonly"
/* nickserv/userserv+chanserv */
#define PRIV_MARK "user:mark"
#define PRIV_HOLD "user:hold"
#define PRIV_REG_NOLIMIT "user:regnolimit"
/* generic */
#define PRIV_SERVER_AUSPEX "general:auspex"
#define PRIV_VIEWPRIVS "general:viewprivs"
#define PRIV_FLOOD "general:flood"
#define PRIV_HELPER "general:helper"
#define PRIV_METADATA "general:metadata"
#define PRIV_ADMIN "general:admin"
/* operserv */
#define PRIV_OMODE "operserv:omode"
#define PRIV_AKILL "operserv:akill"
#define PRIV_MASS_AKILL "operserv:massakill"
#define PRIV_AKILL_ANYMASK "operserv:akill-anymask"
#define PRIV_JUPE "operserv:jupe"
#define PRIV_NOOP "operserv:noop"
#define PRIV_GLOBAL "operserv:global"
#define PRIV_GRANT "operserv:grant"
#define PRIV_OVERRIDE "operserv:override"
/* saslserv */
#define PRIV_IMPERSONATE_CLASS_FMT "impersonate:class:%s"
#define PRIV_IMPERSONATE_ENTITY_FMT "impersonate:entity:%s"
#define PRIV_IMPERSONATE_ANY "impersonate:any"
/* other access levels */
#define AC_NONE NULL /* anyone */
#define AC_DISABLED "special:disabled" /* noone */
#define AC_AUTHENTICATED "special:authenticated"
/* please do not use the following anymore */
#define AC_IRCOP "special:ircop"
#define AC_SRA "general:admin"
struct operclass_ {
char *name;
char *privs; /* priv1 priv2 priv3... */
int flags;
mowgli_node_t node;
};
#define OPERCLASS_NEEDOPER 0x1 /* only give privs to IRCops */
#define OPERCLASS_BUILTIN 0x2 /* builtin */
/* soper list struct */
struct soper_ {
myuser_t *myuser;
char *name;
operclass_t *operclass;
char *classname;
int flags;
char *password;
};
#define SOPER_CONF 0x1 /* oper is listed in atheme.conf */
/* privs.c */
E mowgli_list_t operclasslist;
E mowgli_list_t soperlist;
E void init_privs(void);
E operclass_t *operclass_add(const char *name, const char *privs, int flags);
E void operclass_delete(operclass_t *operclass);
E operclass_t *operclass_find(const char *name);
E soper_t *soper_add(const char *name, const char *classname, int flags, const char *password);
E void soper_delete(soper_t *soper);
E soper_t *soper_find(myuser_t *myuser);
E soper_t *soper_find_named(const char *name);
E bool is_soper(myuser_t *myuser);
E bool is_conf_soper(myuser_t *myuser);
/* has_any_privs(): used to determine whether we should give detailed
* messages about disallowed things
* warning: do not use this for any kind of real privilege! */
E bool has_any_privs(sourceinfo_t *);
E bool has_any_privs_user(user_t *);
/* has_priv(): for sources of commands */
E bool has_priv(sourceinfo_t *, const char *);
/* has_priv_user(): for online users */
E bool has_priv_user(user_t *, const char *);
/* has_priv_myuser(): channel succession etc */
E bool has_priv_myuser(myuser_t *, const char *);
/* has_priv_operclass(): /os specs etc */
E bool has_priv_operclass(operclass_t *, const char *);
/* has_all_operclass(): checks if source has all privs in operclass */
E bool has_all_operclass(sourceinfo_t *, operclass_t *);
/* get_sourceinfo_soper(): get the specific operclass role which is granting
* privilege authority
*/
E const soper_t *get_sourceinfo_soper(sourceinfo_t *si);
/* get_sourceinfo_operclass(): get the specific operclass role which is granting
* privilege authority
*/
E const operclass_t *get_sourceinfo_operclass(sourceinfo_t *si);
#endif /* PRIVS_H */
/* vim:cinoptions=>s,e0,n0,f0,{0,}0,^0,=s,ps,t0,c3,+s,(2s,us,)20,*30,gs,hs
* vim:ts=8
* vim:sw=8
* vim:noexpandtab
*/
|