-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauth.py
109 lines (88 loc) · 3.18 KB
/
auth.py
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
from database import *;
from api import *;
from lib import *;
#-2 (global block list)
#-1 (group block list)
#0 (common user)
#1 (named)
#2 (group white list)
#3 (global white list)
#4 (labeled 群主给头衔)
#5 (group junior manager)
#6 (global junior manager)
#7 (group manager)
#8 (group senior manager)
#9 (global senior namager)
#10 (bot manager)
#11 (group owner)
#12 (bot owner)
def get_global_authlevel(qqid):
n = execute('SELECT level FROM user_level WHERE qqid = %d and groupid = 0' % (qqid))
if(0 == n):
execute('INSERT INTO user_level (qqid, groupid, level) values (%d, 0, 0)' % (qqid))
db.commit();
return 0;
else:
return cursor.fetchone()[0];
def get_native_authlevel(qqid, groupid):
role = get_group_member_role(groupid, qqid);
if role == "owner":
ret = 11;
elif role == "admin":
ret = 7;
elif get_group_member_title(groupid, qqid) != "":
ret = 4;
elif get_group_member_card(groupid, qqid) != "":
ret = 1;
else:
ret = 0;
return ret;
def get_defined_authlevel(qqid, groupid):
n = execute('SELECT level FROM user_level WHERE qqid = %d and groupid = %d' % (qqid, groupid))
if(0 == n):
return 0;
else:
return cursor.fetchone()[0];
def get_local_authlevel(qqid, groupid):
return max(get_defined_authlevel(qqid, groupid), get_native_authlevel(qqid, groupid))
def get_authlevel(qqid, groupid):
gl = get_global_authlevel(qqid);
lo = get_local_authlevel(qqid, groupid);
#print((get_global_authlevel(qqid), get_defined_authlevel(qqid, groupid), get_native_authlevel(qqid, groupid)))
if(gl == 0 or lo == 0):
return gl + lo;
elif(gl * lo < 0):
return lo;
else:
return max(gl,lo);
def set_global_authlevel(qqid, level):
n = execute('SELECT level FROM user_level WHERE qqid = %d and groupid = 0' % (qqid))
if(0 == n):
execute('INSERT INTO user_level (qqid, groupid, level) values (%d, 0, %d)' % (qqid, level))
else:
execute('UPDATE user_level SET level = %d WHERE qqid = %d and groupid = 0' % (level, qqid))
db.commit();
return n;
def set_local_authlevel(qqid, groupid, level):
n = execute('SELECT level FROM user_level WHERE qqid = %d and groupid = %d' % (qqid, groupid))
if(0 == n):
execute('INSERT INTO user_level (qqid, groupid, level) values (%d, %d, %d)' % (qqid, groupid, level))
else:
execute('UPDATE user_level SET level = %d WHERE qqid = %d and groupid = %d' % (level, qqid, groupid))
db.commit();
return n;
def showauth(args, groupid, qqid):
clean_cache();
print(get_authlevel(qqid, groupid))
if(len(args) == 1):
return get_authlevel(qqid, groupid);
elif(len(args) == 2):
aimqqid = read_qqid(args[1]);
print(get_authlevel(aimqqid, groupid))
if(get_authlevel(qqid, groupid)<5):
return "权限不足,请重试"
elif(get_authlevel(qqid, groupid)<get_authlevel(aimqqid, groupid)):
return "权限不足,请重试"
else:
n = get_authlevel(aimqqid, groupid);
return "%d的权限值是:%d" %(aimqqid, n);