Compare commits

..

5 Commits

Author SHA1 Message Date
6d01f0ef8d build and ver update 2023-07-24 16:17:30 +03:00
eea03c835f prompt fix 2023-07-24 16:12:35 +03:00
f28a783f7e Update About 2023-07-24 16:03:56 +03:00
dbb27ff6d5 Update About 2023-07-24 16:02:40 +03:00
e621c8dc7c lua event onConsoleInput 2023-07-24 15:37:26 +03:00
12 changed files with 47 additions and 21 deletions

View File

@ -4,6 +4,13 @@
**_[Status: Beta]_** \
BeamingDrive Multiplayer (BeamMP) server compatible with BeamMP clients.
Why did I decide to write my own kernel from scratch?\
I didn't like writing plugins in Lua after using Python; it was very inconvenient, there were always some nuances, which ultimately led me to create KuiToi!
**Our site**: [kuitoi.su](https://kuitoi.su) (WIP)\
**Our forum**: [forum.kuitoi.su](https://forum.kuitoi.su) (WIP)\
**Our discord**: [KuiToi](https://discord.gg/BAcgaAmdkJ)
## TODOs
- [x] Server core:

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.tcp_server.py
# Written by: SantaSpeen
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.tcp_server.py
# Written by: SantaSpeen
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,8 +1,8 @@
# Developed by KuiToi Dev
# File core.__init__.py
# Written by: SantaSpeen
# Version 1.3
# Core version: 0.4.1
# Version 1.4
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
# Special thanks to: AI Sage(https://poe.com/Sage), AI falcon-40b-v7(https://OpenBuddy.ai)
@ -10,8 +10,8 @@
__title__ = 'KuiToi-Server'
__description__ = 'BeamingDrive Multiplayer server compatible with BeamMP clients.'
__url__ = 'https://github.com/kuitoi/kuitoi-Server'
__version__ = '0.4.1'
__build__ = 1925 # Я это считаю лог файлами
__version__ = '0.4.3'
__build__ = 2125 # Я это считаю лог файлами
__author__ = 'SantaSpeen'
__author_email__ = 'admin@kuitoi.su'
__license__ = "FPA"
@ -102,7 +102,7 @@ if not config.Auth['private'] and not config.Auth['key']:
log.debug("Initializing console...")
console = Console()
console.builtins_hook()
# console.logger_hook()
console.logger_hook()
console.add_command("stop", console.stop, i18n.man_message_stop, i18n.help_message_stop)
console.add_command("exit", console.stop, i18n.man_message_exit, i18n.help_message_exit)

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.core.py
# Written by: SantaSpeen
# Version: 0.4.1
# Version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.core.pyi
# Written by: SantaSpeen
# Version 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.tcp_server.py
# Written by: SantaSpeen
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.tcp_server.pyi
# Written by: SantaSpeen
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.udp_server.py
# Written by: SantaSpeen
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -1,7 +1,7 @@
# Developed by KuiToi Dev
# File core.udp_server.py
# Written by: SantaSpeen
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import asyncio

View File

@ -2,7 +2,7 @@
# File core.utils.py
# Written by: SantaSpeen
# Version 1.1
# Core version: 0.4.1
# Core version: 0.4.3
# Licence: FPA
# (c) kuitoi.su 2023
import datetime

View File

@ -122,18 +122,29 @@ class Console:
self.__alias.update(custom_completer or {key: None})
self.__alias["man"].update({key: None})
self.__func.update({key: {"f": func}})
self.__man.update({key: f'html<seagreen>{i18n.man_for} <b>{key}</b>\n{man}</seagreen>' if man else None})
self.__man.update({key: f'html:<seagreen>{i18n.man_for} <b>{key}</b>\n{man}</seagreen>' if man else None})
self.__desc.update({key: desc})
self.__update_completer()
return self.__alias.copy()
def write(self, s: AnyStr):
if s.startswith("html"):
print_formatted_text(HTML(s[4:]))
def _write(self, t):
if t.startswith("html:"):
print_formatted_text(HTML(t[5:]))
else:
print_formatted_text(s)
print_formatted_text(t)
def write(self, s: AnyStr):
if isinstance(s, (list, tuple)):
for text in s:
self._write(text)
else:
self._write(s)
def log(self, s: AnyStr) -> None:
if isinstance(s, (list, tuple)):
for text in s:
self.__logger.info(f"{text}")
else:
self.__logger.info(f"{s}")
# self.write(s)
@ -201,12 +212,20 @@ class Console:
if cmd == "":
continue
else:
found_in_lua = False
d = ev.call_lua_event("onConsoleInput", cmd_in)
if len(d) > 0:
for text in d:
if text is not None:
found_in_lua = True
self.log(text)
command_object = self.__func.get(cmd)
if command_object:
out = command_object['f'](cmd_s[1:])
if out:
self.log(out)
else:
if not found_in_lua:
self.log(self.__not_found % cmd)
except KeyboardInterrupt:
raise KeyboardInterrupt