Skip to content

Commit

Permalink
update Field usage to avoid deprecation in pydantic 3.0
Browse files Browse the repository at this point in the history
  • Loading branch information
vincentsarago committed Feb 2, 2024
1 parent f72c415 commit 9c67c4b
Show file tree
Hide file tree
Showing 3 changed files with 142 additions and 40 deletions.
4 changes: 4 additions & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@

## 5.2.3 (2024-02-02)

* update pydantic `Field` usage to avoid deprecation in 3.0

## 5.2.2 (2024-01-25)

* fix `id` for `WGS1984Quad` TileMatrixSet (from `WorldCRS84Quad` to `WGS1984Quad`)
Expand Down
172 changes: 132 additions & 40 deletions morecantile/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -54,11 +54,13 @@ class CRSUri(BaseModel):
uri: Annotated[
AnyUrl,
Field(
description="Reference to one coordinate reference system (CRS) as URI",
examples=[
"http://www.opengis.net/def/crs/EPSG/0/3978",
"urn:ogc:def:crs:EPSG::2193",
],
json_schema_extra={
"description": "Reference to one coordinate reference system (CRS) as URI",
"exemples": [
"http://www.opengis.net/def/crs/EPSG/0/3978",
"urn:ogc:def:crs:EPSG::2193",
],
}
),
]

Expand All @@ -69,7 +71,9 @@ class CRSWKT(BaseModel):
wkt: Annotated[
Dict,
Field(
description="An object defining the CRS using the JSON encoding for Well-known text representation of coordinate reference systems 2.0",
json_schema_extra={
"description": "An object defining the CRS using the JSON encoding for Well-known text representation of coordinate reference systems 2.0",
}
),
]

Expand All @@ -80,7 +84,9 @@ class CRSRef(BaseModel):
referenceSystem: Annotated[
Dict[str, Any],
Field(
description="A reference system data structure as defined in the MD_ReferenceSystem of the ISO 19115",
json_schema_extra={
"description": "A reference system data structure as defined in the MD_ReferenceSystem of the ISO 19115",
}
),
]

Expand Down Expand Up @@ -178,19 +184,35 @@ class TMSBoundingBox(BaseModel, arbitrary_types_allowed=True):

lowerLeft: Annotated[
BoundsType,
Field(description="A 2D Point in the CRS indicated elsewhere"),
Field(
json_schema_extra={
"description": "A 2D Point in the CRS indicated elsewhere",
}
),
]
upperRight: Annotated[
BoundsType,
Field(description="A 2D Point in the CRS indicated elsewhere"),
Field(
json_schema_extra={
"description": "A 2D Point in the CRS indicated elsewhere",
}
),
]
crs: Annotated[
Optional[CRS],
Field(description="Coordinate Reference System (CRS)"),
Field(
json_schema_extra={
"description": "Coordinate Reference System (CRS)",
}
),
] = None
orderedAxes: Annotated[
Optional[axesInfo],
Field(description="Ordered list of names of the dimensions defined in the CRS"),
Field(
json_schema_extra={
"description": "Ordered list of names of the dimensions defined in the CRS",
}
),
] = None


Expand All @@ -205,23 +227,29 @@ class variableMatrixWidth(BaseModel):
Field(
ge=2,
multiple_of=1,
description="Number of tiles in width that coalesce in a single tile for these rows",
json_schema_extra={
"description": "Number of tiles in width that coalesce in a single tile for these rows",
},
),
]
minTileRow: Annotated[
int,
Field(
ge=0,
multiple_of=1,
description="First tile row where the coalescence factor applies for this tilematrix",
json_schema_extra={
"description": "First tile row where the coalescence factor applies for this tilematrix",
},
),
]
maxTileRow: Annotated[
int,
Field(
ge=0,
multiple_of=1,
description="Last tile row where the coalescence factor applies for this tilematrix",
json_schema_extra={
"description": "Last tile row where the coalescence factor applies for this tilematrix",
},
),
]

