Add support for integration_type in audit logs

Currently unsure whether more processing is meant to be done with this,
but for now an Optional[str] is the best I can do without more data.
This commit is contained in:
Rapptz
2023-08-25 11:57:18 -04:00
parent a756df3d5c
commit 60ff239558
3 changed files with 20 additions and 0 deletions

View File

@@ -528,6 +528,10 @@ class _AuditLogProxyAutoModAction(_AuditLogProxy):
channel: Optional[Union[abc.GuildChannel, Thread]]
class _AuditLogProxyMemberKickOrMemberRoleUpdate(_AuditLogProxy):
integration_type: Optional[str]
class AuditLogEntry(Hashable):
r"""Represents an Audit Log entry.
@@ -614,6 +618,7 @@ class AuditLogEntry(Hashable):
_AuditLogProxyStageInstanceAction,
_AuditLogProxyMessageBulkDelete,
_AuditLogProxyAutoModAction,
_AuditLogProxyMemberKickOrMemberRoleUpdate,
Member, User, None, PartialIntegration,
Role, Object
] = None
@@ -638,6 +643,10 @@ class AuditLogEntry(Hashable):
elif self.action is enums.AuditLogAction.message_bulk_delete:
# The bulk message delete action has the number of messages deleted
self.extra = _AuditLogProxyMessageBulkDelete(count=int(extra['count']))
elif self.action in (enums.AuditLogAction.kick, enums.AuditLogAction.member_role_update):
# The member kick action has a dict with some information
integration_type = extra.get('integration_type')
self.extra = _AuditLogProxyMemberKickOrMemberRoleUpdate(integration_type=integration_type)
elif self.action.name.endswith('pin'):
# the pin actions have a dict with some information
channel_id = int(extra['channel_id'])

View File

@@ -316,6 +316,7 @@ class AuditEntryInfo(TypedDict):
guild_id: Snowflake
auto_moderation_rule_name: str
auto_moderation_rule_trigger_type: str
integration_type: str
class AuditLogEntry(TypedDict):