artemis-model 0.1.154__tar.gz → 0.1.156__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of artemis-model might be problematic. Click here for more details.

Files changed (35) hide show
  1. {artemis_model-0.1.154 → artemis_model-0.1.156}/PKG-INFO +3 -2
  2. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/__init__.py +2 -0
  3. artemis_model-0.1.156/artemis_model/approved_playlist_list.py +59 -0
  4. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/organization.py +19 -0
  5. artemis_model-0.1.156/artemis_model/organization_include_pal_setting.py +34 -0
  6. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/setting.py +1 -1
  7. {artemis_model-0.1.154 → artemis_model-0.1.156}/pyproject.toml +1 -1
  8. {artemis_model-0.1.154 → artemis_model-0.1.156}/README.md +0 -0
  9. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/album.py +0 -0
  10. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/artist.py +0 -0
  11. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/auth.py +0 -0
  12. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/banned_tracks.py +0 -0
  13. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/base.py +0 -0
  14. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/category.py +0 -0
  15. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/dj_set.py +0 -0
  16. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/genre.py +0 -0
  17. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/location.py +0 -0
  18. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/location_genre_exclusion.py +0 -0
  19. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/message.py +0 -0
  20. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/otp.py +0 -0
  21. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/permission.py +0 -0
  22. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/playlist.py +0 -0
  23. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/redis/__init__.py +0 -0
  24. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/redis/bucket.py +0 -0
  25. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/redis/device.py +0 -0
  26. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/redis/keys.py +0 -0
  27. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/redis/play_history.py +0 -0
  28. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/redis/zone_state.py +0 -0
  29. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/schedule.py +0 -0
  30. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/sqs/__init__.py +0 -0
  31. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/sqs/messages.py +0 -0
  32. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/track.py +0 -0
  33. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/user.py +0 -0
  34. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/zone.py +0 -0
  35. {artemis_model-0.1.154 → artemis_model-0.1.156}/artemis_model/zone_activity.py +0 -0
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.3
1
+ Metadata-Version: 2.4
2
2
  Name: artemis-model
3
- Version: 0.1.154
3
+ Version: 0.1.156
4
4
  Summary:
5
5
  Author: Jukeboxy
6
6
  Requires-Python: >=3.10.6,<4.0.0
@@ -8,6 +8,7 @@ Classifier: Programming Language :: Python :: 3
8
8
  Classifier: Programming Language :: Python :: 3.11
9
9
  Classifier: Programming Language :: Python :: 3.12
10
10
  Classifier: Programming Language :: Python :: 3.13
11
+ Classifier: Programming Language :: Python :: 3.14
11
12
  Requires-Dist: alembic (>=1.13.1,<2.0.0)
12
13
  Requires-Dist: asyncpg (>=0.30.0,<0.31.0)
13
14
  Requires-Dist: greenlet (>=3.0.2,<4.0.0)
@@ -1,4 +1,5 @@
1
1
  from artemis_model.album import * # noqa
2
+ from artemis_model.approved_playlist_list import * # noqa
2
3
  from artemis_model.artist import * # noqa
3
4
  from artemis_model.auth import * # noqa
4
5
  from artemis_model.category import * # noqa
@@ -8,6 +9,7 @@ from artemis_model.location import * # noqa
8
9
  from artemis_model.location_genre_exclusion import * # noqa
9
10
  from artemis_model.message import * # noqa
10
11
  from artemis_model.organization import * # noqa
12
+ from artemis_model.organization_include_pal_setting import * # noqa
11
13
  from artemis_model.playlist import * # noqa
12
14
  from artemis_model.schedule import * # noqa
13
15
  from artemis_model.setting import * # noqa
