mirror of
https://github.com/pacnpal/Pac-cogs.git
synced 2025-12-20 02:41:06 -05:00
fixed imports again
This commit is contained in:
@@ -3,14 +3,15 @@
|
||||
import logging
|
||||
from typing import Dict, Any, List
|
||||
from datetime import datetime
|
||||
import discord # type: ignore
|
||||
import discord # type: ignore
|
||||
|
||||
try:
|
||||
# Try relative imports first
|
||||
from .exceptions import ConfigurationError as ConfigError
|
||||
except ImportError:
|
||||
# Fall back to absolute imports if relative imports fail
|
||||
# from videoarchiver.config.exceptions import ConfigurationError as ConfigError
|
||||
# try:
|
||||
# Try relative imports first
|
||||
from .exceptions import ConfigurationError as ConfigError
|
||||
|
||||
# except ImportError:
|
||||
# Fall back to absolute imports if relative imports fail
|
||||
# from videoarchiver.config.exceptions import ConfigurationError as ConfigError
|
||||
|
||||
logger = logging.getLogger("SettingsFormatter")
|
||||
|
||||
@@ -22,19 +23,17 @@ class SettingsFormatter:
|
||||
self.embed_color = discord.Color.blue()
|
||||
|
||||
async def format_settings_embed(
|
||||
self,
|
||||
guild: discord.Guild,
|
||||
settings: Dict[str, Any]
|
||||
self, guild: discord.Guild, settings: Dict[str, Any]
|
||||
) -> discord.Embed:
|
||||
"""Format guild settings into a Discord embed
|
||||
|
||||
|
||||
Args:
|
||||
guild: Discord guild
|
||||
settings: Guild settings dictionary
|
||||
|
||||
|
||||
Returns:
|
||||
discord.Embed: Formatted settings embed
|
||||
|
||||
|
||||
Raises:
|
||||
ConfigError: If formatting fails
|
||||
"""
|
||||
@@ -42,7 +41,7 @@ class SettingsFormatter:
|
||||
embed = discord.Embed(
|
||||
title="Video Archiver Settings",
|
||||
color=self.embed_color,
|
||||
timestamp=datetime.utcnow()
|
||||
timestamp=datetime.utcnow(),
|
||||
)
|
||||
|
||||
# Add sections
|
||||
@@ -61,111 +60,98 @@ class SettingsFormatter:
|
||||
raise ConfigError(f"Failed to format settings: {str(e)}")
|
||||
|
||||
async def _add_core_settings(
|
||||
self,
|
||||
embed: discord.Embed,
|
||||
guild: discord.Guild,
|
||||
settings: Dict[str, Any]
|
||||
self, embed: discord.Embed, guild: discord.Guild, settings: Dict[str, Any]
|
||||
) -> None:
|
||||
"""Add core settings to embed"""
|
||||
embed.add_field(
|
||||
name="Core Settings",
|
||||
value="\n".join([
|
||||
f"**Enabled:** {settings['enabled']}",
|
||||
f"**Database Enabled:** {settings['use_database']}",
|
||||
f"**Update Check Disabled:** {settings['disable_update_check']}"
|
||||
]),
|
||||
inline=False
|
||||
value="\n".join(
|
||||
[
|
||||
f"**Enabled:** {settings['enabled']}",
|
||||
f"**Database Enabled:** {settings['use_database']}",
|
||||
f"**Update Check Disabled:** {settings['disable_update_check']}",
|
||||
]
|
||||
),
|
||||
inline=False,
|
||||
)
|
||||
|
||||
async def _add_channel_settings(
|
||||
self,
|
||||
embed: discord.Embed,
|
||||
guild: discord.Guild,
|
||||
settings: Dict[str, Any]
|
||||
self, embed: discord.Embed, guild: discord.Guild, settings: Dict[str, Any]
|
||||
) -> None:
|
||||
"""Add channel settings to embed"""
|
||||
# Get channels with error handling
|
||||
channels = await self._get_channel_mentions(guild, settings)
|
||||
|
||||
|
||||
embed.add_field(
|
||||
name="Channel Settings",
|
||||
value="\n".join([
|
||||
f"**Archive Channel:** {channels['archive']}",
|
||||
f"**Notification Channel:** {channels['notification']}",
|
||||
f"**Log Channel:** {channels['log']}",
|
||||
f"**Monitored Channels:**\n{channels['monitored']}"
|
||||
]),
|
||||
inline=False
|
||||
value="\n".join(
|
||||
[
|
||||
f"**Archive Channel:** {channels['archive']}",
|
||||
f"**Notification Channel:** {channels['notification']}",
|
||||
f"**Log Channel:** {channels['log']}",
|
||||
f"**Monitored Channels:**\n{channels['monitored']}",
|
||||
]
|
||||
),
|
||||
inline=False,
|
||||
)
|
||||
|
||||
async def _add_permission_settings(
|
||||
self,
|
||||
embed: discord.Embed,
|
||||
guild: discord.Guild,
|
||||
settings: Dict[str, Any]
|
||||
self, embed: discord.Embed, guild: discord.Guild, settings: Dict[str, Any]
|
||||
) -> None:
|
||||
"""Add permission settings to embed"""
|
||||
allowed_roles = await self._get_role_names(guild, settings["allowed_roles"])
|
||||
|
||||
|
||||
embed.add_field(
|
||||
name="Permission Settings",
|
||||
value=f"**Allowed Roles:**\n{allowed_roles}",
|
||||
inline=False
|
||||
inline=False,
|
||||
)
|
||||
|
||||
async def _add_video_settings(
|
||||
self,
|
||||
embed: discord.Embed,
|
||||
settings: Dict[str, Any]
|
||||
self, embed: discord.Embed, settings: Dict[str, Any]
|
||||
) -> None:
|
||||
"""Add video settings to embed"""
|
||||
embed.add_field(
|
||||
name="Video Settings",
|
||||
value="\n".join([
|
||||
f"**Format:** {settings['video_format']}",
|
||||
f"**Max Quality:** {settings['video_quality']}p",
|
||||
f"**Max File Size:** {settings['max_file_size']}MB"
|
||||
]),
|
||||
inline=False
|
||||
value="\n".join(
|
||||
[
|
||||
f"**Format:** {settings['video_format']}",
|
||||
f"**Max Quality:** {settings['video_quality']}p",
|
||||
f"**Max File Size:** {settings['max_file_size']}MB",
|
||||
]
|
||||
),
|
||||
inline=False,
|
||||
)
|
||||
|
||||
async def _add_operation_settings(
|
||||
self,
|
||||
embed: discord.Embed,
|
||||
settings: Dict[str, Any]
|
||||
self, embed: discord.Embed, settings: Dict[str, Any]
|
||||
) -> None:
|
||||
"""Add operation settings to embed"""
|
||||
embed.add_field(
|
||||
name="Operation Settings",
|
||||
value="\n".join([
|
||||
f"**Delete After Repost:** {settings['delete_after_repost']}",
|
||||
f"**Message Duration:** {settings['message_duration']} hours",
|
||||
f"**Concurrent Downloads:** {settings['concurrent_downloads']}",
|
||||
f"**Max Retries:** {settings['max_retries']}",
|
||||
f"**Retry Delay:** {settings['retry_delay']}s"
|
||||
]),
|
||||
inline=False
|
||||
value="\n".join(
|
||||
[
|
||||
f"**Delete After Repost:** {settings['delete_after_repost']}",
|
||||
f"**Message Duration:** {settings['message_duration']} hours",
|
||||
f"**Concurrent Downloads:** {settings['concurrent_downloads']}",
|
||||
f"**Max Retries:** {settings['max_retries']}",
|
||||
f"**Retry Delay:** {settings['retry_delay']}s",
|
||||
]
|
||||
),
|
||||
inline=False,
|
||||
)
|
||||
|
||||
async def _add_site_settings(
|
||||
self,
|
||||
embed: discord.Embed,
|
||||
settings: Dict[str, Any]
|
||||
self, embed: discord.Embed, settings: Dict[str, Any]
|
||||
) -> None:
|
||||
"""Add site settings to embed"""
|
||||
enabled_sites = settings["enabled_sites"]
|
||||
sites_text = ", ".join(enabled_sites) if enabled_sites else "All sites"
|
||||
|
||||
embed.add_field(
|
||||
name="Enabled Sites",
|
||||
value=sites_text,
|
||||
inline=False
|
||||
)
|
||||
|
||||
embed.add_field(name="Enabled Sites", value=sites_text, inline=False)
|
||||
|
||||
async def _get_channel_mentions(
|
||||
self,
|
||||
guild: discord.Guild,
|
||||
settings: Dict[str, Any]
|
||||
self, guild: discord.Guild, settings: Dict[str, Any]
|
||||
) -> Dict[str, str]:
|
||||
"""Get channel mentions with error handling"""
|
||||
try:
|
||||
@@ -173,7 +159,7 @@ class SettingsFormatter:
|
||||
archive_channel = guild.get_channel(settings["archive_channel"])
|
||||
notification_channel = guild.get_channel(settings["notification_channel"])
|
||||
log_channel = guild.get_channel(settings["log_channel"])
|
||||
|
||||
|
||||
# Get monitored channels
|
||||
monitored_channels = []
|
||||
for channel_id in settings["monitored_channels"]:
|
||||
@@ -183,9 +169,17 @@ class SettingsFormatter:
|
||||
|
||||
return {
|
||||
"archive": archive_channel.mention if archive_channel else "Not set",
|
||||
"notification": notification_channel.mention if notification_channel else "Same as archive",
|
||||
"notification": (
|
||||
notification_channel.mention
|
||||
if notification_channel
|
||||
else "Same as archive"
|
||||
),
|
||||
"log": log_channel.mention if log_channel else "Not set",
|
||||
"monitored": "\n".join(monitored_channels) if monitored_channels else "All channels"
|
||||
"monitored": (
|
||||
"\n".join(monitored_channels)
|
||||
if monitored_channels
|
||||
else "All channels"
|
||||
),
|
||||
}
|
||||
|
||||
except Exception as e:
|
||||
@@ -194,14 +188,10 @@ class SettingsFormatter:
|
||||
"archive": "Error",
|
||||
"notification": "Error",
|
||||
"log": "Error",
|
||||
"monitored": "Error getting channels"
|
||||
"monitored": "Error getting channels",
|
||||
}
|
||||
|
||||
async def _get_role_names(
|
||||
self,
|
||||
guild: discord.Guild,
|
||||
role_ids: List[int]
|
||||
) -> str:
|
||||
async def _get_role_names(self, guild: discord.Guild, role_ids: List[int]) -> str:
|
||||
"""Get role names with error handling"""
|
||||
try:
|
||||
role_names = []
|
||||
@@ -209,8 +199,10 @@ class SettingsFormatter:
|
||||
role = guild.get_role(role_id)
|
||||
if role:
|
||||
role_names.append(role.name)
|
||||
|
||||
return ", ".join(role_names) if role_names else "All roles (no restrictions)"
|
||||
|
||||
return (
|
||||
", ".join(role_names) if role_names else "All roles (no restrictions)"
|
||||
)
|
||||
|
||||
except Exception as e:
|
||||
logger.error(f"Error getting role names: {e}")
|
||||
|
||||
Reference in New Issue
Block a user