apexdevkit 1.12.6__tar.gz → 1.13.1__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.12.6 → apexdevkit-1.13.1}/PKG-INFO +1 -1
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/service.py +3 -3
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/base.py +5 -5
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/decorator.py +6 -6
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/in_memory.py +4 -4
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/interface.py +4 -5
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/sqlite.py +5 -5
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/pyproject.toml +1 -1
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/LICENSE +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/README.md +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/annotation/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/annotation/deprecate.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/environment.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/error.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/builder.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/dependable.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/docs.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/resource.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/response.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/router.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fastapi/schema.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/fluent.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/formatter.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/http/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/http/fake.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/http/fluent.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/http/httpx.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/http/json.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/http/url.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/py.typed +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/alternative/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/alternative/base.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/alternative/formatter_repository.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/connector.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/database.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/repository/mongo.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/testing/__init__.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/testing/database.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/testing/fake.py +0 -0
- {apexdevkit-1.12.6 → apexdevkit-1.13.1}/apexdevkit/testing/rest.py +0 -0
|
@@ -52,14 +52,14 @@ ItemT = TypeVar("ItemT")
|
|
|
52
52
|
@dataclass
|
|
53
53
|
class RestfulRepositoryBuilder(Generic[ItemT]):
|
|
54
54
|
formatter: Formatter[dict[str, Any], ItemT] = field(init=False)
|
|
55
|
-
repository: Repository[
|
|
55
|
+
repository: Repository[ItemT] = field(init=False)
|
|
56
56
|
|
|
57
57
|
def with_formatter(self, formatter: Formatter[dict[str, Any], ItemT]) -> Self:
|
|
58
58
|
self.formatter = formatter
|
|
59
59
|
|
|
60
60
|
return self
|
|
61
61
|
|
|
62
|
-
def with_repository(self, repository: Repository[
|
|
62
|
+
def with_repository(self, repository: Repository[ItemT]) -> Self:
|
|
63
63
|
self.repository = repository
|
|
64
64
|
|
|
65
65
|
return self
|
|
@@ -71,7 +71,7 @@ class RestfulRepositoryBuilder(Generic[ItemT]):
|
|
|
71
71
|
@dataclass
|
|
72
72
|
class _RestfulRepository(RestfulService, Generic[ItemT]):
|
|
73
73
|
formatter: Formatter[dict[str, Any], ItemT]
|
|
74
|
-
repository: Repository[
|
|
74
|
+
repository: Repository[ItemT]
|
|
75
75
|
|
|
76
76
|
def create_one(self, item: RawItem) -> RawItem:
|
|
77
77
|
return self.formatter.dump(self.repository.create(self.formatter.load(item)))
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
from typing import Any, Generic, Iterator
|
|
2
2
|
|
|
3
|
-
from apexdevkit.repository.interface import
|
|
3
|
+
from apexdevkit.repository.interface import ItemT, Repository
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
class RepositoryBase(Generic[
|
|
6
|
+
class RepositoryBase(Generic[ItemT]): # pragma: no cover
|
|
7
7
|
def create(self, item: ItemT) -> ItemT:
|
|
8
8
|
raise NotImplementedError
|
|
9
9
|
|
|
10
10
|
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
11
11
|
raise NotImplementedError
|
|
12
12
|
|
|
13
|
-
def read(self, item_id:
|
|
13
|
+
def read(self, item_id: str) -> ItemT:
|
|
14
14
|
raise NotImplementedError
|
|
15
15
|
|
|
16
16
|
def update(self, item: ItemT) -> None:
|
|
@@ -19,10 +19,10 @@ class RepositoryBase(Generic[IdT, ItemT]): # pragma: no cover
|
|
|
19
19
|
def update_many(self, items: list[ItemT]) -> None:
|
|
20
20
|
raise NotImplementedError
|
|
21
21
|
|
|
22
|
-
def delete(self, item_id:
|
|
22
|
+
def delete(self, item_id: str) -> None:
|
|
23
23
|
raise NotImplementedError
|
|
24
24
|
|
|
25
|
-
def bind(self, **kwargs: Any) -> Repository[
|
|
25
|
+
def bind(self, **kwargs: Any) -> Repository[ItemT]:
|
|
26
26
|
raise NotImplementedError
|
|
27
27
|
|
|
28
28
|
def __iter__(self) -> Iterator[ItemT]:
|
|
@@ -2,12 +2,12 @@ from dataclasses import dataclass
|
|
|
2
2
|
from typing import Any, Iterator
|
|
3
3
|
|
|
4
4
|
from apexdevkit.repository.base import RepositoryBase
|
|
5
|
-
from apexdevkit.repository.interface import
|
|
5
|
+
from apexdevkit.repository.interface import ItemT, Repository
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
@dataclass
|
|
9
|
-
class RepositoryDecorator(RepositoryBase[
|
|
10
|
-
inner: Repository[
|
|
9
|
+
class RepositoryDecorator(RepositoryBase[ItemT]):
|
|
10
|
+
inner: Repository[ItemT]
|
|
11
11
|
|
|
12
12
|
def create(self, item: ItemT) -> ItemT:
|
|
13
13
|
return self.inner.create(item)
|
|
@@ -15,7 +15,7 @@ class RepositoryDecorator(RepositoryBase[IdT, ItemT]):
|
|
|
15
15
|
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
16
16
|
return self.inner.create_many(items)
|
|
17
17
|
|
|
18
|
-
def read(self, item_id:
|
|
18
|
+
def read(self, item_id: str) -> ItemT:
|
|
19
19
|
return self.inner.read(item_id)
|
|
20
20
|
|
|
21
21
|
def update(self, item: ItemT) -> None:
|
|
@@ -24,10 +24,10 @@ class RepositoryDecorator(RepositoryBase[IdT, ItemT]):
|
|
|
24
24
|
def update_many(self, items: list[ItemT]) -> None:
|
|
25
25
|
self.inner.update_many(items)
|
|
26
26
|
|
|
27
|
-
def delete(self, item_id:
|
|
27
|
+
def delete(self, item_id: str) -> None:
|
|
28
28
|
self.inner.delete(item_id)
|
|
29
29
|
|
|
30
|
-
def bind(self, **kwargs: Any) -> Repository[
|
|
30
|
+
def bind(self, **kwargs: Any) -> Repository[ItemT]:
|
|
31
31
|
return self.inner.bind(**kwargs)
|
|
32
32
|
|
|
33
33
|
def __iter__(self) -> Iterator[ItemT]:
|
|
@@ -4,7 +4,7 @@ from typing import Any, Callable, Iterable, Iterator, Self
|
|
|
4
4
|
from apexdevkit.error import DoesNotExistError, ExistsError
|
|
5
5
|
from apexdevkit.formatter import Formatter
|
|
6
6
|
from apexdevkit.repository import RepositoryBase
|
|
7
|
-
from apexdevkit.repository.interface import
|
|
7
|
+
from apexdevkit.repository.interface import ItemT
|
|
8
8
|
|
|
9
9
|
KeyFunction = Callable[[Any], str]
|
|
10
10
|
_Raw = dict[str, Any]
|
|
@@ -19,7 +19,7 @@ class AttributeKey:
|
|
|
19
19
|
|
|
20
20
|
|
|
21
21
|
@dataclass
|
|
22
|
-
class InMemoryRepository(RepositoryBase[
|
|
22
|
+
class InMemoryRepository(RepositoryBase[ItemT]):
|
|
23
23
|
formatter: Formatter[_Raw, ItemT]
|
|
24
24
|
items: dict[str, _Raw] = field(default_factory=dict)
|
|
25
25
|
|
|
@@ -71,11 +71,11 @@ class InMemoryRepository(RepositoryBase[IdT, ItemT]):
|
|
|
71
71
|
self.delete(self._pk(item))
|
|
72
72
|
self.create(item)
|
|
73
73
|
|
|
74
|
-
def delete(self, item_id:
|
|
74
|
+
def delete(self, item_id: str) -> None:
|
|
75
75
|
item = self.read(item_id)
|
|
76
76
|
del self.items[self._pk(item)]
|
|
77
77
|
|
|
78
|
-
def read(self, item_id:
|
|
78
|
+
def read(self, item_id: str) -> ItemT:
|
|
79
79
|
for key in self._keys:
|
|
80
80
|
for item in self:
|
|
81
81
|
if key(item) == str(item_id):
|
|
@@ -3,17 +3,16 @@ from __future__ import annotations
|
|
|
3
3
|
from typing import Any, Iterator, Protocol, TypeVar
|
|
4
4
|
|
|
5
5
|
ItemT = TypeVar("ItemT")
|
|
6
|
-
IdT = TypeVar("IdT", contravariant=True)
|
|
7
6
|
|
|
8
7
|
|
|
9
|
-
class Repository(Protocol[
|
|
8
|
+
class Repository(Protocol[ItemT]): # pragma: no cover
|
|
10
9
|
def create(self, item: ItemT) -> ItemT:
|
|
11
10
|
pass
|
|
12
11
|
|
|
13
12
|
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
14
13
|
pass
|
|
15
14
|
|
|
16
|
-
def read(self, item_id:
|
|
15
|
+
def read(self, item_id: str) -> ItemT:
|
|
17
16
|
pass
|
|
18
17
|
|
|
19
18
|
def update(self, item: ItemT) -> None:
|
|
@@ -22,10 +21,10 @@ class Repository(Protocol[IdT, ItemT]): # pragma: no cover
|
|
|
22
21
|
def update_many(self, items: list[ItemT]) -> None:
|
|
23
22
|
pass
|
|
24
23
|
|
|
25
|
-
def delete(self, item_id:
|
|
24
|
+
def delete(self, item_id: str) -> None:
|
|
26
25
|
pass
|
|
27
26
|
|
|
28
|
-
def bind(self, **kwargs: Any) -> Repository[
|
|
27
|
+
def bind(self, **kwargs: Any) -> Repository[ItemT]:
|
|
29
28
|
pass
|
|
30
29
|
|
|
31
30
|
def __iter__(self) -> Iterator[ItemT]:
|
|
@@ -6,15 +6,15 @@ from typing import Any, Generic, Iterator
|
|
|
6
6
|
|
|
7
7
|
from apexdevkit.error import DoesNotExistError, ExistsError
|
|
8
8
|
from apexdevkit.repository import Database, DatabaseCommand, RepositoryBase
|
|
9
|
-
from apexdevkit.repository.interface import
|
|
9
|
+
from apexdevkit.repository.interface import ItemT
|
|
10
10
|
|
|
11
11
|
|
|
12
12
|
@dataclass
|
|
13
|
-
class SqliteRepository(RepositoryBase[
|
|
13
|
+
class SqliteRepository(RepositoryBase[ItemT]):
|
|
14
14
|
db: Database
|
|
15
15
|
table: SqlTable[ItemT]
|
|
16
16
|
|
|
17
|
-
def bind(self, **kwargs: Any) -> SqliteRepository[
|
|
17
|
+
def bind(self, **kwargs: Any) -> SqliteRepository[ItemT]:
|
|
18
18
|
return SqliteRepository(self.db, self.table.bind(**kwargs))
|
|
19
19
|
|
|
20
20
|
def __iter__(self) -> Iterator[ItemT]:
|
|
@@ -42,7 +42,7 @@ class SqliteRepository(RepositoryBase[IdT, ItemT]):
|
|
|
42
42
|
def create_many(self, items: list[ItemT]) -> list[ItemT]:
|
|
43
43
|
return [self.create(item) for item in items]
|
|
44
44
|
|
|
45
|
-
def read(self, item_id:
|
|
45
|
+
def read(self, item_id: str) -> ItemT:
|
|
46
46
|
raw = self.db.execute(self.table.select(str(item_id))).fetch_one()
|
|
47
47
|
|
|
48
48
|
if not raw:
|
|
@@ -57,7 +57,7 @@ class SqliteRepository(RepositoryBase[IdT, ItemT]):
|
|
|
57
57
|
for item in items:
|
|
58
58
|
self.update(item)
|
|
59
59
|
|
|
60
|
-
def delete(self, item_id:
|
|
60
|
+
def delete(self, item_id: str) -> None:
|
|
61
61
|
self.db.execute(self.table.delete(str(item_id))).fetch_none()
|
|
62
62
|
|
|
63
63
|
def delete_all(self) -> None:
|
|
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.12.6 → apexdevkit-1.13.1}/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
|
|
File without changes
|