From 705f47184b91697eeb73b3e6e29ef6d616ecc608 Mon Sep 17 00:00:00 2001 From: Walter Lorenzetti Date: Mon, 12 Feb 2024 11:15:08 +0100 Subject: [PATCH] Get REST API parameters from HTTP GET of POST. (#751) Co-authored-by: wlorenzetti --- g3w-admin/core/api/base/views.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/g3w-admin/core/api/base/views.py b/g3w-admin/core/api/base/views.py index c38624b51..605e584af 100644 --- a/g3w-admin/core/api/base/views.py +++ b/g3w-admin/core/api/base/views.py @@ -484,7 +484,8 @@ def response_data_mode(self, request, export_features=False): # -------------------------------------- # IDEA: for big data it'll be iterate over features to get unique # c++ iteration is fast. Instead memory layer with too many features can be a problem. - if 'unique' in request.query_params: + if 'unique' in self.request_data: + vl = QgsVectorLayer(QgsWkbTypes.displayString(self.metadata_layer.qgis_layer.wkbType()), "temporary_vector", "memory") @@ -498,7 +499,7 @@ def response_data_mode(self, request, export_features=False): uniques = vl.uniqueValues( self.metadata_layer.qgis_layer.fields().indexOf( - request.query_params.get('unique')) + self.request_data.get('unique')) ) values = [] @@ -642,6 +643,9 @@ def get_response(self, request, mode_call=None, project_type=None, layer_id=None # set reprojecting status self.set_reprojecting_status() + # Get request data by GET or POST method + self.request_data = request.query_params if request.method == 'GET' else request.data + # get results response = self.get_response_data(request)