diff --git a/discord/audit_logs.py b/discord/audit_logs.py index eebcecfbd..f0924039e 100644 --- a/discord/audit_logs.py +++ b/discord/audit_logs.py @@ -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']) diff --git a/discord/types/audit_log.py b/discord/types/audit_log.py index 10acdb196..3b7022e79 100644 --- a/discord/types/audit_log.py +++ b/discord/types/audit_log.py @@ -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): diff --git a/docs/api.rst b/docs/api.rst index ee38964ed..ce8943160 100644 --- a/docs/api.rst +++ b/docs/api.rst @@ -2106,6 +2106,11 @@ of :class:`enum.Enum`. When this is the action, the type of :attr:`~AuditLogEntry.target` is the :class:`User` or :class:`Object` who got kicked. + When this is the action, the type of :attr:`~AuditLogEntry.extra` is + set to an unspecified proxy object with one attribute: + + - ``integration_type``: An optional string that denotes the type of integration that did the action. + When this is the action, :attr:`~AuditLogEntry.changes` is empty. .. attribute:: member_prune @@ -2166,6 +2171,11 @@ of :class:`enum.Enum`. When this is the action, the type of :attr:`~AuditLogEntry.target` is the :class:`Member`, :class:`User`, or :class:`Object` who got the role. + When this is the action, the type of :attr:`~AuditLogEntry.extra` is + set to an unspecified proxy object with one attribute: + + - ``integration_type``: An optional string that denotes the type of integration that did the action. + Possible attributes for :class:`AuditLogDiff`: - :attr:`~AuditLogDiff.roles`