_data_model.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. # Copyright 2021-2024 Avaiga Private Limited
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
  4. # the License. You may obtain a copy of the License at
  5. #
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
  9. # an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
  10. # specific language governing permissions and limitations under the License.
  11. from dataclasses import dataclass
  12. from typing import Any, Dict, List, Optional
  13. from sqlalchemy import JSON, Boolean, Column, Enum, Float, String, Table, UniqueConstraint
  14. from taipy.config.common.scope import Scope
  15. from .._repository._base_taipy_model import _BaseModel
  16. from .._repository.db._sql_base_model import mapper_registry
  17. from .data_node_id import Edit
  18. @mapper_registry.mapped
  19. @dataclass
  20. class _DataNodeModel(_BaseModel):
  21. __table__ = Table(
  22. "data_node",
  23. mapper_registry.metadata,
  24. Column("id", String, primary_key=True),
  25. Column("config_id", String),
  26. Column("scope", Enum(Scope)),
  27. Column("storage_type", String),
  28. Column("owner_id", String),
  29. Column("parent_ids", JSON),
  30. Column("last_edit_date", String),
  31. Column("edits", JSON),
  32. Column("version", String),
  33. Column("validity_days", Float),
  34. Column("validity_seconds", Float),
  35. Column("edit_in_progress", Boolean),
  36. Column("editor_id", String),
  37. Column("editor_expiration_date", String),
  38. Column("data_node_properties", JSON),
  39. )
  40. __table_args__ = (UniqueConstraint("config_id", "owner_id", name="_config_owner_uc"),)
  41. id: str
  42. config_id: str
  43. scope: Scope
  44. storage_type: str
  45. owner_id: Optional[str]
  46. parent_ids: List[str]
  47. last_edit_date: Optional[str]
  48. edits: List[Edit]
  49. version: str
  50. validity_days: Optional[float]
  51. validity_seconds: Optional[float]
  52. edit_in_progress: bool
  53. editor_id: Optional[str]
  54. editor_expiration_date: Optional[str]
  55. data_node_properties: Dict[str, Any]
  56. @staticmethod
  57. def from_dict(data: Dict[str, Any]):
  58. return _DataNodeModel(
  59. id=data["id"],
  60. config_id=data["config_id"],
  61. scope=Scope._from_repr(data["scope"]),
  62. storage_type=data["storage_type"],
  63. owner_id=data.get("owner_id"),
  64. parent_ids=_BaseModel._deserialize_attribute(data.get("parent_ids", [])),
  65. last_edit_date=data.get("last_edit_date"),
  66. edits=_BaseModel._deserialize_attribute(data["edits"]),
  67. version=data["version"],
  68. validity_days=data["validity_days"],
  69. validity_seconds=data["validity_seconds"],
  70. edit_in_progress=bool(data.get("edit_in_progress", False)),
  71. editor_id=data.get("editor_id", None),
  72. editor_expiration_date=data.get("editor_expiration_date"),
  73. data_node_properties=_BaseModel._deserialize_attribute(data["data_node_properties"]),
  74. )
  75. def to_list(self):
  76. return [
  77. self.id,
  78. self.config_id,
  79. repr(self.scope),
  80. self.storage_type,
  81. self.owner_id,
  82. _BaseModel._serialize_attribute(self.parent_ids),
  83. self.last_edit_date,
  84. _BaseModel._serialize_attribute(self.edits),
  85. self.version,
  86. self.validity_days,
  87. self.validity_seconds,
  88. self.edit_in_progress,
  89. self.editor_id,
  90. self.editor_expiration_date,
  91. _BaseModel._serialize_attribute(self.data_node_properties),
  92. ]