Expand All @@ -237,83 +265,115 @@ class TileMatrix(BaseModel, extra="forbid"):
title: Annotated[
Optional[str],
Field(
description="Title of this tile matrix, normally used for display to a human"
json_schema_extra={
"description": "Title of this tile matrix, normally used for display to a human",
}
),
] = None
description: Annotated[
Optional[str],
Field(
description="Brief narrative description of this tile matrix set, normally available for display to a human",
json_schema_extra={
"description": "Brief narrative description of this tile matrix set, normally available for display to a human",
}
),
] = None
keywords: Annotated[
Optional[List[str]],
Field(
description="Unordered list of one or more commonly used or formalized word(s) or phrase(s) used to describe this dataset",
json_schema_extra={
"description": "Unordered list of one or more commonly used or formalized word(s) or phrase(s) used to describe this dataset",
}
),
] = None
id: Annotated[
str,
Field(
pattern=r"^\-?[0-9]+$",
description="Identifier selecting one of the scales defined in the TileMatrixSet and representing the scaleDenominator the tile. Implementation of 'identifier'",
json_schema_extra={
"description": "Identifier selecting one of the scales defined in the TileMatrixSet and representing the scaleDenominator the tile. Implementation of 'identifier'",
},
),
]
scaleDenominator: Annotated[
float,
Field(description="Scale denominator of this tile matrix"),
Field(
json_schema_extra={
"description": "Scale denominator of this tile matrix",
}
),
]
cellSize: Annotated[
float,
Field(description="Cell size of this tile matrix"),
Field(
json_schema_extra={
"description": "Cell size of this tile matrix",
}
),
]
cornerOfOrigin: Annotated[
Literal["topLeft", "bottomLeft"],
Field(
description="The corner of the tile matrix (_topLeft_ or _bottomLeft_) used as the origin for numbering tile rows and columns. This corner is also a corner of the (0, 0) tile.",
json_schema_extra={
"description": "The corner of the tile matrix (_topLeft_ or _bottomLeft_) used as the origin for numbering tile rows and columns. This corner is also a corner of the (0, 0) tile.",
}
),
] = "topLeft"
pointOfOrigin: Annotated[
BoundsType,
Field(
description="Precise position in CRS coordinates of the corner of origin (e.g. the top-left corner) for this tile matrix. This position is also a corner of the (0, 0) tile. In previous version, this was 'topLeftCorner' and 'cornerOfOrigin' did not exist.",
json_schema_extra={
"description": "Precise position in CRS coordinates of the corner of origin (e.g. the top-left corner) for this tile matrix. This position is also a corner of the (0, 0) tile. In previous version, this was 'topLeftCorner' and 'cornerOfOrigin' did not exist.",
}
),
]
tileWidth: Annotated[
int,
Field(
ge=1,
multiple_of=1,
description="Width of each tile of this tile matrix in pixels",
json_schema_extra={
"description": "Width of each tile of this tile matrix in pixels",
},
),
]
tileHeight: Annotated[
int,
Field(
ge=1,
multiple_of=1,
description="Height of each tile of this tile matrix in pixels",
json_schema_extra={
"description": "Height of each tile of this tile matrix in pixels",
},
),
]
matrixWidth: Annotated[
int,
Field(
ge=1,
multiple_of=1,
description="Width of the matrix (number of tiles in width)",
json_schema_extra={
"description": "Width of the matrix (number of tiles in width)",
},
),
]
matrixHeight: Annotated[
int,
Field(
ge=1,
multiple_of=1,
description="Height of the matrix (number of tiles in height)",
json_schema_extra={
"description": "Height of the matrix (number of tiles in height)",
},
),
]
variableMatrixWidths: Annotated[
Optional[List[variableMatrixWidth]],
Field(description="Describes the rows that has variable matrix width"),
Field(
json_schema_extra={
"description": "Describes the rows that has variable matrix width",
}
),
] = None

def get_coalesce_factor(self, row: int) -> int:
Expand Down Expand Up @@ -350,51 +410,83 @@ class TileMatrixSet(BaseModel, arbitrary_types_allowed=True):
title: Annotated[
Optional[str],
Field(
description="Title of this tile matrix set, normally used for display to a human",
json_schema_extra={
"description": "Title of this tile matrix set, normally used for display to a human",
}
),
] = None
description: Annotated[
Optional[str],
Field(
json_schema_extra={
"description": "Brief narrative description of this tile matrix set, normally available for display to a human",
}
),
] = None
description: Optional[str] = Field(
None,
description="Brief narrative description of this tile matrix set, normally available for display to a human",
)
keywords: Annotated[
Optional[List[str]],
Field(
description="Unordered list of one or more commonly used or formalized word(s) or phrase(s) used to describe this tile matrix set",
json_schema_extra={
"description": "Unordered list of one or more commonly used or formalized word(s) or phrase(s) used to describe this tile matrix set",
}
),
] = None
id: Annotated[
Optional[str],
Field(
pattern=r"^[\w\d_\-]+$",
description="Tile matrix set identifier. Implementation of 'identifier'",
json_schema_extra={
"description": "Tile matrix set identifier. Implementation of 'identifier'",
},
),
] = None
uri: Annotated[
Optional[str],
Field(description="Reference to an official source for this tileMatrixSet"),
Field(
json_schema_extra={
"description": "Reference to an official source for this tileMatrixSet",
}
),
] = None
orderedAxes: Annotated[
Optional[axesInfo],
Field(description="Ordered list of names of the dimensions defined in the CRS"),
Field(
json_schema_extra={
"description": "Ordered list of names of the dimensions defined in the CRS",
}
),
] = None
crs: Annotated[
CRS,
Field(description="Coordinate Reference System (CRS)"),
Field(
json_schema_extra={
"description": "Coordinate Reference System (CRS)",
}
),
]
wellKnownScaleSet: Annotated[
Optional[AnyHttpUrl],
Field(description="Reference to a well-known scale set"),
Field(
json_schema_extra={
"description": "Reference to a well-known scale set",
}
),
] = None
boundingBox: Annotated[
Optional[TMSBoundingBox],
Field(
description="Minimum bounding rectangle surrounding the tile matrix set, in the supported CRS",
json_schema_extra={
"description": "Minimum bounding rectangle surrounding the tile matrix set, in the supported CRS",
}
),
] = None
tileMatrices: Annotated[
List[TileMatrix],
Field(description="Describes scale levels and its tile matrices"),
Field(
json_schema_extra={
"description": "Describes scale levels and its tile matrices",
}
),
]

# Private attributes
Expand Down
6 changes: 6 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -104,3 +104,9 @@ ignore = [

[tool.ruff.per-file-ignores]
"tests/*.py" = ["D1"]


[tool.pytest.ini_options]
filterwarnings = [
"ignore:You will likely lose important projection*:UserWarning",
]

0 comments on commit 9c67c4b

Please sign in to comment.