From 1ed13a692680fcddd01a0162bbf7527da6254ad9 Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 19:34:41 +0200 Subject: [PATCH 1/6] update stac-pydantic dependendy --- stac_fastapi/api/stac_fastapi/api/app.py | 4 ++-- stac_fastapi/api/tests/conftest.py | 1 + stac_fastapi/types/setup.py | 2 +- 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/stac_fastapi/api/stac_fastapi/api/app.py b/stac_fastapi/api/stac_fastapi/api/app.py index ed9a1cc78..7eb7c4e80 100644 --- a/stac_fastapi/api/stac_fastapi/api/app.py +++ b/stac_fastapi/api/stac_fastapi/api/app.py @@ -172,14 +172,14 @@ def register_conformance_classes(self): name="Conformance Classes", path="/conformance", response_model=( - api.ConformanceClasses if self.settings.enable_response_models else None + api.Conformance if self.settings.enable_response_models else None ), responses={ 200: { "content": { MimeTypes.json.value: {}, }, - "model": api.ConformanceClasses, + "model": api.Conformance, }, }, response_class=self.response_class, diff --git a/stac_fastapi/api/tests/conftest.py b/stac_fastapi/api/tests/conftest.py index 1b89f07cd..33919e83e 100644 --- a/stac_fastapi/api/tests/conftest.py +++ b/stac_fastapi/api/tests/conftest.py @@ -16,6 +16,7 @@ @pytest.fixture def _collection(): return Collection( + type="Collection", id="test_collection", title="Test Collection", description="A test collection", diff --git a/stac_fastapi/types/setup.py b/stac_fastapi/types/setup.py index 0dd166ec4..c8f2f9df6 100644 --- a/stac_fastapi/types/setup.py +++ b/stac_fastapi/types/setup.py @@ -9,7 +9,7 @@ "fastapi-slim", "attrs>=23.2.0", "pydantic-settings>=2", - "stac_pydantic>=3", + "stac_pydantic~=3.1", "iso8601>=1.0.2,<2.2.0", ] From f89bf48cf47d04e2307a5844d76b65ad779c12d0 Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 19:38:26 +0200 Subject: [PATCH 2/6] replace stac-pydantic todos --- stac_fastapi/types/stac_fastapi/types/core.py | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/stac_fastapi/types/stac_fastapi/types/core.py b/stac_fastapi/types/stac_fastapi/types/core.py index fdf020b08..ba6ebe440 100644 --- a/stac_fastapi/types/stac_fastapi/types/core.py +++ b/stac_fastapi/types/stac_fastapi/types/core.py @@ -380,10 +380,8 @@ def landing_page(self, **kwargs) -> stac.LandingPage: if self.extension_is_enabled("FilterExtension"): landing_page["links"].append( { - # TODO: replace this with Relations.queryables.value, - "rel": "http://www.opengis.net/def/rel/ogc/1.0/queryables", - # TODO: replace this with MimeTypes.jsonschema, - "type": "application/schema+json", + "rel": Relations.queryables.value, + "type": MimeTypes.jsonschema.value, "title": "Queryables", "href": urljoin(base_url, "queryables"), "method": "GET", @@ -586,10 +584,8 @@ async def landing_page(self, **kwargs) -> stac.LandingPage: if self.extension_is_enabled("FilterExtension"): landing_page["links"].append( { - # TODO: replace this with Relations.queryables.value, - "rel": "http://www.opengis.net/def/rel/ogc/1.0/queryables", - # TODO: replace this with MimeTypes.jsonschema, - "type": "application/schema+json", + "rel": Relations.queryables.value, + "type": MimeTypes.jsonschema.value, "title": "Queryables", "href": urljoin(base_url, "queryables"), "method": "GET", From a0408eb152b099694bcbe6427e4d144539630499 Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 19:46:17 +0200 Subject: [PATCH 3/6] fix benchmark --- stac_fastapi/api/tests/benchmarks.py | 1 + 1 file changed, 1 insertion(+) diff --git a/stac_fastapi/api/tests/benchmarks.py b/stac_fastapi/api/tests/benchmarks.py index 95e1c532a..730f9d40b 100644 --- a/stac_fastapi/api/tests/benchmarks.py +++ b/stac_fastapi/api/tests/benchmarks.py @@ -17,6 +17,7 @@ collections = [ stac_types.Collection( id=f"test_collection_{n}", + type="Collection", title="Test Collection", description="A test collection", keywords=["test"], From 99a0703c7c66ebce4216df4b41ca7125c4e6177d Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 19:49:44 +0200 Subject: [PATCH 4/6] replace deprecated .dict() --- stac_fastapi/api/tests/benchmarks.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/stac_fastapi/api/tests/benchmarks.py b/stac_fastapi/api/tests/benchmarks.py index 730f9d40b..475250d7f 100644 --- a/stac_fastapi/api/tests/benchmarks.py +++ b/stac_fastapi/api/tests/benchmarks.py @@ -26,7 +26,7 @@ "spatial": {"bbox": [[-180, -90, 180, 90]]}, "temporal": {"interval": [["2000-01-01T00:00:00Z", None]]}, }, - links=collection_links.dict(exclude_none=True), + links=collection_links.model_dump(exclude_none=True), ) for n in range(0, 10) ] @@ -38,7 +38,7 @@ geometry={"type": "Point", "coordinates": [0, 0]}, bbox=[-180, -90, 180, 90], properties={"datetime": "2000-01-01T00:00:00Z"}, - links=item_links.dict(exclude_none=True), + links=item_links.model_dump(exclude_none=True), assets={}, ) for n in range(0, 1000) From 454dac829f62220643273c164aff702889bf72c8 Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 19:52:57 +0200 Subject: [PATCH 5/6] fix datetime interval for GET Search --- stac_fastapi/types/stac_fastapi/types/rfc3339.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/stac_fastapi/types/stac_fastapi/types/rfc3339.py b/stac_fastapi/types/stac_fastapi/types/rfc3339.py index a551b45d0..5ba0630aa 100644 --- a/stac_fastapi/types/stac_fastapi/types/rfc3339.py +++ b/stac_fastapi/types/stac_fastapi/types/rfc3339.py @@ -122,6 +122,9 @@ def str_to_interval(interval: Optional[str]) -> Optional[DateTimeType]: detail="Interval string contains more than one forward slash.", ) + if len(values) == 1: + values = [values[0], values[0]] + try: start = parse_single_date(values[0]) if values[0] not in ["..", ""] else None end = ( From 47909ce6942292d7219b26565f888a0d78c2cd58 Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 21:11:34 +0200 Subject: [PATCH 6/6] update changelog --- CHANGES.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 940b7b844..abff6ce43 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -4,8 +4,10 @@ ### Changed -* switch from `fastapi` to `fastapi-slim` to avoid installing unwanted dependencies. ([#687](https://github.com/stac-utils/stac-fastapi/pull/687)) -* replace Enum with `Literal` for `FilterLang`. ([#686](https://github.com/stac-utils/stac-fastapi/pull/686)) +* Switch from `fastapi` to `fastapi-slim` to avoid installing unwanted dependencies. ([#687](https://github.com/stac-utils/stac-fastapi/pull/687)) +* Replace Enum with `Literal` for `FilterLang`. ([#686](https://github.com/stac-utils/stac-fastapi/pull/686)) +* Update stac-pydantic requirement to `~3.1` ([#697](https://github.com/stac-utils/stac-fastapi/pull/697)) +* Fix datetime interval for GET Search when passing a single value ([#697](https://github.com/stac-utils/stac-fastapi/pull/697)) ### Removed