Skip to content
This repository has been archived by the owner on Nov 4, 2024. It is now read-only.

Commit

Permalink
breaking: Rename PostgresJSONB to JSONB and PostgresUUID to UUID
Browse files Browse the repository at this point in the history
  • Loading branch information
etimberg committed Aug 8, 2021
1 parent e1a8fb2 commit c73c294
Show file tree
Hide file tree
Showing 8 changed files with 50 additions and 13 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ python -m pip install ormar-postgres-extensions

### Fields

Two native PG fields are provided. The `PostgresJSONB` and `PostgresUUID` types map to native `JSONB` and `UUID` data types respectively. Using these in an Ormar model is as simple as importing the fields and using them in the model.
Two native PG fields are provided. The `JSONB` and `UUID` types map to native `JSONB` and `UUID` data types respectively. Using these in an Ormar model is as simple as importing the fields and using them in the model.

```python
from uuid import UUID
Expand Down
4 changes: 2 additions & 2 deletions src/ormar_postgres_extensions/__init__.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
from .fields import ( # noqa: F401
PostgresJSONB,
PostgresUUID,
JSONB,
UUID,
)
4 changes: 2 additions & 2 deletions src/ormar_postgres_extensions/fields/__init__.py
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
from .jsonb import PostgresJSONB # noqa: F401
from .uuid import PostgresUUID # noqa: F401
from .jsonb import JSONB # noqa: F401
from .uuid import UUID # noqa: F401
37 changes: 37 additions & 0 deletions src/ormar_postgres_extensions/fields/array.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
from typing import Any

import ormar
from sqlalchemy.dialects import postgresql
from sqlalchemy.types import TypeDecorator


class PostgresArrayTypeDecorator(TypeDecorator):
def __init__(self, item_type, *args, **kwargs):
super().__init__(*args, **kwargs)
self._impl = postgresql.ARRAY(item_type)

@property
def impl(self):
return self._impl


class PostgresArray(ormar.fields.model_fields.ModelFieldFactory, list):
_type = list
_sample = []

def __new__( # type: ignore
cls, *, item_type, **kwargs: Any
) -> ormar.fields.BaseField:
kwargs = {
**kwargs,
**{
k: v
for k, v in locals().items()
if k not in ["cls", "__class__", "kwargs"]
},
}
return super().__new__(cls, **kwargs)

@classmethod
def get_column_type(cls, **kwargs: Any) -> PostgresArrayTypeDecorator:
return PostgresArrayTypeDecorator(item_type=kwargs["item_type"])
2 changes: 1 addition & 1 deletion src/ormar_postgres_extensions/fields/jsonb.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ class PostgresJSONBTypeDecorator(TypeDecorator):
impl = postgresql.JSONB


class PostgresJSONB(ormar.JSON):
class JSONB(ormar.JSON):
"""
Custom JSON field uses a native PG JSONB type
"""
Expand Down
2 changes: 1 addition & 1 deletion src/ormar_postgres_extensions/fields/uuid.py
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ def process_result_value(
return value


class PostgresUUID(ormar.UUID):
class UUID(ormar.UUID):
"""
Custom UUID field for the schema that uses a native PG UUID type
"""
Expand Down
6 changes: 3 additions & 3 deletions tests/fields/test_jsonb.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import ormar
import pytest

from ormar_postgres_extensions.fields import PostgresJSONB
from ormar_postgres_extensions.fields import JSONB
from tests.database import (
database,
metadata,
Expand All @@ -17,7 +17,7 @@ class Meta:
metadata = metadata

id: int = ormar.Integer(primary_key=True)
data: dict = PostgresJSONB()
data: dict = JSONB()


class NullableJSONBTestModel(ormar.Model):
Expand All @@ -26,7 +26,7 @@ class Meta:
metadata = metadata

id: int = ormar.Integer(primary_key=True)
data: Optional[dict] = PostgresJSONB(nullable=True)
data: Optional[dict] = JSONB(nullable=True)


@pytest.mark.asyncio
Expand Down
6 changes: 3 additions & 3 deletions tests/fields/test_uuid.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
import ormar
import pytest

from ormar_postgres_extensions.fields import PostgresUUID
from ormar_postgres_extensions.fields import UUID as UUIDField
from tests.database import (
database,
metadata,
Expand All @@ -20,7 +20,7 @@ class Meta:
metadata = metadata

id: int = ormar.Integer(primary_key=True)
uid: UUID = PostgresUUID(default=uuid4)
uid: UUID = UUIDField(default=uuid4)


class NullableUUIDTestModel(ormar.Model):
Expand All @@ -29,7 +29,7 @@ class Meta:
metadata = metadata

id: int = ormar.Integer(primary_key=True)
uid: Optional[UUID] = PostgresUUID(nullable=True)
uid: Optional[UUID] = UUIDField(nullable=True)


@pytest.mark.asyncio
Expand Down

0 comments on commit c73c294

Please sign in to comment.