apexdevkit 1.19.1__tar.gz → 1.19.3__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.
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/PKG-INFO +1 -1
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/sql.py +29 -19
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/pyproject.toml +1 -1
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/LICENSE +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/README.md +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/annotation/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/annotation/deprecate.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/environment.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/error.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/builder.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/dependable.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/docs.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/name.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/request.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/resource.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/response.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/router.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/schema.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fastapi/service.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/fluent.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/formatter.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/fake.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/fluent.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/httpx/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/httpx/client.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/httpx/hooks.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/json.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/http/url.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/id.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/key_fn.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/py.typed +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/query/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/query/generator.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/query/query.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/base.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/connector.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/database.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/decorator.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/in_memory.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/interface.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/mongo.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/mssql.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/repository/sqlite.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/server.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/synchronization.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/testing/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/testing/database.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/testing/fake.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/testing/rest.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.3}/apexdevkit/value.py +0 -0
|
@@ -22,7 +22,7 @@ class _SqlField:
|
|
|
22
22
|
parent_value: Any | None = None
|
|
23
23
|
|
|
24
24
|
is_filter: bool = False
|
|
25
|
-
|
|
25
|
+
filter_values: list[Any | None | NotNone] = field(default_factory=list)
|
|
26
26
|
|
|
27
27
|
is_fixed: bool = False
|
|
28
28
|
fixed_value: Any | None = None
|
|
@@ -41,7 +41,7 @@ class SqlFieldBuilder:
|
|
|
41
41
|
_parent_value: Any | None = None
|
|
42
42
|
|
|
43
43
|
_is_filter: bool = False
|
|
44
|
-
|
|
44
|
+
_filter_values: list[Any | None | NotNone] = field(default_factory=list)
|
|
45
45
|
|
|
46
46
|
_is_fixed: bool = False
|
|
47
47
|
_fixed_value: Any | None = None
|
|
@@ -82,9 +82,9 @@ class SqlFieldBuilder:
|
|
|
82
82
|
|
|
83
83
|
return self
|
|
84
84
|
|
|
85
|
-
def as_filter(self,
|
|
85
|
+
def as_filter(self, values: list[Any | None | NotNone]) -> SqlFieldBuilder:
|
|
86
86
|
self._is_filter = True
|
|
87
|
-
self.
|
|
87
|
+
self._filter_values = values
|
|
88
88
|
|
|
89
89
|
return self
|
|
90
90
|
|
|
@@ -105,7 +105,7 @@ class SqlFieldBuilder:
|
|
|
105
105
|
self._is_parent,
|
|
106
106
|
self._parent_value,
|
|
107
107
|
self._is_filter,
|
|
108
|
-
self.
|
|
108
|
+
self._filter_values,
|
|
109
109
|
self._is_fixed,
|
|
110
110
|
self._fixed_value,
|
|
111
111
|
)
|
|
@@ -161,6 +161,10 @@ class SqlFieldManager:
|
|
|
161
161
|
data[key.name] = key.parent_value
|
|
162
162
|
if key.is_fixed:
|
|
163
163
|
data[key.name] = key.fixed_value
|
|
164
|
+
if key.is_filter:
|
|
165
|
+
for index, value in enumerate(key.filter_values):
|
|
166
|
+
if value is not None and not isinstance(value, NotNone):
|
|
167
|
+
data[key.name + "_filter_" + str(index)] = value
|
|
164
168
|
return data
|
|
165
169
|
|
|
166
170
|
def _parent_filter(self) -> str:
|
|
@@ -197,20 +201,26 @@ class SqlFieldManager:
|
|
|
197
201
|
statements: list[str] = []
|
|
198
202
|
for key in self.fields:
|
|
199
203
|
if key.is_filter:
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
204
|
+
inner_statements: list[str] = []
|
|
205
|
+
for index, value in enumerate(key.filter_values):
|
|
206
|
+
if value is None:
|
|
207
|
+
inner_statements.append(
|
|
208
|
+
self.key_formatter.replace("x", key.name) + " IS NULL"
|
|
209
|
+
)
|
|
210
|
+
elif isinstance(value, NotNone):
|
|
211
|
+
inner_statements.append(
|
|
212
|
+
self.key_formatter.replace("x", key.name) + " IS NOT NULL"
|
|
213
|
+
)
|
|
214
|
+
else:
|
|
215
|
+
inner_statements.append(
|
|
216
|
+
self.key_formatter.replace("x", key.name)
|
|
217
|
+
+ " = "
|
|
218
|
+
+ self.value_formatter.replace(
|
|
219
|
+
"x", key.name + "_filter_" + str(index)
|
|
220
|
+
)
|
|
221
|
+
)
|
|
222
|
+
if len(inner_statements) > 0:
|
|
223
|
+
statements.append("(" + " OR ".join(inner_statements) + ")")
|
|
214
224
|
|
|
215
225
|
return " AND ".join(statements)
|
|
216
226
|
|
|
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
|
|
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
|