Skip to content

Notification Dto

immichpy.client.generated.models.notification_dto.NotificationDto pydantic-model

Bases: BaseModel

NotificationDto

Show JSON schema:
{
  "$defs": {
    "NotificationLevel": {
      "description": "NotificationLevel",
      "enum": [
        "success",
        "error",
        "warning",
        "info"
      ],
      "title": "NotificationLevel",
      "type": "string"
    },
    "NotificationType": {
      "description": "NotificationType",
      "enum": [
        "JobFailed",
        "BackupFailed",
        "SystemMessage",
        "AlbumInvite",
        "AlbumUpdate",
        "Custom"
      ],
      "title": "NotificationType",
      "type": "string"
    }
  },
  "description": "NotificationDto",
  "properties": {
    "createdAt": {
      "description": "Creation date",
      "format": "date-time",
      "title": "Createdat",
      "type": "string"
    },
    "data": {
      "anyOf": [
        {
          "additionalProperties": true,
          "type": "object"
        },
        {
          "type": "null"
        }
      ],
      "default": null,
      "description": "Additional notification data",
      "title": "Data"
    },
    "description": {
      "anyOf": [
        {
          "type": "string"
        },
        {
          "type": "null"
        }
      ],
      "default": null,
      "description": "Notification description",
      "title": "Description"
    },
    "id": {
      "description": "Notification ID",
      "title": "Id",
      "type": "string"
    },
    "level": {
      "$ref": "#/$defs/NotificationLevel",
      "description": "Notification level"
    },
    "readAt": {
      "anyOf": [
        {
          "format": "date-time",
          "type": "string"
        },
        {
          "type": "null"
        }
      ],
      "default": null,
      "description": "Date when notification was read",
      "title": "Readat"
    },
    "title": {
      "description": "Notification title",
      "title": "Title",
      "type": "string"
    },
    "type": {
      "$ref": "#/$defs/NotificationType",
      "description": "Notification type"
    }
  },
  "required": [
    "createdAt",
    "id",
    "level",
    "title",
    "type"
  ],
  "title": "NotificationDto",
  "type": "object"
}

Config:

  • populate_by_name: True
  • validate_assignment: True
  • protected_namespaces: ()

Fields:

created_at pydantic-field

created_at: datetime

Creation date

data pydantic-field

data: Optional[Dict[str, Any]] = None

Additional notification data

description pydantic-field

description: Optional[StrictStr] = None

Notification description

id pydantic-field

id: StrictStr

Notification ID

level pydantic-field

level: NotificationLevel

Notification level

read_at pydantic-field

read_at: Optional[datetime] = None

Date when notification was read

title pydantic-field

title: StrictStr

Notification title

type pydantic-field

type: NotificationType

Notification type

from_dict classmethod

from_dict(obj: Optional[Dict[str, Any]]) -> Optional[Self]

Create an instance of NotificationDto from a dict

Source code in immichpy/client/generated/models/notification_dto.py
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
@classmethod
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
    """Create an instance of NotificationDto from a dict"""
    if obj is None:
        return None

    if not isinstance(obj, dict):
        return cls.model_validate(obj)

    _obj = cls.model_validate(
        {
            "createdAt": obj.get("createdAt"),
            "data": obj.get("data"),
            "description": obj.get("description"),
            "id": obj.get("id"),
            "level": obj.get("level"),
            "readAt": obj.get("readAt"),
            "title": obj.get("title"),
            "type": obj.get("type"),
        }
    )
    return _obj

from_json classmethod

from_json(json_str: str) -> Optional[Self]

Create an instance of NotificationDto from a JSON string

Source code in immichpy/client/generated/models/notification_dto.py
73
74
75
76
@classmethod
def from_json(cls, json_str: str) -> Optional[Self]:
    """Create an instance of NotificationDto from a JSON string"""
    return cls.from_dict(json.loads(json_str))

to_dict

to_dict() -> Dict[str, Any]

Return the dictionary representation of the model using alias.

This has the following differences from calling pydantic's self.model_dump(by_alias=True):

  • None is only added to the output dict for nullable fields that were set at model initialization. Other fields with value None are ignored.
Source code in immichpy/client/generated/models/notification_dto.py
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
def to_dict(self) -> Dict[str, Any]:
    """Return the dictionary representation of the model using alias.

    This has the following differences from calling pydantic's
    `self.model_dump(by_alias=True)`:

    * `None` is only added to the output dict for nullable fields that
      were set at model initialization. Other fields with value `None`
      are ignored.
    """
    excluded_fields: Set[str] = set([])

    _dict = self.model_dump(
        by_alias=True,
        exclude=excluded_fields,
        exclude_none=True,
    )
    return _dict

to_json

to_json() -> str

Returns the JSON representation of the model using alias

Source code in immichpy/client/generated/models/notification_dto.py
68
69
70
71
def to_json(self) -> str:
    """Returns the JSON representation of the model using alias"""
    # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
    return json.dumps(self.to_dict())

to_str

to_str() -> str

Returns the string representation of the model using alias

Source code in immichpy/client/generated/models/notification_dto.py
64
65
66
def to_str(self) -> str:
    """Returns the string representation of the model using alias"""
    return pprint.pformat(self.model_dump(by_alias=True))