Skip to content

Commit

Permalink
Order support offset and limit (#228)
Browse files Browse the repository at this point in the history
* Order support offset and limit

* Increase default postgres connections
  • Loading branch information
piyushroshan authored Jan 10, 2024
1 parent 4c8655e commit 1bfdba9
Show file tree
Hide file tree
Showing 12 changed files with 89 additions and 32 deletions.
1 change: 1 addition & 0 deletions deploy/docker/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,7 @@ services:
postgresdb:
container_name: postgresdb
image: 'postgres:14'
command: ["postgres", "-c", "max_connections=500"]
environment:
POSTGRES_USER: admin
POSTGRES_PASSWORD: crapisecretpassword
Expand Down
3 changes: 2 additions & 1 deletion deploy/helm/templates/postgres/statefulset.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,13 @@ spec:
- name: {{ .Values.postgresdb.name }}
image: {{ .Values.postgresdb.image }}:{{ .Values.postgresdb.version }}
imagePullPolicy: {{ .Values.postgresdb.imagePullPolicy }}
args: ["-c", "max_connections=500"]
ports:
- containerPort: {{ .Values.postgresdb.port }}
envFrom:
- configMapRef:
name: {{ .Values.postgresdb.config.name }}

volumeMounts:
- mountPath: /var/lib/postgresql/data
name: postgres-data
Expand Down
3 changes: 2 additions & 1 deletion deploy/k8s/base/postgres/statefulset.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,14 @@ spec:
containers:
- name: postgres
image: postgres:14
args: ["-c", "max_connections=500"]
imagePullPolicy: "IfNotPresent"
ports:
- containerPort: 5432
envFrom:
- configMapRef:
name: postgres-config

volumeMounts:
- mountPath: /var/lib/postgresql/data
name: postgres-data
Expand Down
19 changes: 19 additions & 0 deletions openapi-spec/openapi-spec.json
Original file line number Diff line number Diff line change
Expand Up @@ -1944,6 +1944,25 @@
"security" : [ {
"bearerAuth" : [ ]
} ],
"parameters" : [ {
"name" : "limit",
"in" : "query",
"required" : true,
"schema" : {
"type" : "integer",
"format" : "int32",
"example" : 30
}
}, {
"name" : "offset",
"in" : "query",
"required" : true,
"schema" : {
"type" : "integer",
"format" : "int32",
"example" : 0
}
} ],
"responses" : {
"200" : {
"content" : {
Expand Down
12 changes: 11 additions & 1 deletion postman_collections/crAPI.postman_collection.json
Original file line number Diff line number Diff line change
Expand Up @@ -2421,7 +2421,7 @@
}
],
"url": {
"raw": "{{url}}/workshop/api/shop/orders/all",
"raw": "{{url}}/workshop/api/shop/orders/all?limit=30&offset=0",
"host": [
"{{url}}"
],
Expand All @@ -2431,6 +2431,16 @@
"shop",
"orders",
"all"
],
"query": [
{
"key": "limit",
"value": "30"
},
{
"key": "offset",
"value": "0"
}
]
}
},
Expand Down
3 changes: 3 additions & 0 deletions services/identity/src/main/resources/application.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ logging.level.org.springframework.web=DEBUG
spring.datasource.url= jdbc:postgresql://${DB_HOST}:${DB_PORT}/${DB_NAME}
spring.datasource.username=${DB_USER}
spring.datasource.password=${DB_PASSWORD}
spring.datasource.max-active=100
spring.datasource.max-idle=8
spring.datasource.min-idle=8

spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.PostgreSQLDialect
Expand Down
14 changes: 6 additions & 8 deletions services/workshop/crapi/mechanic/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,13 @@
from rest_framework.response import Response
from rest_framework.views import APIView
from django.db import models
from crapi_site import settings
from utils.jwt import jwt_auth_required
from utils import messages
from crapi.user.models import User, Vehicle, UserDetails
from utils.logging import log_error
from .models import Mechanic, ServiceRequest
from .serializers import MechanicSerializer, ServiceRequestSerializer, ReceiveReportSerializer, SignUpSerializer
DEFAULT_LIMIT = 10
DEFAULT_OFFSET = 0
MAX_LIMIT = 100

