aboutsummaryrefslogtreecommitdiff
path: root/src/hydrilla/proxy/state.py
diff options
context:
space:
mode:
authorWojtek Kosior <koszko@koszko.org>2022-08-18 13:40:16 +0200
committerWojtek Kosior <koszko@koszko.org>2022-09-28 12:54:22 +0200
commit2579081df2a568192887d776a6965af323b7c4ee (patch)
tree12491e0ee11568a09891f4d261e9cba60e8a8d52 /src/hydrilla/proxy/state.py
parentc242a5833d41fdcee6e2b35cff7af8d445b44946 (diff)
downloadhaketilo-hydrilla-2579081df2a568192887d776a6965af323b7c4ee.tar.gz
haketilo-hydrilla-2579081df2a568192887d776a6965af323b7c4ee.zip
make it possible to list all repositories in the web UI
Diffstat (limited to 'src/hydrilla/proxy/state.py')
-rw-r--r--src/hydrilla/proxy/state.py31
1 files changed, 27 insertions, 4 deletions
diff --git a/src/hydrilla/proxy/state.py b/src/hydrilla/proxy/state.py
index 14d38b6..c3712f2 100644
--- a/src/hydrilla/proxy/state.py
+++ b/src/hydrilla/proxy/state.py
@@ -39,6 +39,7 @@ import typing as t
from pathlib import Path
from abc import ABC, abstractmethod
from enum import Enum
+from datetime import datetime
from immutables import Map
@@ -68,6 +69,9 @@ class Ref:
"""...."""
id: str
+ def __post_init__(self):
+ assert isinstance(self.id, str)
+
RefType = t.TypeVar('RefType', bound=Ref)
@@ -83,14 +87,13 @@ class Store(ABC, t.Generic[RefType]):
class RepoRef(Ref):
"""...."""
@abstractmethod
- def remove(self, state: 'HaketiloState') -> None:
+ def remove(self) -> None:
"""...."""
...
@abstractmethod
def update(
self,
- state: 'HaketiloState',
*,
name: t.Optional[str] = None,
url: t.Optional[str] = None
@@ -99,10 +102,30 @@ class RepoRef(Ref):
...
@abstractmethod
- def refresh(self, state: 'HaketiloState') -> 'RepoIterationRef':
+ def refresh(self) -> 'RepoIterationRef':
"""...."""
...
+ @abstractmethod
+ def get_display_info(self) -> 'RepoDisplayInfo':
+ ...
+
+@dc.dataclass(frozen=True)
+class RepoDisplayInfo:
+ ref: RepoRef
+ name: str
+ url: t.Optional[str]
+ deleted: t.Optional[bool]
+ last_refreshed: t.Optional[datetime]
+ resource_count: int
+ mapping_count: int
+
+class RepoStore(Store[RepoRef]):
+ @abstractmethod
+ def get_display_infos(self, include_deleted: bool = False) -> \
+ t.Iterable[RepoDisplayInfo]:
+ ...
+
@dc.dataclass(frozen=True, unsafe_hash=True) # type: ignore[misc]
class RepoIterationRef(Ref):
@@ -253,7 +276,7 @@ class HaketiloState(ABC):
...
@abstractmethod
- def get_repo(self, repo_id: str) -> RepoRef:
+ def repo_store(self) -> RepoStore:
"""...."""
...