From 0e24aa2ccf839bec6135cefab9520ea11d1fb896 Mon Sep 17 00:00:00 2001 From: naegi Date: Sun, 23 Apr 2017 19:54:14 +0200 Subject: [PATCH] add Filter.within to be able to integrate with postGIS' St_DWithin --- opv_api_client/filter.py | 16 ++++++++++++++++ opv_api_client/restclient.py | 2 ++ 2 files changed, 18 insertions(+) diff --git a/opv_api_client/filter.py b/opv_api_client/filter.py index 95fffa7..5c176ce 100644 --- a/opv_api_client/filter.py +++ b/opv_api_client/filter.py @@ -7,6 +7,9 @@ class Filter: To set those values, you can respectively use the `name` and `val`/`value` fonction to set those """ + _url_modifier = 0 + _eq = 1 + def name(self, name): """Allow to set the name's field of the filter @@ -37,11 +40,24 @@ def get(self): Allow to get the final filter, in a form that can directly be used by the API """ + if self._type == self._url_modifier: + return {"_url": self._url} + return {self._name: self._value} + @classmethod + def within(cls, ids, meters): + """Returns a filter that allow to integrate with ST_within""" + f = cls() + + f._type = cls._url_modifier + f._url = "/" + "/".join(map(str, ids)) + "/within/" + str(meters) # should use client._gen_id + return f + def __init__(self, name=None): self._name = name self._value = None + self._type = self._eq __eq__ = value diff --git a/opv_api_client/restclient.py b/opv_api_client/restclient.py index 808980d..523c06e 100644 --- a/opv_api_client/restclient.py +++ b/opv_api_client/restclient.py @@ -219,6 +219,8 @@ def make_all(self, ressource, filters=None): else: params = dict() + url += str(params.pop("_url", "")) + r = requests.get(url, params=params) if r.status_code != 200: raise RequestAPIException("Can't get the list of ressources", response=r)