Files
Rasadyar_RSI/app/helper.py
2026-01-18 11:29:19 +03:30

158 lines
5.6 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
import re
import requests
from bs4 import BeautifulSoup
from requests.adapters import HTTPAdapter
from requests.packages.urllib3.util.ssl_ import create_urllib3_context
from django.db.models import Q
from django.views.decorators.csrf import csrf_exempt
from rest_framework import status
from rest_framework.decorators import api_view, permission_classes
from rest_framework.permissions import AllowAny
from rest_framework.response import Response
from app.cityandprovince import correct_province, correct_city, search_city_list, \
search_province_list
from app.models import TransportingDetail, Guilds, AllProductsTransport
from app.serializers import TransportingDetailForUpdateSerializer, AllProductsTransportSerializer
@api_view(["POST"])
@permission_classes([AllowAny])
@csrf_exempt
def get_bar_info(request):
kill_houses = request.data
kill_houses = dict(kill_houses)['kill_house']
bars = AllProductsTransport.objects.filter(trash=False, out=True, jihadi_destination__in=kill_houses,
unloading='تخلیه شده.',product='مرغ زنده -جهت كشتار',hatching__isnull=False,
date__gte='2025-12-25').order_by('-date')
ser_data = AllProductsTransportSerializer(bars, many=True).data
return Response(ser_data, status=status.HTTP_200_OK)
@api_view(["GET"])
@permission_classes([AllowAny])
@csrf_exempt
def test_city(request):
excluded_provinces = search_province_list
excluded_city = search_city_list
# hatchings = Hatching.objects.filter(
# ~Q(ProvinceName__in=excluded_provinces) | ~Q(CityName__in=excluded_city)
# )
transport = TransportingDetail.objects.filter(
~Q(Province__in=excluded_provinces) | ~Q(City__in=excluded_city)).only('Province', 'City')
# hatchings = Hatching.objects.filter(
# Q(ProvinceName__contains='<27>') | Q( CityName__contains='<27>')
# )
l = 1
for t in transport:
print(l)
if t.Province not in excluded_provinces:
t.Province = correct_province(t.Province)
t.save()
if t.City not in excluded_city:
t.CityName = correct_city(t.City, t.Province)
t.save()
l += 1
# if hatching:
return Response('lo')
class SSLAdapter(HTTPAdapter):
def __init__(self, *args, **kwargs):
self.context = create_urllib3_context()
self.context.options |= 0x4 # OP_LEGACY_SERVER_CONNECT
super().__init__(*args, **kwargs)
def init_poolmanager(self, *args, **kwargs):
kwargs['ssl_context'] = self.context
return super().init_poolmanager(*args, **kwargs)
def build_response(self, req, resp):
resp = super().build_response(req, resp)
return resp
def check_quarantine_code(lst):
result_code = []
for code in lst:
session = requests.Session()
session.mount('https://', SSLAdapter())
data = {'gid': str(code)}
m = session.post('https://e.ivo.ir/Rahgiri/Gidprnt.aspx', data=data, verify=False,
headers={
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36'
' (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36'})
context = BeautifulSoup(m.text, 'html.parser')
table = context.find_all('table')
if table[5:6]:
row = context.find('div', align="right")
if row:
content = row.get_text(separator=" ", strip=True)
date_match = re.search(r'تاريخ:(\d{4}/\d{2}/\d{2})', content)
if date_match:
for i in table[5:6]:
row = i.find_all('tr')
for r in row[1:2]:
quantity = r.find('td')
match = re.search(r'\d+', quantity.text)
if match:
result_code.append(code)
return result_code
def get_hatching_permit_code(code):
result = {}
session = requests.Session()
session.mount('https://', SSLAdapter())
data = {'gid': str(code)}
m = session.post(
'https://e.ivo.ir/Rahgiri/Gidprnt.aspx',
data=data,
verify=False,
headers={
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36'
' (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36'
},
timeout=20,
)
text = m.text
permit = None
match = re.search(r'کد\s*مجوز\s*جوجه\s*ریزی\s*[:]\s*([0-9۰-۹]+)', text)
if match:
raw_permit = match.group(1)
trans = str.maketrans('۰۱۲۳۴۵۶۷۸۹', '0123456789')
permit = raw_permit.translate(trans)
if permit:
result[str(code)] = permit
return result
@api_view(["GET"])
@permission_classes([AllowAny])
@csrf_exempt
def api_get_hatching_permit_code(request):
code = request.GET.get('code')
if not code:
return Response({'detail': 'code query param is required'}, status=status.HTTP_400_BAD_REQUEST)
try:
data = get_hatching_permit_code(code)
return Response(data, status=status.HTTP_200_OK)
except Exception as e:
return Response({'detail': str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
def create_guild(**info):
Guilds(
)
class SSLAdapter(HTTPAdapter):
def __init__(self, *args, **kwargs):
self.context = create_urllib3_context()
self.context.options |= 0x4 # OP_LEGACY_SERVER_CONNECT
super().__init__(*args, **kwargs)