apexdevkit 1.13.1__tar.gz → 1.13.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.13.1 → apexdevkit-1.13.3}/PKG-INFO +1 -1
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/service.py +6 -3
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/base.py +0 -6
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/decorator.py +10 -7
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/in_memory.py +1 -10
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/interface.py +9 -6
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/mongo.py +0 -7
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/sqlite.py +0 -7
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/pyproject.toml +1 -1
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/LICENSE +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/README.md +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/annotation/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/annotation/deprecate.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/environment.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/error.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/builder.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/dependable.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/docs.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/resource.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/response.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/router.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fastapi/schema.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/fluent.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/formatter.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/http/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/http/fake.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/http/fluent.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/http/httpx.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/http/json.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/http/url.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/py.typed +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/alternative/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/alternative/base.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/alternative/formatter_repository.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/connector.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/database.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/testing/__init__.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/testing/database.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/testing/fake.py +0 -0
- {apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/testing/rest.py +0 -0
|
@@ -3,6 +3,7 @@ from dataclasses import dataclass, field
|
|
|
3
3
|
from typing import Any, Dict, Generic, Iterable, Self, TypeVar
|
|
4
4
|
|
|
5
5
|
from apexdevkit.formatter import Formatter
|
|
6
|
+
from apexdevkit.repository.decorator import BatchRepositoryDecorator
|
|
6
7
|
from apexdevkit.repository.interface import Repository
|
|
7
8
|
|
|
8
9
|
RawItem = dict[str, Any]
|
|
@@ -79,7 +80,7 @@ class _RestfulRepository(RestfulService, Generic[ItemT]):
|
|
|
79
80
|
def create_many(self, items: RawCollection) -> RawCollection:
|
|
80
81
|
return [
|
|
81
82
|
self.formatter.dump(item)
|
|
82
|
-
for item in self.repository.create_many(
|
|
83
|
+
for item in BatchRepositoryDecorator(self.repository).create_many(
|
|
83
84
|
[self.formatter.load(fields) for fields in items]
|
|
84
85
|
)
|
|
85
86
|
]
|
|
@@ -106,7 +107,7 @@ class _RestfulRepository(RestfulService, Generic[ItemT]):
|
|
|
106
107
|
|
|
107
108
|
updates.append(self.formatter.load(data))
|
|
108
109
|
|
|
109
|
-
self.repository.update_many(updates)
|
|
110
|
+
BatchRepositoryDecorator(self.repository).update_many(updates)
|
|
110
111
|
|
|
111
112
|
return [self.formatter.dump(item) for item in updates]
|
|
112
113
|
|
|
@@ -116,7 +117,9 @@ class _RestfulRepository(RestfulService, Generic[ItemT]):
|
|
|
116
117
|
return item
|
|
117
118
|
|
|
118
119
|
def replace_many(self, items: RawCollection) -> RawCollection:
|
|
119
|
-
self.repository.update_many(
|
|
120
|
+
BatchRepositoryDecorator(self.repository).update_many(
|
|
121
|
+
[self.formatter.load(item) for item in items]
|
|
122
|
+
)
|
|
120
123
|
|
|
121
124
|
return items
|
|
122
125
|
|
|
@@ -7,18 +7,12 @@ class RepositoryBase(Generic[ItemT]): # pragma: no cover
|
|
|
7
7
|
def create(self, item: ItemT) -> ItemT:
|
|
8
8
|
raise NotImplementedError
|
|
9
9
|
|
|
10
|
-
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
11
|
-
raise NotImplementedError
|
|
12
|
-
|
|
13
10
|
def read(self, item_id: str) -> ItemT:
|
|
14
11
|
raise NotImplementedError
|
|
15
12
|
|
|
16
13
|
def update(self, item: ItemT) -> None:
|
|
17
14
|
raise NotImplementedError
|
|
18
15
|
|
|
19
|
-
def update_many(self, items: list[ItemT]) -> None:
|
|
20
|
-
raise NotImplementedError
|
|
21
|
-
|
|
22
16
|
def delete(self, item_id: str) -> None:
|
|
23
17
|
raise NotImplementedError
|
|
24
18
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
from dataclasses import dataclass
|
|
2
|
-
from typing import Any, Iterator
|
|
2
|
+
from typing import Any, Iterable, Iterator
|
|
3
3
|
|
|
4
4
|
from apexdevkit.repository.base import RepositoryBase
|
|
5
5
|
from apexdevkit.repository.interface import ItemT, Repository
|
|
@@ -12,18 +12,12 @@ class RepositoryDecorator(RepositoryBase[ItemT]):
|
|
|
12
12
|
def create(self, item: ItemT) -> ItemT:
|
|
13
13
|
return self.inner.create(item)
|
|
14
14
|
|
|
15
|
-
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
16
|
-
return self.inner.create_many(items)
|
|
17
|
-
|
|
18
15
|
def read(self, item_id: str) -> ItemT:
|
|
19
16
|
return self.inner.read(item_id)
|
|
20
17
|
|
|
21
18
|
def update(self, item: ItemT) -> None:
|
|
22
19
|
self.inner.update(item)
|
|
23
20
|
|
|
24
|
-
def update_many(self, items: list[ItemT]) -> None:
|
|
25
|
-
self.inner.update_many(items)
|
|
26
|
-
|
|
27
21
|
def delete(self, item_id: str) -> None:
|
|
28
22
|
self.inner.delete(item_id)
|
|
29
23
|
|
|
@@ -35,3 +29,12 @@ class RepositoryDecorator(RepositoryBase[ItemT]):
|
|
|
35
29
|
|
|
36
30
|
def __len__(self) -> int:
|
|
37
31
|
return self.inner.__len__()
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
class BatchRepositoryDecorator(RepositoryDecorator[ItemT]):
|
|
35
|
+
def create_many(self, items: Iterable[ItemT]) -> Iterable[ItemT]:
|
|
36
|
+
return [self.inner.create(item) for item in items]
|
|
37
|
+
|
|
38
|
+
def update_many(self, items: Iterable[ItemT]) -> None:
|
|
39
|
+
for item in items:
|
|
40
|
+
self.inner.update(item)
|
|
@@ -34,15 +34,10 @@ class InMemoryRepository(RepositoryBase[ItemT]):
|
|
|
34
34
|
return self
|
|
35
35
|
|
|
36
36
|
def with_seeded(self, *items: ItemT) -> Self:
|
|
37
|
-
self.create_many(list(items))
|
|
38
|
-
|
|
39
|
-
return self
|
|
40
|
-
|
|
41
|
-
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
42
37
|
for item in items:
|
|
43
38
|
self.create(item)
|
|
44
39
|
|
|
45
|
-
return
|
|
40
|
+
return self
|
|
46
41
|
|
|
47
42
|
def create(self, item: ItemT) -> ItemT:
|
|
48
43
|
self._ensure_does_not_exist(item)
|
|
@@ -63,10 +58,6 @@ class InMemoryRepository(RepositoryBase[ItemT]):
|
|
|
63
58
|
def _pk(self, item: ItemT) -> Any:
|
|
64
59
|
return self._keys[0](item)
|
|
65
60
|
|
|
66
|
-
def update_many(self, items: list[ItemT]) -> None:
|
|
67
|
-
for item in items:
|
|
68
|
-
self.update(item)
|
|
69
|
-
|
|
70
61
|
def update(self, item: ItemT) -> None:
|
|
71
62
|
self.delete(self._pk(item))
|
|
72
63
|
self.create(item)
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
+
from collections.abc import Iterable
|
|
3
4
|
from typing import Any, Iterator, Protocol, TypeVar
|
|
4
5
|
|
|
5
6
|
ItemT = TypeVar("ItemT")
|
|
@@ -9,18 +10,12 @@ class Repository(Protocol[ItemT]): # pragma: no cover
|
|
|
9
10
|
def create(self, item: ItemT) -> ItemT:
|
|
10
11
|
pass
|
|
11
12
|
|
|
12
|
-
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
13
|
-
pass
|
|
14
|
-
|
|
15
13
|
def read(self, item_id: str) -> ItemT:
|
|
16
14
|
pass
|
|
17
15
|
|
|
18
16
|
def update(self, item: ItemT) -> None:
|
|
19
17
|
pass
|
|
20
18
|
|
|
21
|
-
def update_many(self, items: list[ItemT]) -> None:
|
|
22
|
-
pass
|
|
23
|
-
|
|
24
19
|
def delete(self, item_id: str) -> None:
|
|
25
20
|
pass
|
|
26
21
|
|
|
@@ -32,3 +27,11 @@ class Repository(Protocol[ItemT]): # pragma: no cover
|
|
|
32
27
|
|
|
33
28
|
def __len__(self) -> int:
|
|
34
29
|
pass
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
class BatchRepository(Repository[ItemT], Protocol[ItemT]): # pragma: no cover
|
|
33
|
+
def create_many(self, items: Iterable[ItemT]) -> Iterable[ItemT]:
|
|
34
|
+
pass
|
|
35
|
+
|
|
36
|
+
def update_many(self, items: Iterable[ItemT]) -> None:
|
|
37
|
+
pass
|
|
@@ -49,9 +49,6 @@ class MongoRepository(Generic[ItemT]):
|
|
|
49
49
|
self.collection(client).insert_one(self.formatter.dump(item))
|
|
50
50
|
return item
|
|
51
51
|
|
|
52
|
-
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
53
|
-
return [self.create(item) for item in items]
|
|
54
|
-
|
|
55
52
|
def read(self, item_id: str) -> ItemT:
|
|
56
53
|
with self.connector.connect() as client:
|
|
57
54
|
raw = self.collection(client).find_one({"id": item_id})
|
|
@@ -69,10 +66,6 @@ class MongoRepository(Generic[ItemT]):
|
|
|
69
66
|
return_document=ReturnDocument.AFTER,
|
|
70
67
|
)
|
|
71
68
|
|
|
72
|
-
def update_many(self, items: list[ItemT]) -> None:
|
|
73
|
-
for item in items:
|
|
74
|
-
self.update(item)
|
|
75
|
-
|
|
76
69
|
def delete(self, item_id: str) -> None:
|
|
77
70
|
with self.connector.connect() as client:
|
|
78
71
|
result = self.collection(client).delete_one({"id": item_id})
|
|
@@ -39,9 +39,6 @@ class SqliteRepository(RepositoryBase[ItemT]):
|
|
|
39
39
|
self.table.duplicate(item).fire()
|
|
40
40
|
return item
|
|
41
41
|
|
|
42
|
-
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
43
|
-
return [self.create(item) for item in items]
|
|
44
|
-
|
|
45
42
|
def read(self, item_id: str) -> ItemT:
|
|
46
43
|
raw = self.db.execute(self.table.select(str(item_id))).fetch_one()
|
|
47
44
|
|
|
@@ -53,10 +50,6 @@ class SqliteRepository(RepositoryBase[ItemT]):
|
|
|
53
50
|
def update(self, item: ItemT) -> None:
|
|
54
51
|
self.db.execute(self.table.update(item)).fetch_none()
|
|
55
52
|
|
|
56
|
-
def update_many(self, items: list[ItemT]) -> None:
|
|
57
|
-
for item in items:
|
|
58
|
-
self.update(item)
|
|
59
|
-
|
|
60
53
|
def delete(self, item_id: str) -> None:
|
|
61
54
|
self.db.execute(self.table.delete(str(item_id))).fetch_none()
|
|
62
55
|
|
|
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
|
{apexdevkit-1.13.1 → apexdevkit-1.13.3}/apexdevkit/repository/alternative/formatter_repository.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|