@@ -0,0 +1,59 @@
1
+ import uuid
2
+ from typing import List
3
+
4
+ from sqlalchemy import ForeignKey
5
+ from sqlalchemy.orm import Mapped, mapped_column, relationship
6
+ from sqlalchemy.ext.declarative import declared_attr
7
+
8
+ from artemis_model.base import CustomSyncBase, TimeStampMixin, AuditMixin, CustomBase
9
+
10
+
11
+ class ApprovedPlaylistListMixin(TimeStampMixin, AuditMixin):
12
+
13
+ id: Mapped[int] = mapped_column(autoincrement=True, primary_key=True, index=True)
14
+ name: Mapped[str] = mapped_column(nullable=False)
15
+ organization_id: Mapped[uuid.UUID] = mapped_column(
16
+ ForeignKey("organization.id"), nullable=False, index=True
17
+ )
18
+
19
+ @declared_attr
20
+ def organization(cls) -> Mapped["Organization"]:
21
+ return relationship("Organization", back_populates="approved_playlist_lists")
22
+
23
+ @declared_attr
24
+ def playlist_associations(cls) -> Mapped[List["ApprovedPlaylistListPlaylistAssoc"]]:
25
+ return relationship(cascade="all, delete-orphan")
26
+
27
+ @declared_attr
28
+ def playlists(cls) -> Mapped[List["Playlist"]]:
29
+ return relationship(
30
+ "Playlist",
31
+ secondary="approved_playlist_list_playlist_assoc",
32
+ viewonly=True
33
+ )
34
+
35
+
36
+ class ApprovedPlaylistListSync(CustomSyncBase, ApprovedPlaylistListMixin):
37
+ pass
38
+
39
+
40
+ class ApprovedPlaylistList(CustomBase, ApprovedPlaylistListMixin):
41
+ pass
42
+
43
+
44
+ class ApprovedPlaylistListPlaylistAssocMixin(TimeStampMixin):
45
+
46
+ approved_playlist_list_id: Mapped[int] = mapped_column(
47
+ ForeignKey("approved_playlist_list.id"), primary_key=True, nullable=False
48
+ )
49
+ playlist_id: Mapped[int] = mapped_column(
50
+ ForeignKey("playlist.id"), primary_key=True, nullable=False
51
+ )
52
+
53
+
54
+ class ApprovedPlaylistListPlaylistAssocSync(CustomSyncBase, ApprovedPlaylistListPlaylistAssocMixin):
55
+ pass
56
+
57
+
58
+ class ApprovedPlaylistListPlaylistAssoc(CustomBase, ApprovedPlaylistListPlaylistAssocMixin):
59
+ pass
@@ -37,6 +37,25 @@ class OrganizationMixin(TimeStampMixin):
37
37
  @declared_attr
38
38
  def message_groups(cls) -> Mapped[List["MessageGroup"]]:
39
39
  return relationship(back_populates="organization")
40
+
41
+ @declared_attr
42
+ def include_pal_setting(cls) -> Mapped["OrganizationIncludePalSetting"]:
43
+ return relationship(back_populates="organization", uselist=False, cascade="all, delete-orphan")
44
+
45
+ @declared_attr
46
+ def approved_playlist_lists(cls) -> Mapped[List["ApprovedPlaylistList"]]:
47
+ return relationship("ApprovedPlaylistList", back_populates="organization")
48
+
49
+ @property
50
+ def approved_playlists(self) -> List[int]:
51
+ """
52
+ Convenience property to get all playlist IDs from all approved lists, flattened.
53
+ Returns empty list if no approved lists exist.
54
+ """
55
+ playlist_ids = []
56
+ for approved_list in self.approved_playlist_lists:
57
+ playlist_ids.extend([playlist.id for playlist in approved_list.playlists])
58
+ return playlist_ids
40
59
 
41
60
 
42
61
  def generate_slug(target: Any, value: Any, old_value: Any, initiator: Any) -> None:
@@ -0,0 +1,34 @@
1
+ import uuid
2
+ from sqlalchemy import ForeignKey, UniqueConstraint
3
+ from sqlalchemy.orm import Mapped, mapped_column, relationship
4
+ from sqlalchemy.ext.declarative import declared_attr
5
+
6
+ from artemis_model.base import TimeStampMixin, CustomSyncBase, CustomBase
7
+
8
+
9
+ class OrganizationIncludePalSettingMixin(TimeStampMixin):
10
+ """Organization-level setting for including parental advisory (explicit) content."""
11
+
12
+ id: Mapped[int] = mapped_column(primary_key=True, autoincrement=True)
13
+ organization_id: Mapped[uuid.UUID] = mapped_column(
14
+ ForeignKey("organization.id", ondelete="CASCADE"), nullable=False, index=True
15
+ )
16
+ include_pal: Mapped[bool] = mapped_column(
17
+ nullable=False, default=False
18
+ )
19
+
20
+ @declared_attr
21
+ def organization(cls) -> Mapped["Organization"]:
22
+ return relationship(back_populates="include_pal_setting")
23
+
24
+ __table_args__ = (
25
+ UniqueConstraint("organization_id", name="unique_organization_include_pal_setting"),
26
+ )
27
+
28
+
29
+ class OrganizationIncludePalSettingSync(CustomSyncBase, OrganizationIncludePalSettingMixin):
30
+ pass
31
+
32
+
33
+ class OrganizationIncludePalSetting(CustomBase, OrganizationIncludePalSettingMixin):
34
+ pass
@@ -25,7 +25,7 @@ class SettingMixin(TimeStampMixin):
25
25
  "<track_id>": "<track_name>",
26
26
  ...
27
27
  },
28
- "exclude_pal": True/False
28
+ "include_pal": True/False
29
29
  }
30
30
  """
31
31
 
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "artemis-model"
3
- version = "0.1.154"
3
+ version = "0.1.156"
4
4
  description = ""
5
5
  authors = ["Jukeboxy"]
6
6
  readme = "README.md"