Compare commits
No commits in common. "37ec0cf0c796062d8ee2d87e34805fec61a0ea77" and "0c76269e40304ba9f68764e9667b60e1af217c47" have entirely different histories.
37ec0cf0c7
...
0c76269e40
@ -187,13 +187,7 @@
|
|||||||
"type_error": "Der angegebene Wert ist keine Zahl! :("
|
"type_error": "Der angegebene Wert ist keine Zahl! :("
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"add": {
|
|
||||||
"xp": "Die {} von {} wurden um {} erhöht"
|
|
||||||
},
|
|
||||||
"remove": {
|
"remove": {
|
||||||
"xp": "Die {} von {} wurden um {} verringert"
|
|
||||||
},
|
|
||||||
"reset": {
|
|
||||||
"xp": "Die {} von {} wurden entfernt",
|
"xp": "Die {} von {} wurden entfernt",
|
||||||
"ontime": "Die {} von {} wurden entfernt"
|
"ontime": "Die {} von {} wurden entfernt"
|
||||||
},
|
},
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
from abc import ABC, abstractmethod
|
from abc import ABC, abstractmethod
|
||||||
from datetime import datetime
|
|
||||||
from typing import Callable
|
from typing import Callable
|
||||||
|
|
||||||
from cpl_query.extension import List
|
from cpl_query.extension import List
|
||||||
@ -7,6 +6,8 @@ from discord.ext.commands import Context
|
|||||||
|
|
||||||
from bot_data.model.user import User
|
from bot_data.model.user import User
|
||||||
from modules.base.configuration.base_server_settings import BaseServerSettings
|
from modules.base.configuration.base_server_settings import BaseServerSettings
|
||||||
|
from bot_data.model.user import User
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class ClientUtilsABC(ABC):
|
class ClientUtilsABC(ABC):
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
from datetime import datetime
|
|
||||||
from typing import Callable
|
from typing import Callable
|
||||||
|
|
||||||
import discord
|
import discord
|
||||||
|
from bot_data.abc.user_joined_voice_channel_abc import UserJoinedVoiceChannelRepositoryABC
|
||||||
from cpl_core.configuration import ConfigurationABC
|
from cpl_core.configuration import ConfigurationABC
|
||||||
from cpl_core.database.context import DatabaseContextABC
|
from cpl_core.database.context import DatabaseContextABC
|
||||||
from cpl_core.logging import LoggerABC
|
from cpl_core.logging import LoggerABC
|
||||||
@ -17,7 +17,6 @@ from bot_core.configuration.feature_flags_enum import FeatureFlagsEnum
|
|||||||
from bot_core.configuration.feature_flags_settings import FeatureFlagsSettings
|
from bot_core.configuration.feature_flags_settings import FeatureFlagsSettings
|
||||||
from bot_data.abc.client_repository_abc import ClientRepositoryABC
|
from bot_data.abc.client_repository_abc import ClientRepositoryABC
|
||||||
from bot_data.abc.server_repository_abc import ServerRepositoryABC
|
from bot_data.abc.server_repository_abc import ServerRepositoryABC
|
||||||
from bot_data.abc.user_joined_voice_channel_repository_abc import UserJoinedVoiceChannelRepositoryABC
|
|
||||||
from bot_data.abc.user_message_count_per_hour_repository_abc import UserMessageCountPerHourRepositoryABC
|
from bot_data.abc.user_message_count_per_hour_repository_abc import UserMessageCountPerHourRepositoryABC
|
||||||
from bot_data.model.user import User
|
from bot_data.model.user import User
|
||||||
from bot_data.model.user_message_count_per_hour import UserMessageCountPerHour
|
from bot_data.model.user_message_count_per_hour import UserMessageCountPerHour
|
||||||
@ -34,8 +33,8 @@ class ClientUtilsService(ClientUtilsABC):
|
|||||||
bot: DiscordBotServiceABC,
|
bot: DiscordBotServiceABC,
|
||||||
servers: ServerRepositoryABC,
|
servers: ServerRepositoryABC,
|
||||||
clients: ClientRepositoryABC,
|
clients: ClientRepositoryABC,
|
||||||
user_joined_vc: UserJoinedVoiceChannelRepositoryABC,
|
|
||||||
umcphs: UserMessageCountPerHourRepositoryABC,
|
umcphs: UserMessageCountPerHourRepositoryABC,
|
||||||
|
user_joined_vc: UserJoinedVoiceChannelRepositoryABC,
|
||||||
message_service: MessageServiceABC,
|
message_service: MessageServiceABC,
|
||||||
db: DatabaseContextABC,
|
db: DatabaseContextABC,
|
||||||
t: TranslatePipe,
|
t: TranslatePipe,
|
||||||
@ -91,6 +90,8 @@ class ClientUtilsService(ClientUtilsABC):
|
|||||||
async def check_if_bot_is_ready_yet_and_respond(self, ctx: Context) -> bool:
|
async def check_if_bot_is_ready_yet_and_respond(self, ctx: Context) -> bool:
|
||||||
result = await self.check_if_bot_is_ready_yet()
|
result = await self.check_if_bot_is_ready_yet()
|
||||||
if not result:
|
if not result:
|
||||||
|
await self._message_service.send_ctx_msg(ctx, self._t.transform('common.errors.bot_not_ready_yet'),
|
||||||
|
without_tracking=True)
|
||||||
await self._message_service.send_ctx_msg(
|
await self._message_service.send_ctx_msg(
|
||||||
ctx,
|
ctx,
|
||||||
self._t.transform('common.errors.bot_not_ready_yet'),
|
self._t.transform('common.errors.bot_not_ready_yet'),
|
||||||
|
@ -68,35 +68,6 @@ class UserGroup(DiscordCommandABC):
|
|||||||
|
|
||||||
self._atr_list = [(key, self._atr_dict[key]) for key in self._atr_dict]
|
self._atr_list = [(key, self._atr_dict[key]) for key in self._atr_dict]
|
||||||
|
|
||||||
async def _handle_atr_calc(self, ctx: Context, atr: str, value: int, member: discord.Member, is_remove=False):
|
|
||||||
if member is None or not isinstance(member, discord.Member):
|
|
||||||
member = ctx.author
|
|
||||||
|
|
||||||
server = self._servers.find_server_by_discord_id(ctx.guild.id)
|
|
||||||
user = self._users.find_user_by_discord_id_and_server_id(member.id, server.server_id)
|
|
||||||
|
|
||||||
if atr == 'xp':
|
|
||||||
if is_remove:
|
|
||||||
user.xp -= value
|
|
||||||
else:
|
|
||||||
user.xp += value
|
|
||||||
self._users.update_user(user)
|
|
||||||
self._db.save_changes()
|
|
||||||
await self._level.check_level(member)
|
|
||||||
|
|
||||||
else:
|
|
||||||
await self._message_service.send_interaction_msg(
|
|
||||||
ctx.interaction,
|
|
||||||
self._t.transform('modules.base.user.error.atr_not_found').format(atr)
|
|
||||||
)
|
|
||||||
return
|
|
||||||
|
|
||||||
type = 'add' if not is_remove else 'remove'
|
|
||||||
await self._message_service.send_interaction_msg(
|
|
||||||
ctx.interaction,
|
|
||||||
self._t.transform(f'modules.base.user.{type}.{atr.lower()}').format(atr, value, member.mention)
|
|
||||||
)
|
|
||||||
|
|
||||||
@commands.hybrid_group()
|
@commands.hybrid_group()
|
||||||
@commands.guild_only()
|
@commands.guild_only()
|
||||||
async def user(self, ctx: Context):
|
async def user(self, ctx: Context):
|
||||||
@ -159,11 +130,8 @@ class UserGroup(DiscordCommandABC):
|
|||||||
embed.add_field(name=self._t.transform('modules.base.user.atr.lefts'), value=lefts_string)
|
embed.add_field(name=self._t.transform('modules.base.user.atr.lefts'), value=lefts_string)
|
||||||
|
|
||||||
if is_mod or member == ctx.author:
|
if is_mod or member == ctx.author:
|
||||||
embed.add_field(
|
embed.add_field(name=self._t.transform('modules.base.user.atr.warnings'),
|
||||||
name=self._t.transform('modules.base.user.atr.warnings'),
|
value=self._t.transform('common.not_implemented_yet'), inline=False)
|
||||||
value=self._t.transform('common.not_implemented_yet'),
|
|
||||||
inline=False
|
|
||||||
)
|
|
||||||
|
|
||||||
# send to interaction because of sensitive data
|
# send to interaction because of sensitive data
|
||||||
await self._message_service.send_interaction_msg(ctx.interaction, embed, wait_before_delete=wait)
|
await self._message_service.send_interaction_msg(ctx.interaction, embed, wait_before_delete=wait)
|
||||||
@ -212,7 +180,7 @@ class UserGroup(DiscordCommandABC):
|
|||||||
@commands.guild_only()
|
@commands.guild_only()
|
||||||
@CommandChecks.check_is_ready()
|
@CommandChecks.check_is_ready()
|
||||||
@CommandChecks.check_is_member_moderator()
|
@CommandChecks.check_is_member_moderator()
|
||||||
async def set(self, ctx: Context, atr: str, value: int, member: discord.Member = None):
|
async def set(self, ctx: Context, atr: str, value: str, member: discord.Member = None):
|
||||||
self._logger.debug(__name__, f'Received command user-set {atr} {ctx}:{member}')
|
self._logger.debug(__name__, f'Received command user-set {atr} {ctx}:{member}')
|
||||||
|
|
||||||
if member is None or not isinstance(member, discord.Member):
|
if member is None or not isinstance(member, discord.Member):
|
||||||
@ -222,8 +190,14 @@ class UserGroup(DiscordCommandABC):
|
|||||||
user = self._users.find_user_by_discord_id_and_server_id(member.id, server.server_id)
|
user = self._users.find_user_by_discord_id_and_server_id(member.id, server.server_id)
|
||||||
|
|
||||||
if atr == 'xp':
|
if atr == 'xp':
|
||||||
|
if not value.isnumeric():
|
||||||
|
await self._message_service.send_interaction_msg(
|
||||||
|
ctx.interaction, self._t.transform('modules.base.user.set.error.value_type_not_numeric')
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
try:
|
try:
|
||||||
user.xp = value
|
user.xp = int(value)
|
||||||
except TypeError as te:
|
except TypeError as te:
|
||||||
self._logger.error(__name__, f'String value couldn\'t be converted to int', te)
|
self._logger.error(__name__, f'String value couldn\'t be converted to int', te)
|
||||||
await self._message_service.send_interaction_msg(
|
await self._message_service.send_interaction_msg(
|
||||||
@ -257,34 +231,8 @@ class UserGroup(DiscordCommandABC):
|
|||||||
@commands.guild_only()
|
@commands.guild_only()
|
||||||
@CommandChecks.check_is_ready()
|
@CommandChecks.check_is_ready()
|
||||||
@CommandChecks.check_is_member_moderator()
|
@CommandChecks.check_is_member_moderator()
|
||||||
async def add(self, ctx: Context, atr: str, value: int, member: discord.Member = None):
|
async def remove(self, ctx: Context, atr: str, member: discord.Member = None):
|
||||||
self._logger.debug(__name__, f'Received command user-add {atr}-={value} {ctx}:{member}')
|
self._logger.debug(__name__, f'Received command user-remove {atr} {ctx}:{member}')
|
||||||
await self._handle_atr_calc(ctx, atr, value, member)
|
|
||||||
|
|
||||||
@add.autocomplete('atr')
|
|
||||||
async def set_autocomplete(self, interaction: discord.Interaction, current: str) -> List[app_commands.Choice[str]]:
|
|
||||||
atr_list = [('xp', self._atr_dict['xp'])]
|
|
||||||
return [app_commands.Choice(name=value, value=key) for key, value in atr_list]
|
|
||||||
|
|
||||||
@user.command()
|
|
||||||
@commands.guild_only()
|
|
||||||
@CommandChecks.check_is_ready()
|
|
||||||
@CommandChecks.check_is_member_moderator()
|
|
||||||
async def remove(self, ctx: Context, atr: str, value: int, member: discord.Member = None):
|
|
||||||
self._logger.debug(__name__, f'Received command user-remove {atr}-={value} {ctx}:{member}')
|
|
||||||
await self._handle_atr_calc(ctx, atr, value, member, is_remove=True)
|
|
||||||
|
|
||||||
@remove.autocomplete('atr')
|
|
||||||
async def set_autocomplete(self, interaction: discord.Interaction, current: str) -> List[app_commands.Choice[str]]:
|
|
||||||
atr_list = [('xp', self._atr_dict['xp'])]
|
|
||||||
return [app_commands.Choice(name=value, value=key) for key, value in atr_list]
|
|
||||||
|
|
||||||
@user.command()
|
|
||||||
@commands.guild_only()
|
|
||||||
@CommandChecks.check_is_ready()
|
|
||||||
@CommandChecks.check_is_member_moderator()
|
|
||||||
async def reset(self, ctx: Context, atr: str, member: discord.Member = None):
|
|
||||||
self._logger.debug(__name__, f'Received command user-reset {atr} {ctx}:{member}')
|
|
||||||
|
|
||||||
if member is None or not isinstance(member, discord.Member):
|
if member is None or not isinstance(member, discord.Member):
|
||||||
member = ctx.author
|
member = ctx.author
|
||||||
@ -311,11 +259,11 @@ class UserGroup(DiscordCommandABC):
|
|||||||
|
|
||||||
await self._message_service.send_interaction_msg(
|
await self._message_service.send_interaction_msg(
|
||||||
ctx.interaction,
|
ctx.interaction,
|
||||||
self._t.transform(f'modules.base.user.reset.{atr.lower()}').format(atr, member.mention)
|
self._t.transform(f'modules.base.user.remove.{atr.lower()}').format(atr, member.mention)
|
||||||
)
|
)
|
||||||
|
|
||||||
@reset.autocomplete('atr')
|
@remove.autocomplete('atr')
|
||||||
async def reset_autocomplete(self, interaction: discord.Interaction, current: str) -> List[
|
async def remove_autocomplete(self, interaction: discord.Interaction, current: str) -> List[
|
||||||
app_commands.Choice[str]
|
app_commands.Choice[str]
|
||||||
]:
|
]:
|
||||||
return [app_commands.Choice(name=value, value=key) for key, value in self._atr_list]
|
return [app_commands.Choice(name=value, value=key) for key, value in self._atr_list]
|
||||||
|
@ -7,7 +7,7 @@ from cpl_core.database.context import DatabaseContextABC
|
|||||||
from cpl_core.logging import LoggerABC
|
from cpl_core.logging import LoggerABC
|
||||||
from cpl_discord.events import OnVoiceStateUpdateABC
|
from cpl_discord.events import OnVoiceStateUpdateABC
|
||||||
|
|
||||||
from bot_core.abc.client_utils_abc import ClientUtilsABC
|
from bot_core.abc.client_utils_service_abc import ClientUtilsServiceABC
|
||||||
from bot_core.helper.event_checks import EventChecks
|
from bot_core.helper.event_checks import EventChecks
|
||||||
from bot_data.abc.known_user_repository_abc import KnownUserRepositoryABC
|
from bot_data.abc.known_user_repository_abc import KnownUserRepositoryABC
|
||||||
from bot_data.abc.server_repository_abc import ServerRepositoryABC
|
from bot_data.abc.server_repository_abc import ServerRepositoryABC
|
||||||
@ -33,7 +33,7 @@ class BaseOnVoiceStateUpdateEvent(OnVoiceStateUpdateABC):
|
|||||||
users: UserRepositoryABC,
|
users: UserRepositoryABC,
|
||||||
user_joins: UserJoinedServerRepositoryABC,
|
user_joins: UserJoinedServerRepositoryABC,
|
||||||
user_joins_vc: UserJoinedVoiceChannelRepositoryABC,
|
user_joins_vc: UserJoinedVoiceChannelRepositoryABC,
|
||||||
client_utils: ClientUtilsABC,
|
client_utils: ClientUtilsServiceABC,
|
||||||
db: DatabaseContextABC,
|
db: DatabaseContextABC,
|
||||||
):
|
):
|
||||||
OnVoiceStateUpdateABC.__init__(self)
|
OnVoiceStateUpdateABC.__init__(self)
|
||||||
|
Loading…
Reference in New Issue
Block a user