42 lines
1.3 KiB
Python
42 lines
1.3 KiB
Python
|
from ..adapters.postgres import Postgre, PostgreNew
|
||
|
from .base import SQLRepresenter, JSONRepresenter
|
||
|
from . import representers, before_type, for_type
|
||
|
from ..helpers.serializers import serializers
|
||
|
|
||
|
|
||
|
@representers.register_for(Postgre)
|
||
|
class PostgreRepresenter(SQLRepresenter, JSONRepresenter):
|
||
|
def _make_geoextra(self, field_type):
|
||
|
srid = 4326
|
||
|
geotype, params = field_type[:-1].split('(')
|
||
|
params = params.split(',')
|
||
|
if len(params) >= 2:
|
||
|
schema, srid = params[:2]
|
||
|
return {'srid': srid}
|
||
|
|
||
|
@before_type('geometry')
|
||
|
def geometry_extras(self, field_type):
|
||
|
return self._make_geoextra(field_type)
|
||
|
|
||
|
@for_type('geometry', adapt=False)
|
||
|
def _geometry(self, value, srid):
|
||
|
return "ST_GeomFromText('%s',%s)" % (value, srid)
|
||
|
|
||
|
@before_type('geography')
|
||
|
def geography_extras(self, field_type):
|
||
|
return self._make_geoextra(field_type)
|
||
|
|
||
|
@for_type('geography', adapt=False)
|
||
|
def _geography(self, value, srid):
|
||
|
return "ST_GeogFromText('SRID=%s;%s')" % (srid, value)
|
||
|
|
||
|
@for_type('jsonb', encode=True)
|
||
|
def _jsonb(self, value):
|
||
|
return serializers.json(value)
|
||
|
|
||
|
|
||
|
@representers.register_for(PostgreNew)
|
||
|
class PostgreArraysRepresenter(PostgreRepresenter):
|
||
|
def _listify_elements(self, elements):
|
||
|
return "{" + ",".join(str(el) for el in elements) + "}"
|