first base of project-changed apps: Herd-livestock-tag-log-elasticsearch-

This commit is contained in:
2025-05-24 15:01:55 +03:30
parent eab40af15d
commit 90a46e493c
129 changed files with 3844 additions and 187 deletions

View File

@@ -0,0 +1,32 @@
# Generated by Django 4.2.20 on 2025-05-13 06:31
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('authentication', '0010_organization_company_code_and_more'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('herd', '0001_initial'),
]
operations = [
migrations.AddField(
model_name='herd',
name='city',
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='herd_city', to='authentication.city'),
),
migrations.AddField(
model_name='herd',
name='owner',
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='herd', to=settings.AUTH_USER_MODEL),
),
migrations.AddField(
model_name='herd',
name='province',
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='herd_province', to='authentication.province'),
),
]

View File

@@ -0,0 +1,21 @@
# Generated by Django 4.2.20 on 2025-05-17 06:01
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('herd', '0002_herd_city_herd_owner_herd_province'),
]
operations = [
migrations.RemoveField(
model_name='herd',
name='created_by',
),
migrations.RemoveField(
model_name='herd',
name='modified_by',
),
]

View File

@@ -0,0 +1,23 @@
# Generated by Django 4.2.20 on 2025-05-17 06:24
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('herd', '0003_remove_herd_created_by_remove_herd_modified_by'),
]
operations = [
migrations.AddField(
model_name='herd',
name='created_by',
field=models.CharField(max_length=50, null=True),
),
migrations.AddField(
model_name='herd',
name='modified_by',
field=models.CharField(max_length=50, null=True),
),
]

View File

@@ -0,0 +1,21 @@
# Generated by Django 4.2.20 on 2025-05-17 06:27
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('herd', '0004_herd_created_by_herd_modified_by'),
]
operations = [
migrations.RemoveField(
model_name='herd',
name='created_by',
),
migrations.RemoveField(
model_name='herd',
name='modified_by',
),
]

View File

@@ -0,0 +1,26 @@
# Generated by Django 4.2.20 on 2025-05-17 06:29
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('herd', '0005_remove_herd_created_by_remove_herd_modified_by'),
]
operations = [
migrations.AddField(
model_name='herd',
name='created_by',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='%(class)s_createddby', to=settings.AUTH_USER_MODEL),
),
migrations.AddField(
model_name='herd',
name='modified_by',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='%(class)s_modifiedby', to=settings.AUTH_USER_MODEL),
),
]

View File

@@ -0,0 +1,23 @@
# Generated by Django 4.2.20 on 2025-05-17 06:35
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('herd', '0006_herd_created_by_herd_modified_by'),
]
operations = [
migrations.AddField(
model_name='herd',
name='creator_info',
field=models.CharField(max_length=100, null=True),
),
migrations.AddField(
model_name='herd',
name='modifier_info',
field=models.CharField(max_length=100, null=True),
),
]

View File

@@ -0,0 +1,40 @@
# Generated by Django 5.0 on 2025-05-19 08:14
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('authentication', '0017_bankaccountinformation_creator_info_and_more'),
('herd', '0007_herd_creator_info_herd_modifier_info'),
]
operations = [
migrations.AddField(
model_name='herd',
name='cooperative',
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='herd', to='authentication.organization'),
),
migrations.AddField(
model_name='herd',
name='heavy_livestock_number',
field=models.BigIntegerField(default=0),
),
migrations.AddField(
model_name='herd',
name='heavy_livestock_quota',
field=models.BigIntegerField(default=0),
),
migrations.AddField(
model_name='herd',
name='light_livestock_number',
field=models.BigIntegerField(default=0),
),
migrations.AddField(
model_name='herd',
name='light_livestock_quota',
field=models.BigIntegerField(default=0),
),
]

View File

