goober/modules/central.py

99 lines
3.8 KiB
Python
Raw Normal View History

2025-06-20 23:48:10 +02:00
import requests
import os
import modules.globalvars as gv
from modules.volta.main import _
2025-06-20 23:48:10 +02:00
from modules.markovmemory import get_file_info
2025-07-09 15:05:06 +02:00
import logging
logger = logging.getLogger("goober")
2025-06-20 23:48:10 +02:00
# Ping the server to check if it's alive and send some info
2025-06-20 23:48:10 +02:00
def ping_server():
if gv.ALIVEPING == "false":
# If pinging is disabled, print message and set environment variable
2025-07-09 15:05:06 +02:00
print(f"{gv.YELLOW}{(_('pinging_disabled'))}")
2025-06-20 23:48:10 +02:00
os.environ['gooberauthenticated'] = 'No'
return
# Get server alert message
2025-06-20 23:48:10 +02:00
goobres = requests.get(f"{gv.VERSION_URL}/alert")
2025-07-09 15:05:06 +02:00
logger.info(f"{(_('goober_server_alert'))}{goobres.text}")
# Gather file info for payload
2025-06-20 23:48:10 +02:00
file_info = get_file_info(gv.MEMORY_FILE)
payload = {
"name": gv.NAME,
"memory_file_info": file_info,
"version": gv.local_version,
"slash_commands": gv.slash_commands_enabled,
"token": gv.gooberTOKEN
}
try:
# Send ping to server
2025-06-20 23:48:10 +02:00
response = requests.post(gv.VERSION_URL+"/ping", json=payload)
if response.status_code == 200:
# Success: print message and set environment variable
2025-07-09 15:05:06 +02:00
logger.info(f"{(_('goober_ping_success')).format(NAME=gv.NAME)}")
2025-06-20 23:48:10 +02:00
os.environ['gooberauthenticated'] = 'Yes'
else:
# Failure: print error and set environment variable
2025-07-09 15:05:06 +02:00
logger.error(f"{(_('goober_ping_fail'))} {response.status_code}")
2025-06-20 23:48:10 +02:00
os.environ['gooberauthenticated'] = 'No'
except Exception as e:
# Exception: print error and set environment variable
2025-07-09 15:05:06 +02:00
logger.error(f"{(_('goober_ping_fail2'))} {str(e)}")
2025-06-20 23:48:10 +02:00
os.environ['gooberauthenticated'] = 'No'
# Check if a given name is available for registration
2025-06-20 23:48:10 +02:00
def is_name_available(NAME):
if os.getenv("gooberTOKEN"):
# If token is already set, skip check
2025-06-20 23:48:10 +02:00
return
try:
# Send request to check name availability
2025-06-20 23:48:10 +02:00
response = requests.post(f"{gv.VERSION_URL}/check-if-available", json={"name": NAME}, headers={"Content-Type": "application/json"})
if response.status_code == 200:
data = response.json()
return data.get("available", False)
else:
# Print error if request failed
2025-07-09 22:57:59 +02:00
logger.error(f"{(_('name_check'))}", response.json())
2025-06-20 23:48:10 +02:00
return False
except Exception as e:
# Print exception if request failed
2025-07-09 15:05:06 +02:00
logger.error(f"{(_('name_check2'))}", e)
2025-06-20 23:48:10 +02:00
return False
# Register a new name with the server
2025-06-20 23:48:10 +02:00
def register_name(NAME):
try:
if gv.ALIVEPING == False:
# If pinging is disabled, do nothing
2025-06-20 23:48:10 +02:00
return
# Check if the name is available
2025-06-20 23:48:10 +02:00
if not is_name_available(NAME):
2025-07-09 22:57:59 +02:00
if os.getenv("GOOBERTOKEN"):
2025-06-20 23:48:10 +02:00
return
# Name taken: print error and exit
2025-07-09 15:05:06 +02:00
logger.critical(f"{(_('name_taken'))}")
2025-06-20 23:48:10 +02:00
quit()
# Register the name
2025-06-20 23:48:10 +02:00
response = requests.post(f"{gv.VERSION_URL}/register", json={"name": NAME}, headers={"Content-Type": "application/json"})
if response.status_code == 200:
data = response.json()
token = data.get("token")
if not os.getenv("gooberTOKEN"):
# Print instructions to add token and exit
2025-07-09 15:05:06 +02:00
logger.info(f"{(_('add_token')).format(token=token)} gooberTOKEN=<token>.")
2025-06-20 23:48:10 +02:00
quit()
else:
print(f"{gv.GREEN}{gv.gv.RESET}")
2025-06-20 23:48:10 +02:00
return token
else:
# Print error if registration failed
2025-07-09 15:05:06 +02:00
logger.critical(f"{gv.RED}{(_('token_exists')).format()}", response.json())
2025-06-20 23:48:10 +02:00
return None
except Exception as e:
# Print exception if registration failed
2025-07-09 15:05:06 +02:00
logger.critical(f"{gv.RED}{(_('registration_error')).format()}", e)
2025-06-20 23:48:10 +02:00
return None
# Attempt to register the name at module load
2025-06-20 23:48:10 +02:00
register_name(gv.NAME)