class SignUpView(APIView):
"""
Expand Down Expand Up @@ -206,21 +204,21 @@ def get(self, request, user=None):
list of service request object and 200 status if no error
message and corresponding status if error
"""
limit = request.GET.get('limit', str(DEFAULT_LIMIT))
offset = request.GET.get('offset', str(DEFAULT_OFFSET))
limit = request.GET.get('limit', str(settings.DEFAULT_LIMIT))
offset = request.GET.get('offset', str(settings.DEFAULT_OFFSET))
if not limit.isdigit() or not offset.isdigit():
return Response(
{'message': messages.INVALID_LIMIT_OR_OFFSET},
status=status.HTTP_400_BAD_REQUEST
)
limit = int(limit)
offset = int(offset)
if limit > MAX_LIMIT:
if limit > settings.MAX_LIMIT:
limit = 100
if limit < 0:
limit = DEFAULT_LIMIT
limit = settings.DEFAULT_LIMIT
if offset < 0:
offset = DEFAULT_OFFSET
offset = settings.DEFAULT_OFFSET
service_requests = ServiceRequest.objects.filter(mechanic__user=user).order_by('id')[offset:offset+limit]
serializer = ServiceRequestSerializer(service_requests, many=True)
response_data = dict(
Expand Down
38 changes: 30 additions & 8 deletions services/workshop/crapi/shop/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,22 @@ def get(self, request, user=None):
list of order object and 200 status if no error
message and corresponding status if error
"""
orders = Order.objects.filter(user=user)
limit = request.GET.get('limit', str(settings.DEFAULT_LIMIT))
offset = request.GET.get('offset', str(settings.DEFAULT_OFFSET))
if not limit.isdigit() or not offset.isdigit():
return Response(
{'message': messages.INVALID_LIMIT_OR_OFFSET},
status=status.HTTP_400_BAD_REQUEST
)
limit = int(limit)
offset = int(offset)
if limit > settings.MAX_LIMIT:
limit = 100
if limit < 0:
limit = settings.DEFAULT_LIMIT
if offset < 0:
offset = settings.DEFAULT_OFFSET
orders = Order.objects.filter(user=user).order_by('-id')[offset:offset+limit]
serializer = OrderSerializer(orders, many=True)
response_data = dict(
orders=serializer.data
Expand Down Expand Up @@ -329,14 +344,21 @@ def post(self, request, user=None):
if not serializer.is_valid():
log_error(request.path, request.data, 400, serializer.errors)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)

row = None
with connection.cursor() as cursor:
cursor.execute("SELECT coupon_code from applied_coupon WHERE user_id = "\
+ str(user.id)\
+ " AND coupon_code = '"\
+ coupon_request_body['coupon_code']\
+ "'")
row = cursor.fetchall()
try:
cursor.execute("SELECT coupon_code from applied_coupon WHERE user_id = "\
+ str(user.id)\
+ " AND coupon_code = '"\
+ coupon_request_body['coupon_code']\
+ "'")
row = cursor.fetchall()
except Exception as e:
log_error(request.path, request.data, 500, e)
return Response(
{'message': e},
status=status.HTTP_500_INTERNAL_SERVER_ERROR
)

if row and row != None:
return Response(
Expand Down
20 changes: 9 additions & 11 deletions services/workshop/crapi/user/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,14 +23,12 @@
from rest_framework.views import APIView
from crapi.user.serializers import UserDetailsSerializer
from crapi.user.models import User, UserDetails
from crapi_site import settings
from utils.jwt import jwt_auth_required
from utils import messages
from utils.logging import log_error

logger = logging.getLogger()
DEFAULT_LIMIT = 30
DEFAULT_OFFSET = 0
MAX_LIMIT = 100

class AdminUserView(APIView):
"""
Expand All @@ -49,21 +47,21 @@ def get(self, request, user=None):
user details and 200 status if no error
message and corresponding status if error
"""
limit = request.GET.get('limit', str(DEFAULT_LIMIT))
offset = request.GET.get('offset', str(DEFAULT_OFFSET))
limit = request.GET.get('limit', str(settings.DEFAULT_LIMIT))
offset = request.GET.get('offset', str(settings.DEFAULT_OFFSET))
if not limit.isdigit() or not offset.isdigit():
return Response(
{'message': messages.INVALID_LIMIT_OFFSET},
{'message': messages.INVALID_LIMIT_OR_OFFSET},
status=status.HTTP_400_BAD_REQUEST
)
limit = int(limit)
offset = int(offset)
if limit > MAX_LIMIT:
limit = MAX_LIMIT
if int(limit) < 0:
limit = DEFAULT_LIMIT
if limit > settings.MAX_LIMIT:
limit = 100
if limit < 0:
limit = settings.DEFAULT_LIMIT
if offset < 0:
offset = DEFAULT_OFFSET
offset = settings.DEFAULT_OFFSET
# Sort by id
userdetails = UserDetails.objects.all().order_by('id')[offset:offset+limit]
if not userdetails:
Expand Down
4 changes: 4 additions & 0 deletions services/workshop/crapi_site/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,9 @@

from django.core.exceptions import ImproperlyConfigured

DEFAULT_LIMIT = 10
DEFAULT_OFFSET = 0
MAX_LIMIT = 100

def get_env_value(env_variable):
try:
Expand Down Expand Up @@ -173,6 +176,7 @@ def get_env_value(env_variable):
'NAME': 'test_crapi',
'USER': get_env_value('DB_USER'),
},
'CONN_MAX_AGE': 60,
},
'mongodb': {
'ENGINE': 'djongo',
Expand Down
2 changes: 1 addition & 1 deletion services/workshop/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ django-health-check==3.17.0
djangorestframework==3.14.0
django-sslserver==0.22
djongo==1.3.6
psycopg2==2.9.6
psycopg2==2.9.9
PyJWT==2.7.0
pymongo==3.12.3
pyOpenSSL==23.1.1
Expand Down
2 changes: 1 addition & 1 deletion services/workshop/utils/messages.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,5 +41,5 @@
INVALID_REPORT_ID = "Please enter a valid report_id value."
REPORT_DOES_NOT_EXIST = "The Report does not exist for given report_id."
COULD_NOT_CONNECT = "Could not connect to mechanic api."
INVALID_LIMIT_OFFSET = "Param limit and offset values should be integers."
INVALID_LIMIT_OR_OFFSET = "Param limit and offset values should be integers."
NO_USER_DETAILS = "No user details found."

0 comments on commit 1bfdba9

Please sign in to comment.