mirror of
https://github.com/SantaSpeen/Rcon-VK-Bot.git
synced 2025-08-18 00:55:51 +00:00
Perms system
This commit is contained in:
parent
4d560aa15a
commit
b790a97500
21
config.json
21
config.json
@ -1,21 +0,0 @@
|
|||||||
{
|
|
||||||
"rcon": {
|
|
||||||
"host": "",
|
|
||||||
"port": 0,
|
|
||||||
"password": ""
|
|
||||||
},
|
|
||||||
"vk": {
|
|
||||||
"token": "",
|
|
||||||
"admins": []
|
|
||||||
},
|
|
||||||
"permissions": {
|
|
||||||
"admin": {
|
|
||||||
"lvl": 100,
|
|
||||||
"allow": true
|
|
||||||
},
|
|
||||||
"helper": {
|
|
||||||
"lvl": 1,
|
|
||||||
"allow": ["say"]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
12
src/config.json
Normal file
12
src/config.json
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"rcon": {
|
||||||
|
"host": "",
|
||||||
|
"port": 0,
|
||||||
|
"password": ""
|
||||||
|
},
|
||||||
|
"vk": {
|
||||||
|
"token": "",
|
||||||
|
"help_file": "help_message.txt"
|
||||||
|
},
|
||||||
|
"permission_file": "permissions.json"
|
||||||
|
}
|
4
src/help_message.txt
Normal file
4
src/help_message.txt
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
Тебе не нужна помощь, ты и так беспомощный, кожаный ублюдок. Так уж и быть, подскажу пару команд...
|
||||||
|
!help - Вывести эту "справку"
|
||||||
|
!online - Показать текущий онлайн сервере
|
||||||
|
Бот сделан кожанным петухом - админом, все вопросы к нему, я не причём.
|
@ -16,17 +16,54 @@ log("Starting..")
|
|||||||
with open('config-t.json' if "-t" in sys.argv else 'config.json') as f:
|
with open('config-t.json' if "-t" in sys.argv else 'config.json') as f:
|
||||||
config = json.load(f)
|
config = json.load(f)
|
||||||
|
|
||||||
|
with open('help_message.txt') as f:
|
||||||
|
help_message = f.read()
|
||||||
|
|
||||||
vk = vk.API(access_token=config['vk']['token'], v=5.131)
|
vk = vk.API(access_token=config['vk']['token'], v=5.131)
|
||||||
group_id = vk.groups.getById()[0]['id']
|
group_id = vk.groups.getById()[0]['id']
|
||||||
log(f"Group id: {group_id}")
|
log(f"Group id: {group_id}")
|
||||||
admins = config['vk']['admins']
|
|
||||||
stoplist = config['vk']['stoplist']
|
|
||||||
|
|
||||||
host = config['rcon']['host']
|
host = config['rcon']['host']
|
||||||
port = config['rcon']['port']
|
port = config['rcon']['port']
|
||||||
password = config['rcon']['password']
|
password = config['rcon']['password']
|
||||||
|
|
||||||
|
|
||||||
|
class Permissions:
|
||||||
|
|
||||||
|
def __init__(self, permission_file):
|
||||||
|
self.permission_file = permission_file
|
||||||
|
self._raw_file = {}
|
||||||
|
self._members = {}
|
||||||
|
|
||||||
|
def _parse_file(self):
|
||||||
|
with open(self.permission_file) as pf:
|
||||||
|
self._raw_file = json.load(pf)
|
||||||
|
|
||||||
|
for role, role_data in self._raw_file.items():
|
||||||
|
members = role_data.get("members", [])
|
||||||
|
allow = role_data.get("allow", [])
|
||||||
|
for member in members:
|
||||||
|
self._members[member] = {
|
||||||
|
"role": role,
|
||||||
|
"allow": allow
|
||||||
|
}
|
||||||
|
|
||||||
|
def is_allow(self, vk_id, cmd):
|
||||||
|
u = self._members.get(vk_id)
|
||||||
|
if u is not None:
|
||||||
|
role = u['role']
|
||||||
|
allow = u['allow']
|
||||||
|
if allow is True:
|
||||||
|
return True, role
|
||||||
|
elif cmd in allow:
|
||||||
|
return True, role
|
||||||
|
return False, role
|
||||||
|
return False, None
|
||||||
|
|
||||||
|
|
||||||
|
perms = Permissions(config['permission_file'])
|
||||||
|
|
||||||
|
|
||||||
def fix_rcon_text(_srt):
|
def fix_rcon_text(_srt):
|
||||||
try:
|
try:
|
||||||
_srt = list(_srt)
|
_srt = list(_srt)
|
||||||
@ -63,35 +100,32 @@ def write(peer_id, message):
|
|||||||
if i > 30:
|
if i > 30:
|
||||||
log("Found very long message...", 1)
|
log("Found very long message...", 1)
|
||||||
break
|
break
|
||||||
write(peer_id, message[:4095*i])
|
write(peer_id, message[:4095 * i])
|
||||||
else:
|
else:
|
||||||
vk.messages.send(message=message, peer_id=peer_id, random_id=0)
|
vk.messages.send(message=message, peer_id=peer_id, random_id=0)
|
||||||
|
|
||||||
|
|
||||||
def rcon_cmd_handle(cmd, from_id, peer_id, _write=True):
|
def rcon_cmd_handle(cmd, from_id, peer_id, _write=True):
|
||||||
answer = rcon(cmd)
|
a, r = perms.is_allow(from_id, cmd.split()[0])
|
||||||
log(f"User: {from_id} in Chat: {peer_id} use RCON cmd: \"{cmd}\", with answer: \"{answer}\"")
|
if a:
|
||||||
if _write:
|
answer = rcon(cmd)
|
||||||
write(peer_id, f"RCON:\n{answer}")
|
log(f"User: {from_id}({r}) in Chat: {peer_id} use RCON cmd: \"{cmd}\", with answer: \"{answer}\"")
|
||||||
|
if _write:
|
||||||
|
write(peer_id, f"RCON:\n{answer}")
|
||||||
|
else:
|
||||||
|
return answer
|
||||||
else:
|
else:
|
||||||
return answer
|
log(f"User: {from_id}({r}) in Chat: {peer_id} no have rights RCON cmd: \"{cmd}\".")
|
||||||
|
|
||||||
|
|
||||||
def message_handle(message):
|
def message_handle(message):
|
||||||
from_id = message['from_id']
|
from_id = message['from_id']
|
||||||
peer_id = message['peer_id']
|
peer_id = message['peer_id']
|
||||||
text = message['text']
|
text = message['text']
|
||||||
if from_id in admins:
|
if text.startswith(".rcon "):
|
||||||
if text.startswith(".rcon "):
|
rcon_cmd_handle(text[6:], from_id, peer_id)
|
||||||
rcon_cmd_handle(text[6:], from_id, peer_id)
|
|
||||||
elif text.startswith(".wl "):
|
|
||||||
rcon_cmd_handle(f'whitelist add {text[4:]}', from_id, peer_id)
|
|
||||||
if text == "!help":
|
if text == "!help":
|
||||||
write(peer_id, "Тебе не нужна помощь, ты и так беспомощный, кожаный ублюдок."
|
write(peer_id, help_message)
|
||||||
"Так уж и быть, подскажу пару команд..\n\n"
|
|
||||||
"!help - Вывести эту \"справку\"\n"
|
|
||||||
"!online - Показать текущий онлайн сервере\n\n"
|
|
||||||
"Бот сделан кожанным петухом - админом, все вопросы к нему, я не причём.")
|
|
||||||
elif text == "!online":
|
elif text == "!online":
|
||||||
text = rcon_cmd_handle('list', from_id, peer_id, False).replace("\n", "")
|
text = rcon_cmd_handle('list', from_id, peer_id, False).replace("\n", "")
|
||||||
now = text[10:11]
|
now = text[10:11]
|
10
src/permissions.json
Normal file
10
src/permissions.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"admin": {
|
||||||
|
"allow": true,
|
||||||
|
"members": [123]
|
||||||
|
},
|
||||||
|
"helper": {
|
||||||
|
"allow": ["say", "warn"],
|
||||||
|
"members": [111, 432]
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user