apexdevkit 1.19.1__tar.gz → 1.19.2__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.2}/PKG-INFO +1 -1
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/sql.py +28 -19
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/pyproject.toml +1 -1
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/LICENSE +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/README.md +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/annotation/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/annotation/deprecate.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/environment.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/error.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/builder.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/dependable.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/docs.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/name.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/request.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/resource.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/response.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/router.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/schema.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fastapi/service.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/fluent.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/formatter.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/fake.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/fluent.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/httpx/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/httpx/client.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/httpx/hooks.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/json.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/http/url.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/id.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/key_fn.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/py.typed +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/query/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/query/generator.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/query/query.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/base.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/connector.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/database.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/decorator.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/in_memory.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/interface.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/mongo.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/mssql.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/repository/sqlite.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/server.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/synchronization.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/testing/__init__.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/testing/database.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/testing/fake.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/apexdevkit/testing/rest.py +0 -0
- {apexdevkit-1.19.1 → apexdevkit-1.19.2}/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,9 @@ 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
|
+
data[key.name + "_filter_" + str(index)] = value
|
|
164
167
|
return data
|
|
165
168
|
|
|
166
169
|
def _parent_filter(self) -> str:
|
|
@@ -197,20 +200,26 @@ class SqlFieldManager:
|
|
|
197
200
|
statements: list[str] = []
|
|
198
201
|
for key in self.fields:
|
|
199
202
|
if key.is_filter:
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
203
|
+
inner_statements: list[str] = []
|
|
204
|
+
for index, value in enumerate(key.filter_values):
|
|
205
|
+
if value is None:
|
|
206
|
+
inner_statements.append(
|
|
207
|
+
self.key_formatter.replace("x", key.name) + " IS NULL"
|
|
208
|
+
)
|
|
209
|
+
elif isinstance(value, NotNone):
|
|
210
|
+
inner_statements.append(
|
|
211
|
+
self.key_formatter.replace("x", key.name) + " IS NOT NULL"
|
|
212
|
+
)
|
|
213
|
+
else:
|
|
214
|
+
inner_statements.append(
|
|
215
|
+
self.key_formatter.replace("x", key.name)
|
|
216
|
+
+ " = "
|
|
217
|
+
+ self.value_formatter.replace(
|
|
218
|
+
"x", key.name + "_filter_" + str(index)
|
|
219
|
+
)
|
|
220
|
+
)
|
|
221
|
+
if len(inner_statements) > 0:
|
|
222
|
+
statements.append("(" + " OR ".join(inner_statements) + ")")
|
|
214
223
|
|
|
215
224
|
return " AND ".join(statements)
|
|
216
225
|
|
|
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
|