123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- from django.conf import settings
- from django.db import transaction
- from django.shortcuts import render
- from django_logit import logit
- from django_response import response
- from json_render import json_render
- from mch.models import BrandInfo, DistributorInfo, SaleclerkInfo
- from utils.error.errno_utils import ProductBrandStatusCode, ProductDistributorStatusCode, SaleclerkStatusCode
- from utils.redis.connect import r
- def login_qrcode(request):
- lensman_type = int(request.GET.get('lt') or 0)
- unionid = request.GET.get('unionid', '')
- data = {
- 'lensman_type': lensman_type,
- 'unionid': unionid,
- 'token': r.token(unionid)
- }
- return json_render(request, 'page/login_qrcode.html', data)
- def clerk_oauth(request):
- brand_id = request.GET.get('brand_id') or settings.KODO_DEFAULT_BRAND_ID
- unionid = request.GET.get('unionid', '')
- try:
- BrandInfo.objects.get(brand_id=brand_id, status=True)
- except BrandInfo.DoesNotExist:
- return response(ProductBrandStatusCode.BRAND_NOT_FOUND)
- distributors = DistributorInfo.objects.filter(brand_id=brand_id, status=True)
- distributors = [distributor.admindata for distributor in distributors]
- try:
- clerk = SaleclerkInfo.objects.get(brand_id=brand_id, unionid=unionid, status=True)
- except SaleclerkInfo.DoesNotExist:
- clerk = None
- return render(request, 'page/clerk_oauth.html', {
- 'domain': settings.DOMAIN,
- 'distributors': distributors,
- 'clerk_info': clerk and clerk.data,
- 'modified': bool((not clerk) or (clerk and clerk.user_status in [SaleclerkInfo.UNVERIFIED, SaleclerkInfo.REFUSED])),
- })
- @logit
- @transaction.atomic
- def clerk_submit_api(request):
- """ 店员授权信息提交 """
- brand_id = request.POST.get('brand_id') or settings.KODO_DEFAULT_BRAND_ID
- distributor_id = request.POST.get('distributor_id', '')
- unionid = request.POST.get('unionid', '')
- openid = request.POST.get('openid', '')
- phone = request.POST.get('phone', '')
- if SaleclerkInfo.objects.filter(clerk_phone=phone).exclude(unionid=unionid).exists():
- return response(SaleclerkStatusCode.CLERK_PHONE_ALREADY_EXISTS)
- try:
- distributor = DistributorInfo.objects.get(distributor_id=distributor_id)
- except DistributorInfo.DoesNotExist:
- return response(ProductDistributorStatusCode.DISTRIBUTOR_NOT_FOUND)
- fields = {
- 'distributor_id': distributor_id,
- 'distributor_name': distributor.distributor_name,
- 'clerk_name': request.POST.get('name', ''),
- 'clerk_sex': int(request.POST.get('sex', 1)),
- 'clerk_phone': phone,
- 'openid': openid,
- 'user_status': SaleclerkInfo.UNVERIFIED,
- }
- clerk, created = SaleclerkInfo.objects.select_for_update().get_or_create(brand_id=brand_id, unionid=unionid, defaults=fields)
-
- clerk.status = True
-
- if clerk.user_status not in [SaleclerkInfo.UNVERIFIED, SaleclerkInfo.REFUSED]:
- return response(SaleclerkStatusCode.CLERK_ALREADY_NOT_UNVERIFIED)
- if not created:
- for key, value in fields.items():
- setattr(clerk, key, value)
- clerk.save()
- return response(200, 'Submit Success', u'提交成功', {})
|