ecodev-core 0.0.46__tar.gz → 0.0.48__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 ecodev-core might be problematic. Click here for more details.
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/PKG-INFO +1 -1
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/db_upsertion.py +11 -1
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/version.py +4 -4
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/pyproject.toml +1 -1
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/LICENSE.md +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/README.md +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/__init__.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/app_activity.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/app_rights.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/app_user.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/auth_configuration.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/authentication.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/backup.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/check_dependencies.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/custom_equal.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/db_connection.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/db_filters.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/db_insertion.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/db_retrieval.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/deployment.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/email_sender.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/enum_utils.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/es_connection.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/list_utils.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/logger.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/pandas_utils.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/permissions.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/pydantic_utils.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/read_write.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/safe_utils.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/settings.py +0 -0
- {ecodev_core-0.0.46 → ecodev_core-0.0.48}/ecodev_core/sqlmodel_utils.py +0 -0
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"""
|
|
2
2
|
Module handling CRUD and version operations
|
|
3
3
|
"""
|
|
4
|
+
from datetime import datetime
|
|
4
5
|
from functools import partial
|
|
6
|
+
from typing import Any
|
|
5
7
|
from typing import Union
|
|
6
8
|
|
|
7
9
|
import pandas as pd
|
|
@@ -78,12 +80,20 @@ def upsert_updator(values: SQLModel,
|
|
|
78
80
|
col_types = {x: y.annotation for x, y in db_schema.__fields__.items()}
|
|
79
81
|
table = db_schema.__tablename__
|
|
80
82
|
|
|
81
|
-
for col, val in {k: v for k, v in db.items() if k in to_update and
|
|
83
|
+
for col, val in {k: v for k, v in db.items() if k in to_update and _value_comparator(
|
|
84
|
+
v, to_update[k])}.items():
|
|
82
85
|
session.add(Version.from_table_row(table, col, row_id, col_types[col], val))
|
|
83
86
|
|
|
84
87
|
return update(db_schema).where(db_schema.id == row_id).values(**to_update)
|
|
85
88
|
|
|
86
89
|
|
|
90
|
+
def _value_comparator(v: Any, to_update: Any) -> bool:
|
|
91
|
+
"""
|
|
92
|
+
Performs a comparison between the value in db and the value to be upserted
|
|
93
|
+
"""
|
|
94
|
+
return v.date() != to_update.date() if isinstance(v, datetime) else v != to_update
|
|
95
|
+
|
|
96
|
+
|
|
87
97
|
def upsert_deletor(values: SQLModel, session: Session):
|
|
88
98
|
"""
|
|
89
99
|
Delete row in db corresponding to the passed values, selecting on columns not to be versioned.
|
|
@@ -135,10 +135,10 @@ def db_to_value(db_value: str | None, col_type: type | EnumType) -> COL_TYPES:
|
|
|
135
135
|
"""
|
|
136
136
|
if db_value is None:
|
|
137
137
|
return None
|
|
138
|
-
if col_type
|
|
138
|
+
if issubclass(int, col_type) or issubclass(str, col_type) or issubclass(float, col_type):
|
|
139
139
|
return col_type(db_value)
|
|
140
|
-
if col_type
|
|
141
|
-
return
|
|
142
|
-
if col_type
|
|
140
|
+
if issubclass(bool, col_type):
|
|
141
|
+
return db_value == 'True'
|
|
142
|
+
if issubclass(datetime, col_type):
|
|
143
143
|
return datetime.strptime(db_value, '%Y-%m-%d %H:%M:%S.%f')
|
|
144
144
|
return col_type[db_value] # type: ignore[index]
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|