@@ -1,34 +1,31 @@ |
||
1 | 1 |
# -*- coding: utf-8 -*- |
2 | 2 |
|
3 |
-import logging |
|
4 |
-import requests |
|
5 | 3 |
import json |
4 |
+import logging |
|
6 | 5 |
|
7 |
-from django.core.paginator import Paginator |
|
6 |
+import requests |
|
7 |
+from django.conf import settings |
|
8 | 8 |
from django.contrib.auth.hashers import check_password |
9 |
+from django.core.paginator import Paginator |
|
9 | 10 |
from django.db import transaction |
10 | 11 |
from django.db.models import Q |
11 | 12 |
from django_logit import logit |
12 | 13 |
from django_response import response |
13 |
-from django.core.files import File |
|
14 |
-from TimeConvert import TimeConvert as tc |
|
15 |
-from django.conf import settings |
|
16 |
- |
|
17 | 14 |
from pywe_token import access_token |
18 |
-from pywe_storage import RedisStorage |
|
15 |
+from TimeConvert import TimeConvert as tc |
|
19 | 16 |
|
20 | 17 |
from account.models import AdministratorInfo, UserInfo |
21 | 18 |
from goods.models import GoodsInfo, PackInfo |
22 | 19 |
from kol.models import KOLInfo |
20 |
+from live.models import AnchorInfo, RoomGoodsInfo, RoomInfo, RoomOrderInfo, liveGoodsInfo |
|
23 | 21 |
from pay.models import OrderInfo |
24 |
-from live.models import RoomInfo, RoomGoodsInfo, RoomOrderInfo, AnchorInfo, liveGoodsInfo |
|
25 | 22 |
from utils.error.errno_utils import AdministratorStatusCode, OrderStatusCode |
26 | 23 |
|
27 |
-from utils.redis.connect import r |
|
28 | 24 |
|
29 | 25 |
logger = logging.getLogger('logit') |
30 | 26 |
WECHAT = settings.WECHAT |
31 | 27 |
|
28 |
+ |
|
32 | 29 |
@logit(res=True) |
33 | 30 |
def login(request): |
34 | 31 |
name = request.POST.get('name', '') |
@@ -141,6 +138,7 @@ def order_update(request): |
||
141 | 138 |
|
142 | 139 |
return response(200, 'Order Update Success', '订单更新成功') |
143 | 140 |
|
141 |
+ |
|
144 | 142 |
@logit(res=True) |
145 | 143 |
def live_goods_list(request): |
146 | 144 |
admin_id = request.POST.get('admin_id', '') |
@@ -169,6 +167,7 @@ def live_goods_list(request): |
||
169 | 167 |
'count': count, |
170 | 168 |
}) |
171 | 169 |
|
170 |
+ |
|
172 | 171 |
@logit(res=True) |
173 | 172 |
def live_goods_create(request): |
174 | 173 |
admin_id = request.POST.get('admin_id', '') |
@@ -182,7 +181,6 @@ def live_goods_create(request): |
||
182 | 181 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
183 | 182 |
except AdministratorInfo.DoesNotExist: |
184 | 183 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
185 |
- |
|
186 | 184 |
|
187 | 185 |
wxcfg = WECHAT.get('MINIAPP', {}) |
188 | 186 |
|
@@ -195,7 +193,7 @@ def live_goods_create(request): |
||
195 | 193 |
|
196 | 194 |
if media_id == '': |
197 | 195 |
return response() |
198 |
- |
|
196 |
+ |
|
199 | 197 |
goods_info, _ = liveGoodsInfo.objects.get_or_create( |
200 | 198 |
name=goods_name, |
201 | 199 |
coverImgUrl=media_id, |
@@ -205,7 +203,7 @@ def live_goods_create(request): |
||
205 | 203 |
goods_img=goods_img |
206 | 204 |
) |
207 | 205 |
|
208 |
- data ={ |
|
206 |
+ data = { |
|
209 | 207 |
"goodsInfo": { |
210 | 208 |
'name': goods_name, |
211 | 209 |
'coverImgUrl': media_id, |
@@ -214,7 +212,7 @@ def live_goods_create(request): |
||
214 | 212 |
'price2': price2 / 100, |
215 | 213 |
'url': 'pages/live/order/order?goods_id=' + goods_info.goods_id, |
216 | 214 |
} |
217 |
- } |
|
215 |
+ } |
|
218 | 216 |
|
219 | 217 |
wx_goods = requests.post(url=('https://api.weixin.qq.com/wxaapi/broadcast/goods/add?access_token=' + token), json=data).text |
220 | 218 |
wx_goods = json.loads(wx_goods) |
@@ -227,6 +225,7 @@ def live_goods_create(request): |
||
227 | 225 |
'goods': goods_info.admindata, |
228 | 226 |
}) |
229 | 227 |
|
228 |
+ |
|
230 | 229 |
@logit(res=True) |
231 | 230 |
def live_goods_update(request): |
232 | 231 |
admin_id = request.POST.get('admin_id', '') |
@@ -239,7 +238,6 @@ def live_goods_update(request): |
||
239 | 238 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
240 | 239 |
except AdministratorInfo.DoesNotExist: |
241 | 240 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
242 |
- |
|
243 | 241 |
|
244 | 242 |
goods_info = liveGoodsInfo.objects.get(goods_id=goods_id, status=True) |
245 | 243 |
|
@@ -255,8 +253,8 @@ def live_goods_update(request): |
||
255 | 253 |
if media_id == '': |
256 | 254 |
return response() |
257 | 255 |
|
258 |
- data ={ |
|
259 |
- "goodsInfo": { |
|
256 |
+ data = { |
|
257 |
+ 'goodsInfo': { |
|
260 | 258 |
'goodsId': goods_info.wx_goods_id, |
261 | 259 |
'name': goods_info.name, |
262 | 260 |
'coverImgUrl': media_id, |
@@ -265,7 +263,7 @@ def live_goods_update(request): |
||
265 | 263 |
'price2': price2 / 100, |
266 | 264 |
'url': 'pages/live/order/order?goods_id=' + goods_id, |
267 | 265 |
} |
268 |
- } |
|
266 |
+ } |
|
269 | 267 |
|
270 | 268 |
wx_goods = requests.post(url=('https://api.weixin.qq.com/wxaapi/broadcast/goods/update?access_token=' + token), json=data).text |
271 | 269 |
errcode = json.loads(wx_goods).get('errcode', -1) |
@@ -278,12 +276,12 @@ def live_goods_update(request): |
||
278 | 276 |
goods_info.price2 = price2 |
279 | 277 |
goods_info.coverImgUrl = media_id |
280 | 278 |
goods_info.save() |
281 |
- |
|
282 | 279 |
|
283 | 280 |
return response(200, 'Live Goods Update Success', u'直播商品库更新成功', data={ |
284 | 281 |
'goods': goods_info.admindata, |
285 | 282 |
}) |
286 | 283 |
|
284 |
+ |
|
287 | 285 |
@logit(res=True) |
288 | 286 |
def live_goods_audit(request): |
289 | 287 |
admin_id = request.POST.get('admin_id', '') |
@@ -291,7 +289,6 @@ def live_goods_audit(request): |
||
291 | 289 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
292 | 290 |
except AdministratorInfo.DoesNotExist: |
293 | 291 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
294 |
- |
|
295 | 292 |
|
296 | 293 |
wxcfg = WECHAT.get('MINIAPP', {}) |
297 | 294 |
|
@@ -312,9 +309,8 @@ def live_goods_audit(request): |
||
312 | 309 |
g = liveGoodsInfo.objects.get(wx_goods_id=goods.get('goods_id', ''), status=True) |
313 | 310 |
g.audit_status = goods.get('audit_status', 0) |
314 | 311 |
g.save() |
315 |
- |
|
316 |
- return response(200, 'Live Goods Audit Success', '获取直播商品库审核状态成功') |
|
317 | 312 |
|
313 |
+ return response(200, 'Live Goods Audit Success', '获取直播商品库审核状态成功') |
|
318 | 314 |
|
319 | 315 |
|
320 | 316 |
@logit(res=True) |
@@ -322,11 +318,11 @@ def live_goods_delete(request): |
||
322 | 318 |
admin_id = request.POST.get('admin_id', '') |
323 | 319 |
goods_id = request.POST.get('goods_id', '') |
324 | 320 |
wx_goods_id = request.POST.get('wx_goods_id', '') |
321 |
+ |
|
325 | 322 |
try: |
326 | 323 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
327 | 324 |
except AdministratorInfo.DoesNotExist: |
328 | 325 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
329 |
- |
|
330 | 326 |
|
331 | 327 |
wxcfg = WECHAT.get('MINIAPP', {}) |
332 | 328 |
|
@@ -334,18 +330,15 @@ def live_goods_delete(request): |
||
334 | 330 |
secret = wxcfg.get('appsecret') |
335 | 331 |
token = access_token(appid, secret) |
336 | 332 |
|
337 |
- status = requests.post(url=('https://api.weixin.qq.com/wxaapi/broadcast/goods/delete?access_token=' + token), json={ 'goodsId': wx_goods_id}).text |
|
333 |
+ status = requests.post(url=('https://api.weixin.qq.com/wxaapi/broadcast/goods/delete?access_token=' + token), json={'goodsId': wx_goods_id}).text |
|
338 | 334 |
errcode = json.loads(status).get('errcode', -1) |
339 | 335 |
|
340 | 336 |
if errcode != 0: |
341 | 337 |
return response() |
342 |
- |
|
343 |
- try: |
|
344 |
- liveGoodsInfo.objects.filter(goods_id=goods_id, status=True).update(status=False) |
|
345 |
- except: |
|
346 |
- return response() |
|
347 |
- |
|
348 |
- return response(200, 'Live Goods Delete Success', '直播商品库删除成功') |
|
338 |
+ |
|
339 |
+ liveGoodsInfo.objects.filter(goods_id=goods_id, status=True).update(status=False) |
|
340 |
+ |
|
341 |
+ return response(200, 'Live Goods Delete Success', '直播商品库删除成功') |
|
349 | 342 |
|
350 | 343 |
|
351 | 344 |
@logit(res=True) |
@@ -373,6 +366,7 @@ def live_room_list(request): |
||
373 | 366 |
'count': count, |
374 | 367 |
}) |
375 | 368 |
|
369 |
+ |
|
376 | 370 |
@logit(res=True) |
377 | 371 |
def live_order_list(request): |
378 | 372 |
admin_id = request.POST.get('admin_id', '') |
@@ -386,11 +380,11 @@ def live_order_list(request): |
||
386 | 380 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
387 | 381 |
except AdministratorInfo.DoesNotExist: |
388 | 382 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
389 |
- |
|
383 |
+ |
|
390 | 384 |
orders = RoomOrderInfo.objects.filter(Q(name__contains=query) | Q(phone__contains=query)).order_by('-created_at') |
391 | 385 |
if pay_status: |
392 | 386 |
orders = orders.filter(pay_status=pay_status) |
393 |
- |
|
387 |
+ |
|
394 | 388 |
if goods_name: |
395 | 389 |
goods_infos = liveGoodsInfo.objects.filter(goods_name__contains=goods_name) |
396 | 390 |
goods_infos = [info.goods_id for info in goods_infos] |
@@ -405,12 +399,13 @@ def live_order_list(request): |
||
405 | 399 |
'count': count, |
406 | 400 |
}) |
407 | 401 |
|
402 |
+ |
|
408 | 403 |
@logit(res=True) |
409 | 404 |
def live_order_delivery(request): |
410 | 405 |
admin_id = request.POST.get('admin_id', '') |
411 | 406 |
order_id = request.POST.get('order_id', '') |
412 | 407 |
user_id = request.POST.get('user_id', '') |
413 |
- |
|
408 |
+ |
|
414 | 409 |
delivery_id = request.POST.get('delivery_id', '') |
415 | 410 |
biz_id = request.POST.get('biz_id', '') |
416 | 411 |
|
@@ -418,13 +413,13 @@ def live_order_delivery(request): |
||
418 | 413 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
419 | 414 |
except AdministratorInfo.DoesNotExist: |
420 | 415 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
421 |
- |
|
416 |
+ |
|
422 | 417 |
user = UserInfo.objects.get(user_id=user_id, status=True) |
423 | 418 |
|
424 | 419 |
order = RoomOrderInfo.objects.get(order_id=order_id, status=True) |
425 | 420 |
|
426 | 421 |
goods = liveGoodsInfo.objects.get(goods_id=order.goods_id, status=True) |
427 |
- |
|
422 |
+ |
|
428 | 423 |
wxcfg = WECHAT.get('MINIAPP', {}) |
429 | 424 |
|
430 | 425 |
appid = wxcfg.get('appID') |
@@ -462,13 +457,15 @@ def live_order_delivery(request): |
||
462 | 457 |
'spaceX': 10, |
463 | 458 |
'spaceY': 10, |
464 | 459 |
'spaceZ': 10, |
465 |
- 'detail_list': [{ |
|
466 |
- 'name': goods.name, |
|
467 |
- 'count': order.amount, |
|
468 |
- }] |
|
460 |
+ 'detail_list': [ |
|
461 |
+ { |
|
462 |
+ 'name': goods.name, |
|
463 |
+ 'count': order.amount, |
|
464 |
+ } |
|
465 |
+ ] |
|
469 | 466 |
}, |
470 | 467 |
'shop': { |
471 |
- 'wxa_path': 'pages/live/anchorHome/anchorHome?anchor_id='+order.anchor_id, |
|
468 |
+ 'wxa_path': 'pages/live/anchorHome/anchorHome?anchor_id=' + order.anchor_id, |
|
472 | 469 |
'img_url': goods.goods_img_url, |
473 | 470 |
'goods_name': goods.name, |
474 | 471 |
'goods_count': order.amount, |
@@ -493,14 +490,15 @@ def live_order_delivery(request): |
||
493 | 490 |
deliveryResultcode = res.get('delivery_resultcode', '') |
494 | 491 |
deliveryResultmsg = res.get('delivery_resultmsg', '') |
495 | 492 |
return response(errCode, errMsg, str(deliveryResultcode) + ':' + deliveryResultmsg) |
496 |
- |
|
493 |
+ |
|
497 | 494 |
order.tracking_number = res.get('waybill_id', '') |
498 | 495 |
order.save() |
499 |
- |
|
496 |
+ |
|
500 | 497 |
return response(200, 'Live Order Delivery Success', '直播订单下单成功', data={ |
501 | 498 |
'order': order.admindata |
502 | 499 |
}) |
503 | 500 |
|
501 |
+ |
|
504 | 502 |
@logit(res=True) |
505 | 503 |
def fetch_wx_room_list(request): |
506 | 504 |
admin_id = request.POST.get('admin_id', '') |
@@ -508,7 +506,6 @@ def fetch_wx_room_list(request): |
||
508 | 506 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
509 | 507 |
except AdministratorInfo.DoesNotExist: |
510 | 508 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
511 |
- |
|
512 | 509 |
|
513 | 510 |
wxcfg = WECHAT.get('MINIAPP', {}) |
514 | 511 |
|
@@ -521,7 +518,7 @@ def fetch_wx_room_list(request): |
||
521 | 518 |
if rooms.count() != 0: |
522 | 519 |
start = int(rooms[0].room_id) - 1 |
523 | 520 |
|
524 |
- roominfos = requests.post(url=('http://api.weixin.qq.com/wxa/business/getliveinfo?access_token='+token), json={'start': 0, 'limit': 99}) |
|
521 |
+ roominfos = requests.post(url=('http://api.weixin.qq.com/wxa/business/getliveinfo?access_token=' + token), json={'start': 0, 'limit': 99}) |
|
525 | 522 |
|
526 | 523 |
roominfos = json.loads(roominfos.text).get('room_info', {}) |
527 | 524 |
for roominfo in roominfos: |
@@ -540,9 +537,10 @@ def fetch_wx_room_list(request): |
||
540 | 537 |
room.anchor_name = roominfo.get('anchor_name', '') |
541 | 538 |
room.anchor_id = anchor.anchor_id |
542 | 539 |
room.save() |
543 |
- |
|
540 |
+ |
|
544 | 541 |
return response(200, 'Fetch wx Room List Success', u'微信直播间列表获取成功') |
545 | 542 |
|
543 |
+ |
|
546 | 544 |
@logit(res=True) |
547 | 545 |
def room_goods_list(request): |
548 | 546 |
admin_id = request.POST.get('admin_id', '') |
@@ -554,7 +552,7 @@ def room_goods_list(request): |
||
554 | 552 |
administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True) |
555 | 553 |
except AdministratorInfo.DoesNotExist: |
556 | 554 |
return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND) |
557 |
- |
|
555 |
+ |
|
558 | 556 |
goods_list = RoomGoodsInfo.objects.filter(status=True).order_by('-created_at') |
559 | 557 |
|
560 | 558 |
if room_id: |
@@ -569,6 +567,7 @@ def room_goods_list(request): |
||
569 | 567 |
'count': count, |
570 | 568 |
}) |
571 | 569 |
|
570 |
+ |
|
572 | 571 |
def room_goods_add(request): |
573 | 572 |
admin_id = request.POST.get('admin_id', '') |
574 | 573 |
room_id = request.POST.get('room_id', '') |
@@ -591,6 +590,7 @@ def room_goods_add(request): |
||
591 | 590 |
|
592 | 591 |
return response(200, 'Room Goods Add Success', u'直播间商品库添加成功') |
593 | 592 |
|
593 |
+ |
|
594 | 594 |
def room_goods_publish(request): |
595 | 595 |
admin_id = request.POST.get('admin_id', '') |
596 | 596 |
room_id = request.POST.get('room_id', '') |
@@ -606,17 +606,18 @@ def room_goods_publish(request): |
||
606 | 606 |
secret = wxcfg.get('appsecret') |
607 | 607 |
token = access_token(appid, secret) |
608 | 608 |
|
609 |
- status = requests.post(url=('https://api.weixin.qq.com/wxaapi/broadcast/room/addgoods?access_token=' + token), json={ 'ids': [goods.wx_goods_id], 'roomId': room_id}).text |
|
609 |
+ status = requests.post(url=('https://api.weixin.qq.com/wxaapi/broadcast/room/addgoods?access_token=' + token), json={'ids': [goods.wx_goods_id], 'roomId': room_id}).text |
|
610 | 610 |
errcode = json.loads(status).get('errcode', -1) |
611 | 611 |
|
612 | 612 |
if errcode != 0: |
613 | 613 |
return response(errcode, 'Room Goods Publish Fail', '直播间商品发布失败') |
614 |
- |
|
614 |
+ |
|
615 | 615 |
room_goods.goods_status = RoomGoodsInfo.PUBLISH |
616 | 616 |
room_goods.save() |
617 | 617 |
|
618 | 618 |
return response(200, 'Room Goods Publish Success', '直播间商品上架成功') |
619 | 619 |
|
620 |
+ |
|
620 | 621 |
def room_goods_off(request): |
621 | 622 |
admin_id = request.POST.get('admin_id', '') |
622 | 623 |
room_id = request.POST.get('room_id', '') |
@@ -629,6 +630,7 @@ def room_goods_off(request): |
||
629 | 630 |
|
630 | 631 |
return response(200, 'Room Goods Off Success', '直播间商品下架成功') |
631 | 632 |
|
633 |
+ |
|
632 | 634 |
def room_goods_update(request): |
633 | 635 |
admin_id = request.POST.get('admin_id', '') |
634 | 636 |
room_id = request.POST.get('room_id', '') |
@@ -64,6 +64,7 @@ def mini_login_api(request): |
||
64 | 64 |
|
65 | 65 |
return response(data=user.data) |
66 | 66 |
|
67 |
+ |
|
67 | 68 |
@logit(res=True) |
68 | 69 |
@transaction.atomic |
69 | 70 |
def mini_live_login_api(request): |
@@ -112,7 +113,6 @@ def mini_live_login_api(request): |
||
112 | 113 |
# Store SessionKey |
113 | 114 |
store_session_key(appid=appid, secret=secret, session_key=session_key, unid=user.user_id, storage=RedisStorage(r)) |
114 | 115 |
|
115 |
- |
|
116 | 116 |
# Update live |
117 | 117 |
room = RoomInfo.objects.get(room_id=room_id) |
118 | 118 |
is_new = not RoomUserInfo.objects.filter(user_id=user.user_id).exists() |
@@ -129,7 +129,6 @@ def mini_live_login_api(request): |
||
129 | 129 |
room_user.is_new = is_new |
130 | 130 |
room_user.save() |
131 | 131 |
|
132 |
- |
|
133 | 132 |
return response(data=user.data) |
134 | 133 |
|
135 | 134 |
|
@@ -4,8 +4,8 @@ from django.conf.urls import url |
||
4 | 4 |
from django_file_upload import views as file_views |
5 | 5 |
|
6 | 6 |
from api import admin_views, mini_views, oauth_views, pack_views |
7 |
-from pay import views as pay_views |
|
8 | 7 |
from live import views as live_views |
8 |
+from pay import views as pay_views |
|
9 | 9 |
|
10 | 10 |
|
11 | 11 |
urlpatterns = [ |
@@ -23,7 +23,7 @@ urlpatterns += [ |
||
23 | 23 |
url(r'^pay/wx/notify_url$', pay_views.wx_notify_url_api, name='wx_notify_url_api'), # 支付异步通知回调地址 |
24 | 24 |
] |
25 | 25 |
|
26 |
-#直播相关 |
|
26 |
+# 直播相关 |
|
27 | 27 |
urlpatterns += [ |
28 | 28 |
url(r'^live/anchor/detail$', live_views.anchor_detail, name='anchor_detail'), # 微信直播间列表 |
29 | 29 |
url(r'^live/goods/detail$', live_views.room_goods_detail, name='room_goods_detail'), |
@@ -55,15 +55,15 @@ urlpatterns += [ |
||
55 | 55 |
url(r'^admin/live/room/list$', admin_views.live_room_list, name='live_room_list'), # 直播间列表 |
56 | 56 |
|
57 | 57 |
url(r'^admin/live/order/list$', admin_views.live_order_list, name='live_order_list'), # 直播间订单列表 |
58 |
- url(r'^admin/live/order/delivery$', admin_views.live_order_delivery, name='live_order_delivery'), # 直播间订单发货 |
|
58 |
+ url(r'^admin/live/order/delivery$', admin_views.live_order_delivery, name='live_order_delivery'), # 直播间订单发货 |
|
59 | 59 |
|
60 |
- url(r'^admin/room/goods/list$', admin_views.room_goods_list, name='room_goods_list'), # 直播间商品 |
|
61 |
- url(r'^admin/room/goods/add$', admin_views.room_goods_add, name='room_goods_add'), #添加直播间商品 |
|
62 |
- url(r'^admin/room/goods/publish$', admin_views.room_goods_publish, name='room_goods_publish'), #直播间商品上架 |
|
63 |
- url(r'^admin/room/goods/off$', admin_views.room_goods_off, name='room_goods_off'), #直播间商品下架 |
|
64 |
- url(r'^admin/room/goods/update$', admin_views.room_goods_update, name='room_goods_update'), #直播间商品库存更新 |
|
60 |
+ url(r'^admin/room/goods/list$', admin_views.room_goods_list, name='room_goods_list'), # 直播间商品 |
|
61 |
+ url(r'^admin/room/goods/add$', admin_views.room_goods_add, name='room_goods_add'), # 添加直播间商品 |
|
62 |
+ url(r'^admin/room/goods/publish$', admin_views.room_goods_publish, name='room_goods_publish'), # 直播间商品上架 |
|
63 |
+ url(r'^admin/room/goods/off$', admin_views.room_goods_off, name='room_goods_off'), # 直播间商品下架 |
|
64 |
+ url(r'^admin/room/goods/update$', admin_views.room_goods_update, name='room_goods_update'), # 直播间商品库存更新 |
|
65 | 65 |
|
66 |
- #微信直播 api |
|
66 |
+ # 微信直播 api |
|
67 | 67 |
url(r'^admin/live/wx/room/list$', admin_views.fetch_wx_room_list, name='fetch_wx_room_list'), # 微信直播间列表 |
68 | 68 |
] |
69 | 69 |
|
@@ -1,6 +1,6 @@ |
||
1 | 1 |
from django.contrib import admin |
2 | 2 |
|
3 |
-from live.models import RoomGoodsInfo, RoomInfo, AnchorInfo, liveGoodsInfo, RoomOrderInfo, RoomUserInfo |
|
3 |
+from live.models import AnchorInfo, RoomGoodsInfo, RoomInfo, RoomOrderInfo, RoomUserInfo, liveGoodsInfo |
|
4 | 4 |
|
5 | 5 |
|
6 | 6 |
class AnchorInfoAdmin(admin.ModelAdmin): |
@@ -18,10 +18,12 @@ class liveGoodsInfoAdmin(admin.ModelAdmin): |
||
18 | 18 |
class RoomGoodsInfoAdmin(admin.ModelAdmin): |
19 | 19 |
list_display = ('room_id', 'anchor_id', 'goods_id', 'inventory', 'sale_infos', 'status', 'created_at', 'updated_at') |
20 | 20 |
|
21 |
+ |
|
21 | 22 |
class RoomOrderInfoAdmin(admin.ModelAdmin): |
22 | 23 |
list_display = ('order_id', 'anchor_id', 'room_id', 'goods_id', 'share_openid', 'user_id', 'total_fee', 'name', 'phone', 'address', 'tracking_number', 'pay_status', 'status', 'created_at', 'updated_at') |
23 | 24 |
readonly_fields_exclude = ('tracking_number', ) |
24 | 25 |
|
26 |
+ |
|
25 | 27 |
class RoomUserInfoAdmin(admin.ModelAdmin): |
26 | 28 |
list_display = ('room_id', 'anchor_id', 'user_id', 'openid', 'share_openid', 'status', 'created_at', 'updated_at') |
27 | 29 |
|
@@ -31,4 +33,4 @@ admin.site.register(RoomInfo, RoomInfoAdmin) |
||
31 | 33 |
admin.site.register(liveGoodsInfo, liveGoodsInfoAdmin) |
32 | 34 |
admin.site.register(RoomGoodsInfo, RoomGoodsInfoAdmin) |
33 | 35 |
admin.site.register(RoomOrderInfo, RoomOrderInfoAdmin) |
34 |
-admin.site.register(RoomUserInfo, RoomUserInfoAdmin) |
|
36 |
+admin.site.register(RoomUserInfo, RoomUserInfoAdmin) |
@@ -1,5 +1,3 @@ |
||
1 |
-import json |
|
2 |
- |
|
3 | 1 |
from django.db import models |
4 | 2 |
from django.utils.translation import ugettext_lazy as _ |
5 | 3 |
from django_models_ext import BaseModelMixin, upload_file_path, upload_file_url, upload_path |
@@ -7,9 +5,9 @@ from jsonfield import JSONField |
||
7 | 5 |
from shortuuidfield import ShortUUIDField |
8 | 6 |
from TimeConvert import TimeConvert as tc |
9 | 7 |
|
10 |
-from account.models import UserInfo |
|
11 | 8 |
from simditor.fields import RichTextField |
12 | 9 |
|
10 |
+ |
|
13 | 11 |
class AnchorInfo(BaseModelMixin): |
14 | 12 |
anchor_id = ShortUUIDField(_('anchor_id'), max_length=32, blank=True, help_text='主播唯一标识', unique=True) |
15 | 13 |
# 微信相关 |
@@ -20,14 +18,14 @@ class AnchorInfo(BaseModelMixin): |
||
20 | 18 |
anchor_name = models.CharField(_('anchor_name'), max_length=255, blank=True, help_text='主播姓名', db_index=True) |
21 | 19 |
anchor_avatar = models.ImageField(_('anchor_avatar'), upload_to=upload_path, help_text='主播头像') |
22 | 20 |
anchor_intro = RichTextField(_('anchor_intro'), blank=True, help_text='主播介绍') |
23 |
- |
|
21 |
+ |
|
24 | 22 |
class Meta: |
25 | 23 |
verbose_name = _('主播信息') |
26 | 24 |
verbose_name_plural = _('主播信息') |
27 | 25 |
|
28 | 26 |
def __unicode__(self): |
29 | 27 |
return self.pk |
30 |
- |
|
28 |
+ |
|
31 | 29 |
@property |
32 | 30 |
def anchor_avatar_path(self): |
33 | 31 |
return upload_file_path(self.anchor_avatar) |
@@ -35,6 +33,7 @@ class AnchorInfo(BaseModelMixin): |
||
35 | 33 |
@property |
36 | 34 |
def anchor_avatar_url(self): |
37 | 35 |
return upload_file_url(self.anchor_avatar) |
36 |
+ |
|
38 | 37 |
@property |
39 | 38 |
def banner_path(self): |
40 | 39 |
return upload_file_path(self.banner) |
@@ -57,8 +56,8 @@ class RoomInfo(BaseModelMixin): |
||
57 | 56 |
|
58 | 57 |
anchor_id = models.CharField(_('anchor_id'), blank=True, max_length=32, help_text='主播唯一标识') |
59 | 58 |
anchor_name = models.CharField(_('anchor_name'), blank=True, max_length=255, help_text='主播名称', db_index=True) |
60 |
- |
|
61 |
- # "goods": [ |
|
59 |
+ |
|
60 |
+ # "goods": [ |
|
62 | 61 |
# { |
63 | 62 |
# "cover_img": "http://mmbiz.qpic.cn/mmbiz_png/FVribAGdErI2PmyST9ZM0JLbNM48I7TH2FlrwYOlnYqGaej8qKubG1EvK0QIkkwqvicrYTzVtjKmSZSeY5ianc3mw/0?wx_fmt=png", |
64 | 63 |
# "url": "pages/index/index.html", |
@@ -74,7 +73,7 @@ class RoomInfo(BaseModelMixin): |
||
74 | 73 |
|
75 | 74 |
def __unicode__(self): |
76 | 75 |
return self.pk |
77 |
- |
|
76 |
+ |
|
78 | 77 |
@property |
79 | 78 |
def cover_img_path(self): |
80 | 79 |
return upload_file_path(self.cover_img) |
@@ -82,7 +81,7 @@ class RoomInfo(BaseModelMixin): |
||
82 | 81 |
@property |
83 | 82 |
def cover_img_url(self): |
84 | 83 |
return upload_file_url(self.cover_img) |
85 |
- |
|
84 |
+ |
|
86 | 85 |
@property |
87 | 86 |
def share_img_path(self): |
88 | 87 |
return upload_file_path(self.share_img) |
@@ -100,7 +99,7 @@ class RoomInfo(BaseModelMixin): |
||
100 | 99 |
'cover_img': self.wx_cover_img, |
101 | 100 |
'share_img': self.wx_share_img, |
102 | 101 |
} |
103 |
- |
|
102 |
+ |
|
104 | 103 |
@property |
105 | 104 |
def admindata(self): |
106 | 105 |
anchor = AnchorInfo.objects.get(anchor_id=self.anchor_id) |
@@ -117,7 +116,7 @@ class RoomInfo(BaseModelMixin): |
||
117 | 116 |
'anchor_avatar': anchor.anchor_avatar_url |
118 | 117 |
} |
119 | 118 |
|
120 |
- |
|
119 |
+ |
|
121 | 120 |
class liveGoodsInfo(BaseModelMixin): |
122 | 121 |
goods_id = ShortUUIDField(_('goods_id'), max_length=32, blank=True, help_text='商品ID', unique=True) |
123 | 122 |
|
@@ -161,7 +160,7 @@ class liveGoodsInfo(BaseModelMixin): |
||
161 | 160 |
@property |
162 | 161 |
def goods_img_url(self): |
163 | 162 |
return upload_file_url(self.goods_img) |
164 |
- |
|
163 |
+ |
|
165 | 164 |
@property |
166 | 165 |
def admindata(self): |
167 | 166 |
return { |
@@ -179,7 +178,6 @@ class liveGoodsInfo(BaseModelMixin): |
||
179 | 178 |
} |
180 | 179 |
|
181 | 180 |
|
182 |
- |
|
183 | 181 |
class RoomGoodsInfo(BaseModelMixin): |
184 | 182 |
PUBLISH = 0 |
185 | 183 |
DRAFT = 1 |
@@ -205,7 +203,7 @@ class RoomGoodsInfo(BaseModelMixin): |
||
205 | 203 |
|
206 | 204 |
def __unicode__(self): |
207 | 205 |
return self.pk |
208 |
- |
|
206 |
+ |
|
209 | 207 |
@property |
210 | 208 |
def admindata(self): |
211 | 209 |
goods = liveGoodsInfo.objects.get(goods_id=self.goods_id) |
@@ -230,6 +228,7 @@ class RoomGoodsInfo(BaseModelMixin): |
||
230 | 228 |
'sale_count': len(self.sale_infos), |
231 | 229 |
} |
232 | 230 |
|
231 |
+ |
|
233 | 232 |
class RoomUserInfo(BaseModelMixin): |
234 | 233 |
room_id = models.CharField(_('room_id'), max_length=32, help_text='房间唯一标识', db_index=True) |
235 | 234 |
anchor_id = models.CharField(_('anchor_id'), max_length=32, blank=True, help_text='主播唯一标识') |
@@ -247,6 +246,7 @@ class RoomUserInfo(BaseModelMixin): |
||
247 | 246 |
def __unicode__(self): |
248 | 247 |
return self.pk |
249 | 248 |
|
249 |
+ |
|
250 | 250 |
class RoomOrderInfo(BaseModelMixin): |
251 | 251 |
""" |
252 | 252 |
# Trade State of Wechat Query |
@@ -279,7 +279,7 @@ class RoomOrderInfo(BaseModelMixin): |
||
279 | 279 |
share_openid = models.CharField(_('share_openid'), max_length=32, blank=True, help_text='转发用户 openid') |
280 | 280 |
|
281 | 281 |
amount = models.IntegerField(_('amount'), default=0, help_text='数量') |
282 |
- |
|
282 |
+ |
|
283 | 283 |
name = models.CharField(_('name'), max_length=255, blank=True, null=True, help_text='姓名') |
284 | 284 |
phone = models.CharField(_('phone'), max_length=255, blank=True, null=True, help_text='电话') |
285 | 285 |
province = models.CharField(_('province'), max_length=255, blank=True, null=True, help_text='省份') |
@@ -344,4 +344,4 @@ class RoomOrderInfo(BaseModelMixin): |
||
344 | 344 |
'total_fee': self.total_fee, |
345 | 345 |
'pay_status': self.pay_status, |
346 | 346 |
'paid_at': tc.local_string(utc_dt=self.paid_at, format='%Y-%m-%d %H:%M'), |
347 |
- } |
|
347 |
+ } |
@@ -1,3 +1,4 @@ |
||
1 | 1 |
from django.test import TestCase |
2 | 2 |
|
3 |
+ |
|
3 | 4 |
# Create your tests here. |
@@ -1,35 +1,34 @@ |
||
1 |
-from django.shortcuts import render |
|
2 |
-from django_query import get_query_value |
|
1 |
+from django.conf import settings |
|
3 | 2 |
from django.db import transaction |
4 |
-from django_response import response |
|
5 | 3 |
from django.shortcuts import HttpResponse |
6 | 4 |
from django_logit import logit |
5 |
+from django_query import get_query_value |
|
6 |
+from django_response import response |
|
7 | 7 |
from pywe_exception import WeChatPayException |
8 | 8 |
from pywe_pay import WeChatPay |
9 | 9 |
from pywe_pay_notify import check_pay_notify |
10 | 10 |
from pywe_response import WXPAY_NOTIFY_FAIL, WXPAY_NOTIFY_SUCCESS |
11 | 11 |
from TimeConvert import TimeConvert as tc |
12 | 12 |
|
13 |
-from django.conf import settings |
|
14 |
- |
|
15 |
-from live.models import liveGoodsInfo, RoomGoodsInfo, RoomOrderInfo, RoomInfo, AnchorInfo |
|
16 | 13 |
from account.models import UserInfo |
17 |
- |
|
14 |
+from live.models import AnchorInfo, RoomGoodsInfo, RoomInfo, RoomOrderInfo, liveGoodsInfo |
|
18 | 15 |
from utils.error.errno_utils import OrderStatusCode, UserStatusCode |
19 | 16 |
|
17 |
+ |
|
20 | 18 |
WECHAT = settings.WECHAT |
21 | 19 |
|
20 |
+ |
|
22 | 21 |
def anchor_detail(request): |
23 | 22 |
anchor_id = get_query_value(request, 'anchor_id', '') |
24 | 23 |
|
25 | 24 |
try: |
26 | 25 |
anchor = AnchorInfo.objects.get(anchor_id=anchor_id) |
27 |
- except: |
|
26 |
+ except AnchorInfo.DoesNotExist: |
|
28 | 27 |
return response() |
29 |
- |
|
28 |
+ |
|
30 | 29 |
rooms = RoomInfo.objects.filter(anchor_id=anchor_id) |
31 | 30 |
rooms = [room.anchorData for room in rooms] |
32 |
- |
|
31 |
+ |
|
33 | 32 |
return response(200, 'Get Room Anchor Details Success', '获取主播详情成功', data={ |
34 | 33 |
'anchor': { |
35 | 34 |
'anchor_id': anchor.anchor_id, |
@@ -43,49 +42,50 @@ def anchor_detail(request): |
||
43 | 42 |
|
44 | 43 |
|
45 | 44 |
def room_goods_detail(request): |
46 |
- goods_id = get_query_value(request, 'goods_id', '') |
|
47 |
- room_id = get_query_value(request, 'room_id', '') |
|
48 |
- |
|
49 |
- # 校验直播间和商品 |
|
50 |
- try: |
|
51 |
- room_goods_info = RoomGoodsInfo.objects.get(goods_id=goods_id, room_id=room_id) |
|
52 |
- except: |
|
53 |
- return response(400001, 'Room Goods Not Found', '直播间商品不存在') |
|
54 |
- |
|
55 |
- try: |
|
56 |
- goods_info = liveGoodsInfo.objects.get(goods_id=goods_id) |
|
57 |
- except: |
|
58 |
- return response(400001, 'Live Goods Not Found', '直播商品不存在') |
|
59 |
- |
|
60 |
- return response(200, 'Get Room Goods Detail Success', '获取直播间商品成功', data={ |
|
45 |
+ goods_id = get_query_value(request, 'goods_id', '') |
|
46 |
+ room_id = get_query_value(request, 'room_id', '') |
|
47 |
+ |
|
48 |
+ # 校验直播间和商品 |
|
49 |
+ try: |
|
50 |
+ room_goods_info = RoomGoodsInfo.objects.get(goods_id=goods_id, room_id=room_id) |
|
51 |
+ except RoomGoodsInfo.DoesNotExist: |
|
52 |
+ return response(400001, 'Room Goods Not Found', '直播间商品不存在') |
|
53 |
+ |
|
54 |
+ try: |
|
55 |
+ goods_info = liveGoodsInfo.objects.get(goods_id=goods_id) |
|
56 |
+ except liveGoodsInfo.DoesNotExist: |
|
57 |
+ return response(400001, 'Live Goods Not Found', '直播商品不存在') |
|
58 |
+ |
|
59 |
+ return response(200, 'Get Room Goods Detail Success', '获取直播间商品成功', data={ |
|
61 | 60 |
'goods_info': { |
62 |
- 'goods_img': goods_info.goods_img_url, |
|
63 |
- 'name': goods_info.name, |
|
64 |
- 'price_type': goods_info.price_type, |
|
65 |
- 'price': goods_info.price, |
|
66 |
- 'price2': goods_info.price2, |
|
67 |
- 'goods_status': room_goods_info.goods_status, |
|
68 |
- 'inventory': room_goods_info.inventory, |
|
61 |
+ 'goods_img': goods_info.goods_img_url, |
|
62 |
+ 'name': goods_info.name, |
|
63 |
+ 'price_type': goods_info.price_type, |
|
64 |
+ 'price': goods_info.price, |
|
65 |
+ 'price2': goods_info.price2, |
|
66 |
+ 'goods_status': room_goods_info.goods_status, |
|
67 |
+ 'inventory': room_goods_info.inventory, |
|
69 | 68 |
}, |
70 | 69 |
'anchor_id': room_goods_info.anchor_id, |
71 |
- }) |
|
70 |
+ }) |
|
71 |
+ |
|
72 | 72 |
|
73 | 73 |
def room_anchor_details(request): |
74 | 74 |
room_id = request.POST.get('room_id', '') |
75 | 75 |
|
76 | 76 |
try: |
77 | 77 |
room = RoomInfo.objects.get(room_id=room_id) |
78 |
- except: |
|
78 |
+ except RoomInfo.DoesNotExist: |
|
79 | 79 |
return response() |
80 |
- |
|
80 |
+ |
|
81 | 81 |
try: |
82 | 82 |
anchor = AnchorInfo.objects.get(anchor_id=room.anchor_id) |
83 |
- except: |
|
83 |
+ except AnchorInfo.DoesNotExist: |
|
84 | 84 |
return response() |
85 |
- |
|
85 |
+ |
|
86 | 86 |
rooms = RoomInfo.objects.filter(anchor_id=room.anchor_id) |
87 | 87 |
rooms = [room.anchorData for room in rooms] |
88 |
- |
|
88 |
+ |
|
89 | 89 |
return response(200, 'Get Room Anchor Details Success', '获取主播详情成功', data={ |
90 | 90 |
'anchor': { |
91 | 91 |
'anchor_id': anchor.anchor_id, |
@@ -97,6 +97,7 @@ def room_anchor_details(request): |
||
97 | 97 |
'rooms': rooms |
98 | 98 |
}) |
99 | 99 |
|
100 |
+ |
|
100 | 101 |
@logit |
101 | 102 |
def live_order_create(request): |
102 | 103 |
""" 订单创建 """ |
@@ -121,32 +122,34 @@ def live_order_create(request): |
||
121 | 122 |
# 用户校验 |
122 | 123 |
try: |
123 | 124 |
user = UserInfo.objects.get(user_id=user_id, status=True) |
124 |
- user.consignee_name = name |
|
125 |
- user.consignee_phone = phone |
|
126 |
- user.consignee_province = province |
|
127 |
- user.consignee_city = city |
|
128 |
- user.consignee_county = county |
|
129 |
- user.consignee_address = address |
|
130 |
- user.save() |
|
131 | 125 |
except UserInfo.DoesNotExist: |
132 | 126 |
return response(UserStatusCode.USER_NOT_FOUND) |
133 | 127 |
|
128 |
+ user.consignee_name = name |
|
129 |
+ user.consignee_phone = phone |
|
130 |
+ user.consignee_province = province |
|
131 |
+ user.consignee_city = city |
|
132 |
+ user.consignee_county = county |
|
133 |
+ user.consignee_address = address |
|
134 |
+ user.save() |
|
135 |
+ |
|
134 | 136 |
# 校验直播间和商品 |
135 | 137 |
try: |
136 | 138 |
room_goods_info = RoomGoodsInfo.objects.get(goods_id=goods_id, room_id=room_id, anchor_id=anchor_id) |
137 |
- except: |
|
139 |
+ except RoomGoodsInfo.DoesNotExist: |
|
138 | 140 |
return response(400001, 'Room Goods Not Found', description='直播间商品不存在') |
139 | 141 |
|
140 |
- #库存校验 |
|
142 |
+ # 库存校验 |
|
141 | 143 |
if room_goods_info.inventory <= 0: |
142 | 144 |
return response(400001, 'Room Goods Not En', description='商品库存不足') |
143 | 145 |
|
144 | 146 |
# 金额校验 |
145 | 147 |
try: |
146 | 148 |
goods_info = liveGoodsInfo.objects.get(goods_id=goods_id) |
147 |
- if amount * int(goods_info.price if goods_info.price_type == 1 else goods_info.price2) != total_fee: |
|
148 |
- return response(404091, 'FEE Check Fail', description='金额校验失败') |
|
149 |
- except: |
|
149 |
+ except liveGoodsInfo.DoesNotExist: |
|
150 |
+ return response(404091, 'FEE Check Fail', description='金额校验失败') |
|
151 |
+ |
|
152 |
+ if amount * int(goods_info.price if goods_info.price_type == 1 else goods_info.price2) != total_fee: |
|
150 | 153 |
return response(404091, 'FEE Check Fail', description='金额校验失败') |
151 | 154 |
|
152 | 155 |
# 消库存 |
@@ -198,7 +201,6 @@ def live_order_create(request): |
||
198 | 201 |
order.save() |
199 | 202 |
|
200 | 203 |
wxpay_params = wxpay.jsapi.get_jsapi_params(prepay_id) |
201 |
- |
|
202 | 204 |
|
203 | 205 |
return response(200, 'Order Create Success', '订单创建成功', { |
204 | 206 |
'order_id': order.order_id, |
@@ -206,6 +208,7 @@ def live_order_create(request): |
||
206 | 208 |
'wxpay_params': wxpay_params, |
207 | 209 |
}) |
208 | 210 |
|
211 |
+ |
|
209 | 212 |
def live_order_cancel(request): |
210 | 213 |
user_id = request.POST.get('user_id', '') |
211 | 214 |
order_id = request.POST.get('order_id', '') |
@@ -213,24 +216,26 @@ def live_order_cancel(request): |
||
213 | 216 |
|
214 | 217 |
try: |
215 | 218 |
order = RoomOrderInfo.objects.get(user_id=user_id, order_id=order_id, prepay_id=prepay_id) |
216 |
- except: |
|
219 |
+ except RoomOrderInfo.DoesNotExist: |
|
217 | 220 |
return response(400001, 'Order Not Found', description='直播间订单不存在') |
218 |
- |
|
221 |
+ |
|
219 | 222 |
if order.pay_status == RoomOrderInfo.FAIL: |
220 | 223 |
return response(200, 'Order Cancel Success', '订单取消成功') |
221 |
- |
|
224 |
+ |
|
222 | 225 |
order.pay_status = RoomOrderInfo.FAIL |
223 | 226 |
order.save() |
224 |
- |
|
227 |
+ |
|
225 | 228 |
try: |
226 | 229 |
goods_info = RoomGoodsInfo.objects.get(room_id=order.room_id, goods_id=order.goods_id, anchor_id=order.anchor_id) |
227 |
- goods_info.inventory += order.amount |
|
228 |
- goods_info.save() |
|
229 |
- except: |
|
230 |
+ except RoomGoodsInfo.DoesNotExist: |
|
230 | 231 |
return response(400001, 'Room Goods Not Found', description='直播间商品不存在') |
231 |
- |
|
232 |
+ |
|
233 |
+ goods_info.inventory += order.amount |
|
234 |
+ goods_info.save() |
|
235 |
+ |
|
232 | 236 |
return response(200, 'Order Cancel Success', '订单取消成功') |
233 | 237 |
|
238 |
+ |
|
234 | 239 |
def order_paid_success(order): |
235 | 240 |
if order.pay_status == RoomOrderInfo.PAID: |
236 | 241 |
return |
@@ -241,11 +246,13 @@ def order_paid_success(order): |
||
241 | 246 |
|
242 | 247 |
try: |
243 | 248 |
goods_info = RoomGoodsInfo.objects.get(room_id=order.room_id, goods_id=order.goods_id, anchor_id=order.anchor_id) |
244 |
- goods_info.sale_infos += [order.order_id] |
|
245 |
- goods_info.save() |
|
246 |
- except: |
|
249 |
+ except RoomGoodsInfo.DoesNotExist: |
|
247 | 250 |
return |
248 | 251 |
|
252 |
+ goods_info.sale_infos += [order.order_id] |
|
253 |
+ goods_info.save() |
|
254 |
+ |
|
255 |
+ |
|
249 | 256 |
def order_paid_fail(order): |
250 | 257 |
if order.pay_status == RoomGoodsInfo.FAIL: |
251 | 258 |
return |
@@ -255,11 +262,13 @@ def order_paid_fail(order): |
||
255 | 262 |
|
256 | 263 |
try: |
257 | 264 |
goods_info = RoomGoodsInfo.objects.get(room_id=order.room_id, goods_id=order.goods_id, anchor_id=order.anchor_id) |
258 |
- goods_info.inventory += order.amount |
|
259 |
- goods_info.save() |
|
260 |
- except: |
|
265 |
+ except RoomGoodsInfo.DoesNotExist: |
|
261 | 266 |
return |
262 | 267 |
|
268 |
+ goods_info.inventory += order.amount |
|
269 |
+ goods_info.save() |
|
270 |
+ |
|
271 |
+ |
|
263 | 272 |
@logit |
264 | 273 |
@transaction.atomic |
265 | 274 |
def notify_url_api(request): |
@@ -17,12 +17,11 @@ from TimeConvert import TimeConvert as tc |
||
17 | 17 |
from account.models import UserInfo |
18 | 18 |
from goods.models import GoodsInfo, PackGoodsInfo, PackGoodsSaleInfo, PackInfo |
19 | 19 |
from kol.models import KOLInfo |
20 |
-from pay.models import OrderInfo |
|
20 |
+from live import views as live_views |
|
21 | 21 |
from live.models import RoomOrderInfo |
22 |
+from pay.models import OrderInfo |
|
22 | 23 |
from utils.error.errno_utils import KOLStatusCode, OrderStatusCode, PackGoodsStatusCode, PackStatusCode, UserStatusCode |
23 | 24 |
|
24 |
-from live import views as live_views |
|
25 |
- |
|
26 | 25 |
|
27 | 26 |
WECHAT = settings.WECHAT |
28 | 27 |
|
@@ -82,7 +81,7 @@ def wx_order_create_api(request): |
||
82 | 81 |
except GoodsInfo.DoesNotExist: |
83 | 82 |
continue |
84 | 83 |
amount = amount + good.price * g.get('num', 0) |
85 |
- |
|
84 |
+ |
|
86 | 85 |
if amount != total_fee: |
87 | 86 |
return response(OrderStatusCode.FEE_CHECK_FAIL) |
88 | 87 |
|
@@ -145,6 +144,7 @@ def wx_order_create_api(request): |
||
145 | 144 |
'wxpay_params': wxpay_params, |
146 | 145 |
}) |
147 | 146 |
|
147 |
+ |
|
148 | 148 |
def order_cancel(request): |
149 | 149 |
user_id = request.POST.get('user_id', '') |
150 | 150 |
order_id = request.POST.get('order_id', '') |
@@ -152,15 +152,15 @@ def order_cancel(request): |
||
152 | 152 |
|
153 | 153 |
try: |
154 | 154 |
order = OrderInfo.objects.get(user_id=user_id, order_id=order_id, prepay_id=prepay_id) |
155 |
- except: |
|
155 |
+ except OrderInfo.DoesNotExist: |
|
156 | 156 |
return response() |
157 |
- |
|
157 |
+ |
|
158 | 158 |
if order.pay_status == OrderInfo.FAIL: |
159 | 159 |
return response(200, 'Order Cancel Success', '订单取消成功') |
160 |
- |
|
160 |
+ |
|
161 | 161 |
order.pay_status = OrderInfo.FAIL |
162 | 162 |
order.save() |
163 |
- |
|
163 |
+ |
|
164 | 164 |
for g in order.goods_info: |
165 | 165 |
try: |
166 | 166 |
good = PackGoodsInfo.objects.get(pack_id=order.pack_id, good_id=g.get('good_id', '')) |
@@ -168,9 +168,10 @@ def order_cancel(request): |
||
168 | 168 |
good.save() |
169 | 169 |
except PackGoodsInfo.DoesNotExist: |
170 | 170 |
continue |
171 |
- |
|
171 |
+ |
|
172 | 172 |
return response(200, 'Order Cancel Success', '订单取消成功') |
173 | 173 |
|
174 |
+ |
|
174 | 175 |
def order_paid_success(order): |
175 | 176 |
if order.pay_status == OrderInfo.PAID: |
176 | 177 |
return |
@@ -218,22 +219,20 @@ def wx_notify_url_api(request): |
||
218 | 219 |
if not success: |
219 | 220 |
return HttpResponse(WXPAY_NOTIFY_FAIL) |
220 | 221 |
|
221 |
- #尖货接龙订单 |
|
222 |
+ # 尖货接龙订单 |
|
222 | 223 |
try: |
223 | 224 |
order = OrderInfo.objects.select_for_update().get(order_id=notify_data.get('out_trade_no', ''), status=True) |
224 |
- order.notify_msg = request.body |
|
225 |
- order.transaction_id = notify_data.get('transaction_id', '') |
|
226 |
- order.save() |
|
227 |
- |
|
228 |
- result_code = notify_data.get('result_code', '') |
|
229 |
- if result_code == 'SUCCESS': |
|
230 |
- order_paid_success(order) |
|
231 |
- else: |
|
232 |
- order_paid_fail(order) |
|
233 |
- |
|
234 |
- return HttpResponse(WXPAY_NOTIFY_SUCCESS) |
|
235 |
- except: |
|
225 |
+ except OrderInfo.DoesNotExist: |
|
236 | 226 |
return HttpResponse(WXPAY_NOTIFY_FAIL) |
237 | 227 |
|
228 |
+ order.notify_msg = request.body |
|
229 |
+ order.transaction_id = notify_data.get('transaction_id', '') |
|
230 |
+ order.save() |
|
231 |
+ |
|
232 |
+ result_code = notify_data.get('result_code', '') |
|
233 |
+ if result_code == 'SUCCESS': |
|
234 |
+ order_paid_success(order) |
|
235 |
+ else: |
|
236 |
+ order_paid_fail(order) |
|
238 | 237 |
|
239 | 238 |
return HttpResponse(WXPAY_NOTIFY_SUCCESS) |