@@ -4,9 +4,37 @@ from django.db import models
class Herd(BaseModel):
owner = models.ForeignKey(
auth_models.User,
on_delete=models.CASCADE,
related_name='herd',
null=True
)
cooperative = models.ForeignKey(
auth_models.Organization,
on_delete=models.CASCADE,
related_name='herd',
null=True
)
name = models.CharField(max_length=50)
photo = models.CharField(max_length=50, null=True)
code = models.CharField(max_length=20)
heavy_livestock_number = models.BigIntegerField(default=0)
light_livestock_number = models.BigIntegerField(default=0)
heavy_livestock_quota = models.BigIntegerField(default=0)
light_livestock_quota = models.BigIntegerField(default=0)
province = models.ForeignKey(
auth_models.Province,
on_delete=models.CASCADE,
related_name='herd_province',
null=True
)
city = models.ForeignKey(
auth_models.City,
on_delete=models.CASCADE,
related_name='herd_city',
null=True
)
postal = models.CharField(
max_length=10,
help_text="herd postal code", null=True

View File

@@ -1 +1,3 @@
# Your services go here

View File

@@ -1 +1,8 @@
# Your urls go here
from django.urls import path, include
urlpatterns = [
path('web/', include('apps.herd.web.api.v1.urls'))
]

View File

@@ -0,0 +1,87 @@
from apps.herd.web.api.v1.serializers import HerdSerializer
from apps.authentication.api.v1.api import UserViewSet
from rest_framework.exceptions import APIException
from rest_framework.response import Response
from rest_framework.decorators import action
from common.tools import CustomOperations
from rest_framework import viewsets
from apps.herd.models import Herd
from django.db import transaction
from rest_framework import status
class HerdViewSet(viewsets.ModelViewSet):
""" Herd ViewSet """
queryset = Herd.objects.all()
serializer_class = HerdSerializer
@transaction.atomic
def create(self, request, *args, **kwargs):
""" create herd with user """
if 'user' in request.data.keys():
# create user if owner of herd is not exist
user = CustomOperations().custom_create(
request=request,
view=UserViewSet(),
data_key='user'
)
owner = user['id']
request.data.update({'owner': owner})
serializer = self.serializer_class(data=request.data)
if serializer.is_valid():
serializer.save()
return Response(serializer.data, status=status.HTTP_201_CREATED)
else:
return Response(serializer.errors, status=status.HTTP_403_FORBIDDEN)
@action(
methods=['get'],
detail=False,
url_name='my_herds',
url_path='my_herds',
name='my_herds'
)
@transaction.atomic
def my_herds(self, request):
""" get current user herds """
serializer = self.serializer_class(self.queryset.filter(owner=request.user.id), many=True)
if serializer.data:
return Response(serializer.data, status=status.HTTP_200_OK)
else:
return Response(status=status.HTTP_204_NO_CONTENT)
@action(
methods=['post'],
detail=True,
url_path='trash',
url_name='trash',
name='trash'
)
@transaction.atomic
def trash(self, request, pk=None):
""" Sent herd to trash """
try:
herd = self.queryset.get(id=pk)
herd.trash = True
herd.save()
return Response(status=status.HTTP_200_OK)
except APIException as e:
return Response(e, status=status.HTTP_204_NO_CONTENT)
@action(
methods=['post'],
detail=True,
url_path='delete',
url_name='delete',
name='delete'
)
@transaction.atomic
def delete(self, request, pk=None):
""" full delete of herd """
try:
herd = self.queryset.get(id=pk)
herd.delete()
return Response(status=status.HTTP_200_OK)
except APIException as e:
return Response(e, status=status.HTTP_204_NO_CONTENT)

View File

@@ -0,0 +1,27 @@
from apps.authentication.api.v1.serializers.serializer import (
UserSerializer,
OrganizationSerializer,
ProvinceSerializer,
CitySerializer
)
from rest_framework import serializers
from apps.herd.models import Herd
class HerdSerializer(serializers.ModelSerializer):
""" Herd Serializer """
class Meta:
model = Herd
fields = '__all__'
def to_representation(self, instance):
""" Customize serializer output """
representation = super().to_representation(instance)
if isinstance(instance, Herd):
representation['owner'] = UserSerializer(instance.owner).data
representation['cooperative'] = OrganizationSerializer(instance.cooperative).data
representation['province'] = ProvinceSerializer(instance.province).data
representation['city'] = CitySerializer(instance.city).data
representation['contractor'] = OrganizationSerializer(instance.contractor).data
return representation

View File

@@ -0,0 +1,10 @@
from django.urls import path, include
from rest_framework import routers
from .api import HerdViewSet
router = routers.DefaultRouter()
router.register('herd', HerdViewSet, basename='herd')
urlpatterns = [
path('api/v1/', include(router.urls))
]