Skip to content

incident_io_client.models.audit_logs_scim_group_role_mappings_updated_v1_response_body

AuditLogsScimGroupRoleMappingsUpdatedV1ResponseBody

Example

{'action': 'scim_group.role_mappings_updated', 'actor': {'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'metadata': {'user_base_role_slug': 'admin', 'user_custom_role_slugs': 'engineering,security'}, 'name': 'John Doe', 'type': 'user'}, 'context': {'location': '1.2.3.4', 'user_agent': 'Chrome/91.0.4472.114'}, 'metadata': {'after_base_role_slug': 'owner', 'after_custom_role_slugs': 'engineering,data', 'before_base_role_slug': 'admin', 'before_custom_role_slugs': 'engineering,security'}, 'occurred_at': '2021-08-17T13:28:57.801578Z', 'targets': [{'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'name': 'Security', 'type': 'scim_group'}], 'version': 1}

Attributes:

Name Type Description
action str

The type of log entry that this is Example: scim_group.role_mappings_updated.

actor AuditLogActorV2

Example: {'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'metadata': {'user_base_role_slug': 'admin', 'user_custom_role_slugs': 'engineering,security'}, 'name': 'John Doe', 'type': 'user'}.

context AuditLogEntryContextV2

Example: {'location': '1.2.3.4', 'user_agent': 'Chrome/91.0.4472.114'}.

metadata AuditLogUserSCIMGroupMappingChangedMetadataV2

Example: {'after_base_role_slug': 'owner', 'after_custom_role_slugs': 'engineering,data', 'before_base_role_slug': 'admin', 'before_custom_role_slugs': 'engineering,security'}.

occurred_at datetime

When the entry occurred Example: 2021-08-17T13:28:57.801578Z.

targets List[AuditLogTargetV2]

The custom field that was created Example: [{'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'name': 'Security', 'type': 'scim_group'}].

version int

Which version the event is Example: 1.

Source code in incident_io_client/models/audit_logs_scim_group_role_mappings_updated_v1_response_body.py
@_attrs_define
class AuditLogsScimGroupRoleMappingsUpdatedV1ResponseBody:
    """
    Example:
        {'action': 'scim_group.role_mappings_updated', 'actor': {'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'metadata':
            {'user_base_role_slug': 'admin', 'user_custom_role_slugs': 'engineering,security'}, 'name': 'John Doe', 'type':
            'user'}, 'context': {'location': '1.2.3.4', 'user_agent': 'Chrome/91.0.4472.114'}, 'metadata':
            {'after_base_role_slug': 'owner', 'after_custom_role_slugs': 'engineering,data', 'before_base_role_slug':
            'admin', 'before_custom_role_slugs': 'engineering,security'}, 'occurred_at': '2021-08-17T13:28:57.801578Z',
            'targets': [{'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'name': 'Security', 'type': 'scim_group'}], 'version': 1}

    Attributes:
        action (str): The type of log entry that this is Example: scim_group.role_mappings_updated.
        actor (AuditLogActorV2):  Example: {'id': '01FCNDV6P870EA6S7TK1DSYDG0', 'metadata': {'user_base_role_slug':
            'admin', 'user_custom_role_slugs': 'engineering,security'}, 'name': 'John Doe', 'type': 'user'}.
        context (AuditLogEntryContextV2):  Example: {'location': '1.2.3.4', 'user_agent': 'Chrome/91.0.4472.114'}.
        metadata (AuditLogUserSCIMGroupMappingChangedMetadataV2):  Example: {'after_base_role_slug': 'owner',
            'after_custom_role_slugs': 'engineering,data', 'before_base_role_slug': 'admin', 'before_custom_role_slugs':
            'engineering,security'}.
        occurred_at (datetime.datetime): When the entry occurred Example: 2021-08-17T13:28:57.801578Z.
        targets (List['AuditLogTargetV2']): The custom field that was created Example: [{'id':
            '01FCNDV6P870EA6S7TK1DSYDG0', 'name': 'Security', 'type': 'scim_group'}].
        version (int): Which version the event is Example: 1.
    """

    action: str
    actor: "AuditLogActorV2"
    context: "AuditLogEntryContextV2"
    metadata: "AuditLogUserSCIMGroupMappingChangedMetadataV2"
    occurred_at: datetime.datetime
    targets: List["AuditLogTargetV2"]
    version: int
    additional_properties: Dict[str, Any] = _attrs_field(init=False, factory=dict)

    def to_dict(self) -> Dict[str, Any]:
        action = self.action

        actor = self.actor.to_dict()

        context = self.context.to_dict()

        metadata = self.metadata.to_dict()

        occurred_at = self.occurred_at.isoformat()

        targets = []
        for targets_item_data in self.targets:
            targets_item = targets_item_data.to_dict()
            targets.append(targets_item)

        version = self.version

        field_dict: Dict[str, Any] = {}
        field_dict.update(self.additional_properties)
        field_dict.update(
            {
                "action": action,
                "actor": actor,
                "context": context,
                "metadata": metadata,
                "occurred_at": occurred_at,
                "targets": targets,
                "version": version,
            }
        )

        return field_dict

    @classmethod
    def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
        from ..models.audit_log_actor_v2 import AuditLogActorV2
        from ..models.audit_log_entry_context_v2 import AuditLogEntryContextV2
        from ..models.audit_log_target_v2 import AuditLogTargetV2
        from ..models.audit_log_user_scim_group_mapping_changed_metadata_v2 import (
            AuditLogUserSCIMGroupMappingChangedMetadataV2,
        )

        d = src_dict.copy()
        action = d.pop("action")

        actor = AuditLogActorV2.from_dict(d.pop("actor"))

        context = AuditLogEntryContextV2.from_dict(d.pop("context"))

        metadata = AuditLogUserSCIMGroupMappingChangedMetadataV2.from_dict(d.pop("metadata"))

        occurred_at = isoparse(d.pop("occurred_at"))

        targets = []
        _targets = d.pop("targets")
        for targets_item_data in _targets:
            targets_item = AuditLogTargetV2.from_dict(targets_item_data)

            targets.append(targets_item)

        version = d.pop("version")

        audit_logs_scim_group_role_mappings_updated_v1_response_body = cls(
            action=action,
            actor=actor,
            context=context,
            metadata=metadata,
            occurred_at=occurred_at,
            targets=targets,
            version=version,
        )

        audit_logs_scim_group_role_mappings_updated_v1_response_body.additional_properties = d
        return audit_logs_scim_group_role_mappings_updated_v1_response_body

    @property
    def additional_keys(self) -> List[str]:
        return list(self.additional_properties.keys())

    def __getitem__(self, key: str) -> Any:
        return self.additional_properties[key]

    def __setitem__(self, key: str, value: Any) -> None:
        self.additional_properties[key] = value

    def __delitem__(self, key: str) -> None:
        del self.additional_properties[key]

    def __contains__(self, key: str) -> bool:
        return key in self.additional_properties