mirror of
https://github.com/agessaman/meshcore-bot.git
synced 2026-05-13 19:13:20 +00:00
4979687299
BUG-001: web viewer login/session auth (in web viewer commit) BUG-002: db_manager ALTER TABLE for missing channel_operations and feed_message_queue columns on startup BUG-015: scheduler thread blocked on future.result(); replaced all blocking waits with add_done_callback (fire-and-forget) BUG-016: reboot_radio sends meshcore.commands.reboot() before disconnect BUG-017: radio disconnect uses asyncio.wait_for(timeout=10) BUG-022: custom asyncio loop exception handler suppresses IndexError from meshcore parser at DEBUG level BUG-024: last_db_backup_run updated after each run; 2-min startup window; last-run seeded from DB on restart BUG-025: send_channel_message retries up to 2 times (2s delay) on no_event_received via _is_no_event_received() helper BUG-026: split_text_into_chunks() and get_max_message_length() added to CommandManager; keyword dispatch uses send_response_chunked() BUG-028: byte_data = b"" initialised before try block in decode_meshcore_packet to prevent UnboundLocalError in except handler TraceCommand: path nodes reversed and return path truncated; fixed format_elapsed_display: UTC normalisation before elapsed computation (#75) RepeaterManager: auto_manage_contacts guard before any purge logic (#50) Command aliases: [Aliases] config section injects shorthands at startup JSON logging: _JsonFormatter; json_logging = true in [Logging] Structured JSON logging compatible with Loki, Elasticsearch, Splunk Discord bridge, Telegram bridge, and all service plugins updated MeshGraph edge promotion logic corrected Shutdown: scheduler and meshcore disconnect joined cleanly; log spam fixed All modules: ruff and mypy cleanup applied (type annotations, imports)
69 lines
2.0 KiB
Python
69 lines
2.0 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
Reload Command
|
|
Allows admin users to reload the bot configuration without restarting
|
|
"""
|
|
|
|
from ..models import MeshMessage
|
|
from .base_command import BaseCommand
|
|
|
|
|
|
class ReloadCommand(BaseCommand):
|
|
"""Command for reloading bot configuration"""
|
|
|
|
# Plugin metadata
|
|
name = "reload"
|
|
keywords = ["reload", "reloadconfig", "configreload"]
|
|
description = "Reload bot configuration without restart (DM only, admin only)"
|
|
requires_dm = True
|
|
cooldown_seconds = 2
|
|
category = "admin"
|
|
|
|
def __init__(self, bot):
|
|
"""Initialize the reload command.
|
|
|
|
Args:
|
|
bot: The bot instance.
|
|
"""
|
|
super().__init__(bot)
|
|
|
|
def can_execute(self, message: MeshMessage) -> bool:
|
|
"""Check if this command can be executed (admin only)"""
|
|
if not self.requires_admin_access():
|
|
return False
|
|
return super().can_execute(message)
|
|
|
|
def requires_admin_access(self) -> bool:
|
|
"""Reload command requires admin access"""
|
|
return True
|
|
|
|
def get_help_text(self) -> str:
|
|
"""Get help text for the reload command.
|
|
|
|
Returns:
|
|
str: The help text for this command.
|
|
"""
|
|
return ("Reloads the bot configuration from config.ini without restarting.\n"
|
|
"Note: Radio/connection settings cannot be changed via reload.\n"
|
|
"If radio settings changed, restart the bot instead.\n"
|
|
"Usage: reload")
|
|
|
|
async def execute(self, message: MeshMessage) -> bool:
|
|
"""Execute the reload command.
|
|
|
|
Args:
|
|
message: The message triggering the command.
|
|
|
|
Returns:
|
|
bool: True if executed successfully, False otherwise.
|
|
"""
|
|
# Call the bot's reload_config method
|
|
success, msg = self.bot.reload_config()
|
|
|
|
if success:
|
|
await self.send_response(message, f"✓ {msg}")
|
|
else:
|
|
await self.send_response(message, f"✗ {msg}")
|
|
|
|
return True
|