SP/web2py/gluon/packages/dal/pydal/representers/postgre.py

42 lines
1.3 KiB
Python
Raw Permalink Normal View History

2018-10-25 15:33:07 +00:00
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) + "}"