log = CouponInfo.objects.get(coupon_id=coupon_id, status=True)
|
|
1416
|
1183
|
except CouponInfo.DoesNotExist:
|
|
|
|
@@ -1422,26 +1189,18 @@ def coupon_delete(request):
|
|
1422
|
1189
|
return response(200, 'CouponInfo Delete Success', u'劵删除成功')
|
|
1423
|
1190
|
|
|
1424
|
1191
|
|
|
1425
|
|
-def member_goods_list(request):
|
|
1426
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1427
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1192
|
+@check_admin
|
|
|
1193
|
+def member_goods_list(request, administrator):
|
|
1428
|
1194
|
title = request.POST.get('title', '')
|
|
1429
|
1195
|
page = request.POST.get('page', 1)
|
|
1430
|
1196
|
num = request.POST.get('num', 20)
|
|
1431
|
1197
|
|
|
1432
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1433
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1434
|
|
-
|
|
1435
|
|
- try:
|
|
1436
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1437
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1438
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1439
|
|
-
|
|
1440
|
1198
|
logs = GoodsInfo.objects.filter(title__icontains=title, only_for_member=False).order_by('-pk')
|
|
1441
|
1199
|
|
|
1442
|
1200
|
count = logs.count()
|
|
1443
|
1201
|
logs, left = pagination(logs, page, num)
|
|
1444
|
1202
|
logs = [log.admindata for log in logs]
|
|
|
1203
|
+
|
|
1445
|
1204
|
return response(200, 'Get Member Goods Success', u'获取会员商品成功', data={
|
|
1446
|
1205
|
'logs': logs,
|
|
1447
|
1206
|
'left': left,
|
|
|
|
@@ -1449,19 +1208,10 @@ def member_goods_list(request):
|
|
1449
|
1208
|
})
|
|
1450
|
1209
|
|
|
1451
|
1210
|
|
|
1452
|
|
-def member_goods_details(request):
|
|
1453
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1454
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1211
|
+@check_admin
|
|
|
1212
|
+def member_goods_detail(request, administrator):
|
|
1455
|
1213
|
good_id = request.POST.get('good_id', '')
|
|
1456
|
1214
|
|
|
1457
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1458
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1459
|
|
-
|
|
1460
|
|
- try:
|
|
1461
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1462
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1463
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1464
|
|
-
|
|
1465
|
1215
|
try:
|
|
1466
|
1216
|
log = GoodsInfo.objects.get(good_id=good_id)
|
|
1467
|
1217
|
except GoodsInfo.DoesNotExist:
|
|
|
|
@@ -1474,9 +1224,8 @@ def member_goods_details(request):
|
|
1474
|
1224
|
})
|
|
1475
|
1225
|
|
|
1476
|
1226
|
|
|
1477
|
|
-def member_goods_update(request):
|
|
1478
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1479
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1227
|
+@check_admin
|
|
|
1228
|
+def member_goods_update(request, administrator):
|
|
1480
|
1229
|
good_id = request.POST.get('good_id', '')
|
|
1481
|
1230
|
title = request.POST.get('title', '')
|
|
1482
|
1231
|
desc = request.POST.get('desc', '')
|
|
|
|
@@ -1488,14 +1237,6 @@ def member_goods_update(request):
|
|
1488
|
1237
|
integral = int(request.POST.get('integral', 0))
|
|
1489
|
1238
|
fee = int(request.POST.get('fee', 0))
|
|
1490
|
1239
|
|
|
1491
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1492
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1493
|
|
-
|
|
1494
|
|
- try:
|
|
1495
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1496
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1497
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1498
|
|
-
|
|
1499
|
1240
|
try:
|
|
1500
|
1241
|
log = GoodsInfo.objects.get(good_id=good_id, status=True)
|
|
1501
|
1242
|
except GoodsInfo.DoesNotExist:
|
|
|
|
@@ -1515,9 +1256,8 @@ def member_goods_update(request):
|
|
1515
|
1256
|
return response(200, 'GoodsInfo Update Success', u'积分商品更新成功')
|
|
1516
|
1257
|
|
|
1517
|
1258
|
|
|
1518
|
|
-def member_goods_create(request):
|
|
1519
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1520
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1259
|
+@check_admin
|
|
|
1260
|
+def member_goods_create(request, administrator):
|
|
1521
|
1261
|
good_type = int(request.POST.get('good_type', 0))
|
|
1522
|
1262
|
title = request.POST.get('title', '')
|
|
1523
|
1263
|
desc = request.POST.get('desc', '')
|
|
|
|
@@ -1529,14 +1269,6 @@ def member_goods_create(request):
|
|
1529
|
1269
|
integral = int(request.POST.get('integral', 0))
|
|
1530
|
1270
|
fee = int(request.POST.get('fee', 0))
|
|
1531
|
1271
|
|
|
1532
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1533
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1534
|
|
-
|
|
1535
|
|
- try:
|
|
1536
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1537
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1538
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1539
|
|
-
|
|
1540
|
1272
|
GoodsInfo.objects.create(
|
|
1541
|
1273
|
brand_id=administrator.brand_id,
|
|
1542
|
1274
|
good_type=good_type,
|
|
|
|
@@ -1554,23 +1286,14 @@ def member_goods_create(request):
|
|
1554
|
1286
|
return response(200, 'GoodsInfo Create Success', u'积分商品创建成功')
|
|
1555
|
1287
|
|
|
1556
|
1288
|
|
|
1557
|
|
-def complement_code_list(request):
|
|
1558
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1559
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
1560
|
|
- page = request.POST.get('page', 1)
|
|
1561
|
|
- num = request.POST.get('num', 20)
|
|
|
1289
|
+@check_admin
|
|
|
1290
|
+def complement_code_list(request, administrator):
|
|
1562
|
1291
|
start_time = request.POST.get('start_time', '')
|
|
1563
|
1292
|
end_time = request.POST.get('end_time', '')
|
|
1564
|
1293
|
type_ = request.POST.get('type', '')
|
|
1565
|
1294
|
query = request.POST.get('query', '')
|
|
1566
|
|
-
|
|
1567
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1568
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1569
|
|
-
|
|
1570
|
|
- try:
|
|
1571
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1572
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1573
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
|
1295
|
+ page = request.POST.get('page', 1)
|
|
|
1296
|
+ num = request.POST.get('num', 20)
|
|
1574
|
1297
|
|
|
1575
|
1298
|
logs = ComplementCodeLogInfo.objects.filter(status=True)
|
|
1576
|
1299
|
|
|
|
|
@@ -1602,21 +1325,14 @@ def complement_code_list(request):
|
|
1602
|
1325
|
})
|
|
1603
|
1326
|
|
|
1604
|
1327
|
|
|
|
1328
|
+@check_admin
|
|
1605
|
1329
|
@transaction.atomic
|
|
1606
|
|
-def complement_code_audit(request):
|
|
|
1330
|
+def complement_code_audit(request, administrator):
|
|
1607
|
1331
|
brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1608
|
1332
|
admin_id = request.POST.get('admin_id', '')
|
|
1609
|
1333
|
log_id = request.POST.get('log_id', '')
|
|
1610
|
1334
|
audit_status = int(request.POST.get('audit_status', 0)) # -1 审核不通过, 1 审核通过
|
|
1611
|
1335
|
|
|
1612
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1613
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1614
|
|
-
|
|
1615
|
|
- try:
|
|
1616
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1617
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1618
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1619
|
|
-
|
|
1620
|
1336
|
if audit_status not in [ComplementCodeLogInfo.AUDIT_REFUSED, ComplementCodeLogInfo.AUDIT_PASS]:
|
|
1621
|
1337
|
return response(ComplementCodeStatusCode.COMPLEMENT_CODE_STATUS_INVALID)
|
|
1622
|
1338
|
|
|
|
|
@@ -1699,21 +1415,12 @@ def complement_code_audit(request):
|
|
1699
|
1415
|
return response()
|
|
1700
|
1416
|
|
|
1701
|
1417
|
|
|
|
1418
|
+@check_admin
|
|
1702
|
1419
|
@transaction.atomic
|
|
1703
|
|
-def complement_code_contacted(request):
|
|
1704
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1705
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1420
|
+def complement_code_contacted(request, administrator):
|
|
1706
|
1421
|
log_id = request.POST.get('log_id', '')
|
|
1707
|
1422
|
is_contacted = int(request.POST.get('is_contacted', 0)) # 0 未联系, 1 已联系
|
|
1708
|
1423
|
|
|
1709
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1710
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1711
|
|
-
|
|
1712
|
|
- try:
|
|
1713
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1714
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1715
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1716
|
|
-
|
|
1717
|
1424
|
try:
|
|
1718
|
1425
|
log = ComplementCodeLogInfo.objects.select_for_update().get(log_id=log_id, status=True)
|
|
1719
|
1426
|
except ComplementCodeLogInfo.DoesNotExist:
|
|
|
|
@@ -1725,20 +1432,11 @@ def complement_code_contacted(request):
|
|
1725
|
1432
|
return response()
|
|
1726
|
1433
|
|
|
1727
|
1434
|
|
|
1728
|
|
-def administrator_list(request):
|
|
1729
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1730
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1435
|
+@check_admin
|
|
|
1436
|
+def administrator_list(request, administrator):
|
|
1731
|
1437
|
page = request.POST.get('page', 1)
|
|
1732
|
1438
|
num = request.POST.get('num', 20)
|
|
1733
|
1439
|
|
|
1734
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1735
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1736
|
|
-
|
|
1737
|
|
- try:
|
|
1738
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1739
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1740
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1741
|
|
-
|
|
1742
|
1440
|
if administrator.admin_type != AdministratorInfo.ADMINISTRATOR:
|
|
1743
|
1441
|
return response(AdministratorStatusCode.ADMINISTRATOR_PERMISSION_DENIED)
|
|
1744
|
1442
|
|
|
|
|
@@ -1747,6 +1445,7 @@ def administrator_list(request):
|
|
1747
|
1445
|
count = logs.count()
|
|
1748
|
1446
|
logs, left = pagination(logs, page, num)
|
|
1749
|
1447
|
logs = [log.admindata for log in logs]
|
|
|
1448
|
+
|
|
1750
|
1449
|
return response(200, 'Get Admin List Success', u'获取后台管理员成功', data={
|
|
1751
|
1450
|
'logs': logs,
|
|
1752
|
1451
|
'left': left,
|
|
|
|
@@ -1754,31 +1453,21 @@ def administrator_list(request):
|
|
1754
|
1453
|
})
|
|
1755
|
1454
|
|
|
1756
|
1455
|
|
|
1757
|
|
-def administrator_create(request):
|
|
1758
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1759
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
1760
|
|
-
|
|
|
1456
|
+@check_admin
|
|
|
1457
|
+def administrator_create(request, administrator):
|
|
1761
|
1458
|
admin_type = request.POST.get('admin_type', '')
|
|
1762
|
1459
|
phone = request.POST.get('phone', '')
|
|
1763
|
1460
|
name = request.POST.get('name', '')
|
|
1764
|
1461
|
password = request.POST.get('password', '')
|
|
1765
|
1462
|
brand_name = request.POST.get('brand_name', '')
|
|
1766
|
1463
|
|
|
1767
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1768
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1769
|
|
-
|
|
1770
|
|
- try:
|
|
1771
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1772
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1773
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1774
|
|
-
|
|
1775
|
1464
|
if administrator.admin_type != AdministratorInfo.ADMINISTRATOR:
|
|
1776
|
1465
|
return response(AdministratorStatusCode.ADMINISTRATOR_PERMISSION_DENIED)
|
|
1777
|
1466
|
|
|
1778
|
1467
|
encryption = make_password(strip(password), settings.MAKE_PASSWORD_SALT, settings.MAKE_PASSWORD_HASHER)
|
|
1779
|
1468
|
|
|
1780
|
1469
|
AdministratorInfo.objects.create(
|
|
1781
|
|
- brand_id=brand_id,
|
|
|
1470
|
+ brand_id=administrator.brand_id,
|
|
1782
|
1471
|
brand_name=brand_name,
|
|
1783
|
1472
|
admin_type=admin_type,
|
|
1784
|
1473
|
phone=phone,
|
|
|
|
@@ -1790,24 +1479,14 @@ def administrator_create(request):
|
|
1790
|
1479
|
return response(200, 'Create Admin Success', u'创建后台管理员成功')
|
|
1791
|
1480
|
|
|
1792
|
1481
|
|
|
1793
|
|
-def administrator_update(request):
|
|
1794
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1795
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
1796
|
|
-
|
|
|
1482
|
+@check_admin
|
|
|
1483
|
+def administrator_update(request, administrator):
|
|
1797
|
1484
|
target_admin_id = request.POST.get('target_admin_id', '')
|
|
1798
|
1485
|
admin_type = int(request.POST.get('admin_type', -1))
|
|
1799
|
1486
|
phone = request.POST.get('phone', '')
|
|
1800
|
1487
|
name = request.POST.get('name', '')
|
|
1801
|
1488
|
password = request.POST.get('password', '')
|
|
1802
|
1489
|
|
|
1803
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1804
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1805
|
|
-
|
|
1806
|
|
- try:
|
|
1807
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1808
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1809
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1810
|
|
-
|
|
1811
|
1490
|
if administrator.admin_type != AdministratorInfo.ADMINISTRATOR:
|
|
1812
|
1491
|
return response(AdministratorStatusCode.ADMINISTRATOR_PERMISSION_DENIED)
|
|
1813
|
1492
|
|
|
|
|
@@ -1832,19 +1511,10 @@ def administrator_update(request):
|
|
1832
|
1511
|
return response(200, 'Update Admin Success', u'更新后台管理员成功')
|
|
1833
|
1512
|
|
|
1834
|
1513
|
|
|
1835
|
|
-def administrator_delete(request):
|
|
1836
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1837
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1514
|
+@check_admin
|
|
|
1515
|
+def administrator_delete(request, administrator):
|
|
1838
|
1516
|
target_admin_id = request.POST.get('target_admin_id', '')
|
|
1839
|
1517
|
|
|
1840
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1841
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1842
|
|
-
|
|
1843
|
|
- try:
|
|
1844
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1845
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1846
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1847
|
|
-
|
|
1848
|
1518
|
if administrator.admin_type != AdministratorInfo.ADMINISTRATOR:
|
|
1849
|
1519
|
return response(AdministratorStatusCode.ADMINISTRATOR_PERMISSION_DENIED)
|
|
1850
|
1520
|
|
|
|
|
@@ -1853,21 +1523,12 @@ def administrator_delete(request):
|
|
1853
|
1523
|
return response(200, 'Delete Admin Success', u'删除后台管理员成功')
|
|
1854
|
1524
|
|
|
1855
|
1525
|
|
|
1856
|
|
-def administrator_login_list(request):
|
|
1857
|
|
- brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
1858
|
|
- admin_id = request.POST.get('admin_id', '')
|
|
|
1526
|
+@check_admin
|
|
|
1527
|
+def administrator_login_list(request, administrator):
|
|
1859
|
1528
|
page = request.POST.get('page', 1)
|
|
1860
|
1529
|
num = request.POST.get('num', 20)
|
|
1861
|
1530
|
target_admin_id = request.POST.get('target_admin_id', '')
|
|
1862
|
1531
|
|
|
1863
|
|
- if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
1864
|
|
- return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
1865
|
|
-
|
|
1866
|
|
- try:
|
|
1867
|
|
- administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
1868
|
|
- except AdministratorInfo.DoesNotExist:
|
|
1869
|
|
- return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
1870
|
|
-
|
|
1871
|
1532
|
if administrator.admin_type != AdministratorInfo.ADMINISTRATOR:
|
|
1872
|
1533
|
return response(AdministratorStatusCode.ADMINISTRATOR_PERMISSION_DENIED)
|
|
1873
|
1534
|
|
|
|
|
@@ -165,7 +165,7 @@ urlpatterns += [
|
|
165
|
165
|
url(r'^admin/member/goods/order/batch/update$', admin_views.member_goods_order_batch_update, name='member_goods_order_batch_update'),
|
|
166
|
166
|
|
|
167
|
167
|
url(r'^admin/member/activity/list$', admin_views.member_activity_list, name='member_activity_list'),
|
|
168
|
|
- url(r'^admin/member/activity/details$', admin_views.member_activity_details, name='member_activity_details'),
|
|
|
168
|
+ url(r'^admin/member/activity/details$', admin_views.member_activity_detail, name='member_activity_detail'),
|
|
169
|
169
|
url(r'^admin/member/activity/update$', admin_views.member_activity_update, name='member_activity_update'),
|
|
170
|
170
|
url(r'^admin/member/activity/create$', admin_views.member_activity_create, name='member_activity_create'),
|
|
171
|
171
|
url(r'^admin/member/activity/share/list$', admin_views.member_activity_share_list, name='member_activity_share_list'),
|
|
|
|
@@ -175,14 +175,19 @@ urlpatterns += [
|
|
175
|
175
|
url(r'^admin/member/activity/contribute/audit$', admin_views.member_activity_contribute_audit, name='admin_member_activity_contribute_audit'),
|
|
176
|
176
|
url(r'^admin/member/activity/contribute/selected$', admin_views.member_activity_contribute_selected, name='admin_member_activity_contribute_selected'),
|
|
177
|
177
|
|
|
|
178
|
+ url(r'^admin/member/activity/contribute/welfare/list$', admin_views.member_activity_contribute_welfare_list, name='member_activity_contribute_welfare_list'),
|
|
|
179
|
+ url(r'^admin/member/activity/contribute/welfare/detail$', admin_views.member_activity_contribute_welfare_detail, name='member_activity_contribute_welfare_detail'),
|
|
|
180
|
+ url(r'^admin/member/activity/contribute/welfare/update$', admin_views.member_activity_contribute_welfare_update, name='member_activity_contribute_welfare_update'),
|
|
|
181
|
+ url(r'^admin/member/activity/contribute/welfare/create$', admin_views.member_activity_contribute_welfare_create, name='member_activity_contribute_welfare_create'),
|
|
|
182
|
+
|
|
178
|
183
|
url(r'^admin/coupon/list$', admin_views.coupon_list, name='coupon_list'),
|
|
179
|
|
- url(r'^admin/coupon/details$', admin_views.coupon_details, name='coupon_update'),
|
|
|
184
|
+ url(r'^admin/coupon/details$', admin_views.coupon_detail, name='coupon_detail'),
|
|
180
|
185
|
url(r'^admin/coupon/create$', admin_views.coupon_create, name='coupon_create'),
|
|
181
|
186
|
url(r'^admin/coupon/update$', admin_views.coupon_update, name='coupon_update'),
|
|
182
|
187
|
url(r'^admin/coupon/delete$', admin_views.coupon_delete, name='coupon_delete'),
|
|
183
|
188
|
|
|
184
|
189
|
url(r'^admin/member/goods/list$', admin_views.member_goods_list, name='member_goods_list'),
|
|
185
|
|
- url(r'^admin/member/goods/details$', admin_views.member_goods_details, name='member_goods_details'),
|
|
|
190
|
+ url(r'^admin/member/goods/details$', admin_views.member_goods_detail, name='member_goods_detail'),
|
|
186
|
191
|
url(r'^admin/member/goods/create$', admin_views.member_goods_create, name='member_goods_create'),
|
|
187
|
192
|
url(r'^admin/member/goods/update$', admin_views.member_goods_update, name='member_goods_update'),
|
|
188
|
193
|
|
|
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+# -*- coding: utf-8 -*-
|
|
|
2
|
+
|
|
|
3
|
+from __future__ import division
|
|
|
4
|
+
|
|
|
5
|
+from functools import wraps
|
|
|
6
|
+
|
|
|
7
|
+from django.conf import settings
|
|
|
8
|
+from django_response import response
|
|
|
9
|
+
|
|
|
10
|
+from mch.models import AdministratorInfo
|
|
|
11
|
+from utils.error.errno_utils import AdministratorStatusCode, ProductBrandStatusCode
|
|
|
12
|
+
|
|
|
13
|
+
|
|
|
14
|
+def check_admin(func=None):
|
|
|
15
|
+ def decorator(func):
|
|
|
16
|
+ @wraps(func)
|
|
|
17
|
+ def returned_wrapper(request, *args, **kwargs):
|
|
|
18
|
+ brand_id = request.POST.get('brand_id', settings.KODO_DEFAULT_BRAND_ID)
|
|
|
19
|
+ admin_id = request.POST.get('admin_id', '')
|
|
|
20
|
+
|
|
|
21
|
+ if brand_id != settings.KODO_DEFAULT_BRAND_ID:
|
|
|
22
|
+ return response(ProductBrandStatusCode.BRAND_NOT_MATCH)
|
|
|
23
|
+
|
|
|
24
|
+ try:
|
|
|
25
|
+ administrator = AdministratorInfo.objects.get(admin_id=admin_id, user_status=AdministratorInfo.ACTIVATED, status=True)
|
|
|
26
|
+ except AdministratorInfo.DoesNotExist:
|
|
|
27
|
+ return response(AdministratorStatusCode.ADMINISTRATOR_NOT_FOUND)
|
|
|
28
|
+
|
|
|
29
|
+ return func(request, administrator=administrator, *args, **kwargs)
|
|
|
30
|
+
|
|
|
31
|
+ return returned_wrapper
|
|
|
32
|
+
|
|
|
33
|
+ if not func:
|
|
|
34
|
+ def foo(func):
|
|
|
35
|
+ return decorator(func)
|
|
|
36
|
+
|
|
|
37
|
+ return foo
|
|
|
38
|
+
|
|
|
39
|
+ return decorator(func)
|
|
|
|
@@ -5,9 +5,9 @@ from django.contrib import admin
|
|
5
|
5
|
from django_admin import DeleteModelAdmin
|
|
6
|
6
|
|
|
7
|
7
|
from account.models import UserInfo
|
|
8
|
|
-from member.models import (GoodsInfo, GoodsOrderInfo, MemberActivityContributionInfo, MemberActivityGroupShareInfo,
|
|
9
|
|
- MemberActivityInfo, MemberActivitySigninInfo, MemberActivitySignupInfo, RightInfo,
|
|
10
|
|
- ShotTypeInfo)
|
|
|
8
|
+from member.models import (GoodsInfo, GoodsOrderInfo, MemberActivityContributionInfo,
|
|
|
9
|
+ MemberActivityContributionWelfareInfo, MemberActivityGroupShareInfo, MemberActivityInfo,
|
|
|
10
|
+ MemberActivitySigninInfo, MemberActivitySignupInfo, RightInfo, ShotTypeInfo)
|
|
11
|
11
|
from pre.custom_message import sendwxasubscribemessage
|
|
12
|
12
|
from utils.redis.rshot import update_member_shot_data
|
|
13
|
13
|
|
|
|
|
@@ -103,6 +103,11 @@ class MemberActivityContributionInfoAdmin(admin.ModelAdmin):
|
|
103
|
103
|
list_filter = ('activity_id', 'content_type', 'is_audit_pass', 'is_selected', 'status')
|
|
104
|
104
|
|
|
105
|
105
|
|
|
|
106
|
+class MemberActivityContributionWelfareInfoAdmin(admin.ModelAdmin):
|
|
|
107
|
+ list_display = ('welfare_id', 'welfare_type', 'welfare_title', 'welfare_detail', 'welfare_value', 'welfare_image', 'status', 'created_at', 'updated_at')
|
|
|
108
|
+ list_filter = ('welfare_type', 'status')
|
|
|
109
|
+
|
|
|
110
|
+
|
|
106
|
111
|
admin.site.register(GoodsInfo, GoodsInfoAdmin)
|
|
107
|
112
|
admin.site.register(GoodsOrderInfo, GoodsOrderInfoAdmin)
|
|
108
|
113
|
admin.site.register(RightInfo, RightInfoAdmin)
|
|
|
|
@@ -112,3 +117,4 @@ admin.site.register(MemberActivitySignupInfo, MemberActivitySignupInfoAdmin)
|
|
112
|
117
|
admin.site.register(MemberActivitySigninInfo, MemberActivitySigninInfoAdmin)
|
|
113
|
118
|
admin.site.register(MemberActivityGroupShareInfo, MemberActivityGroupShareInfoAdmin)
|
|
114
|
119
|
admin.site.register(MemberActivityContributionInfo, MemberActivityContributionInfoAdmin)
|
|
|
120
|
+admin.site.register(MemberActivityContributionWelfareInfo, MemberActivityContributionWelfareInfoAdmin)
|
|
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+# -*- coding: utf-8 -*-
|
|
|
2
|
+# Generated by Django 3.2.16 on 2022-10-24 17:41
|
|
|
3
|
+
|
|
|
4
|
+from django.db import migrations, models
|
|
|
5
|
+import django_models_ext.fileext
|
|
|
6
|
+import shortuuidfield.fields
|
|
|
7
|
+import simditor.fields
|
|
|
8
|
+
|
|
|
9
|
+
|
|
|
10
|
+class Migration(migrations.Migration):
|
|
|
11
|
+
|
|
|
12
|
+ dependencies = [
|
|
|
13
|
+ ('member', '0037_auto_20221023_2010'),
|
|
|
14
|
+ ]
|
|
|
15
|
+
|
|
|
16
|
+ operations = [
|
|
|
17
|
+ migrations.CreateModel(
|
|
|
18
|
+ name='MemberActivityContributionWelfareInfo',
|
|
|
19
|
+ fields=[
|
|
|
20
|
+ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
|
21
|
+ ('status', models.BooleanField(default=True, help_text='Status', verbose_name='status')),
|
|
|
22
|
+ ('created_at', models.DateTimeField(auto_now_add=True, help_text='Create Time', verbose_name='created_at')),
|
|
|
23
|
+ ('updated_at', models.DateTimeField(auto_now=True, help_text='Update Time', verbose_name='updated_at')),
|
|
|
24
|
+ ('brand_id', models.CharField(blank=True, db_index=True, help_text='品牌唯一标识', max_length=32, null=True, verbose_name='brand_id')),
|
|
|
25
|
+ ('brand_name', models.CharField(blank=True, help_text='品牌名称', max_length=255, null=True, verbose_name='brand_name')),
|
|
|
26
|
+ ('welfare_id', shortuuidfield.fields.ShortUUIDField(blank=True, db_index=True, editable=False, help_text='福利唯一标识', max_length=22, null=True, unique=True)),
|
|
|
27
|
+ ('welfare_type', models.IntegerField(choices=[(0, '实物'), (1, '积分'), (2, '虚拟')], db_index=True, default=0, help_text='福利类型', verbose_name='welfare_type')),
|
|
|
28
|
+ ('welfare_title', models.CharField(blank=True, help_text='福利标题', max_length=255, null=True, verbose_name='welfare_title')),
|
|
|
29
|
+ ('welfare_detail', simditor.fields.RichTextField(blank=True, help_text='福利详情', null=True, verbose_name='welfare_detail')),
|
|
|
30
|
+ ('welfare_value', models.IntegerField(default=0, help_text='福利数量', verbose_name='welfare_value')),
|
|
|
31
|
+ ('welfare_image', models.ImageField(blank=True, help_text='福利图片', null=True, upload_to=django_models_ext.fileext.upload_path, verbose_name='welfare_image')),
|
|
|
32
|
+ ],
|
|
|
33
|
+ options={
|
|
|
34
|
+ 'verbose_name': '会员活动投稿福利信息',
|
|
|
35
|
+ 'verbose_name_plural': '会员活动投稿福利信息',
|
|
|
36
|
+ },
|
|
|
37
|
+ ),
|
|
|
38
|
+ migrations.AlterField(
|
|
|
39
|
+ model_name='memberactivitycontributioninfo',
|
|
|
40
|
+ name='content_type',
|
|
|
41
|
+ field=models.IntegerField(choices=[(0, '投稿'), (1, '创作日记')], db_index=True, default=0, help_text='内容类型', verbose_name='content_type'),
|
|
|
42
|
+ ),
|
|
|
43
|
+ ]
|
|
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+# -*- coding: utf-8 -*-
|
|
|
2
|
+# Generated by Django 3.2.16 on 2022-10-24 17:59
|
|
|
3
|
+
|
|
|
4
|
+from django.db import migrations, models
|
|
|
5
|
+
|
|
|
6
|
+
|
|
|
7
|
+class Migration(migrations.Migration):
|
|
|
8
|
+
|
|
|
9
|
+ dependencies = [
|
|
|
10
|
+ ('member', '0038_auto_20221025_0141'),
|
|
|
11
|
+ ]
|
|
|
12
|
+
|
|
|
13
|
+ operations = [
|
|
|
14
|
+ migrations.AddField(
|
|
|
15
|
+ model_name='memberactivitycontributionwelfareinfo',
|
|
|
16
|
+ name='is_upload_qiniu',
|
|
|
17
|
+ field=models.BooleanField(default=False, help_text='是否已上传七牛', verbose_name='is_upload_qiniu'),
|
|
|
18
|
+ ),
|
|
|
19
|
+ ]
|
|
|
|
@@ -718,3 +718,53 @@ class MemberActivityContributionInfo(BaseModelMixin):
|
|
718
|
718
|
'video_url': self.video_url or '',
|
|
719
|
719
|
'created_at': tc.local_string(utc_dt=self.created_at),
|
|
720
|
720
|
}
|
|
|
721
|
+
|
|
|
722
|
+
|
|
|
723
|
+class MemberActivityContributionWelfareInfo(BaseModelMixin):
|
|
|
724
|
+ WELFARE_TYPE = (
|
|
|
725
|
+ (0, u'实物'),
|
|
|
726
|
+ (1, u'积分'),
|
|
|
727
|
+ (2, u'虚拟'),
|
|
|
728
|
+ )
|
|
|
729
|
+
|
|
|
730
|
+ brand_id = models.CharField(_(u'brand_id'), max_length=32, blank=True, null=True, help_text=u'品牌唯一标识', db_index=True)
|
|
|
731
|
+ brand_name = models.CharField(_(u'brand_name'), max_length=255, blank=True, null=True, help_text=u'品牌名称')
|
|
|
732
|
+
|
|
|
733
|
+ welfare_id = ShortUUIDField(_(u'welfare_id'), max_length=32, blank=True, null=True, help_text=u'福利唯一标识', db_index=True, unique=True)
|
|
|
734
|
+
|
|
|
735
|
+ welfare_type = models.IntegerField(_(u'welfare_type'), choices=WELFARE_TYPE, default=0, help_text=u'福利类型', db_index=True)
|
|
|
736
|
+
|
|
|
737
|
+ welfare_title = models.CharField(_(u'welfare_title'), max_length=255, blank=True, null=True, help_text=u'福利标题')
|
|
|
738
|
+ welfare_detail = RichTextField(_(u'welfare_detail'), blank=True, null=True, help_text=u'福利详情')
|
|
|
739
|
+ welfare_value = models.IntegerField(_(u'welfare_value'), default=0, help_text=_(u'福利数量'))
|
|
|
740
|
+ welfare_image = models.ImageField(_(u'welfare_image'), upload_to=upload_path, blank=True, null=True, help_text=u'福利图片')
|
|
|
741
|
+
|
|
|
742
|
+ is_upload_qiniu = models.BooleanField(_(u'is_upload_qiniu'), default=False, help_text=_(u'是否已上传七牛'))
|
|
|
743
|
+
|
|
|
744
|
+ class Meta:
|
|
|
745
|
+ verbose_name = _(u'会员活动投稿福利信息')
|
|
|
746
|
+ verbose_name_plural = _(u'会员活动投稿福利信息')
|
|
|
747
|
+
|
|
|
748
|
+ def __unicode__(self):
|
|
|
749
|
+ return '%d' % self.pk
|
|
|
750
|
+
|
|
|
751
|
+ @property
|
|
|
752
|
+ def welfare_image_path(self):
|
|
|
753
|
+ return upload_file_path(self.welfare_image)
|
|
|
754
|
+
|
|
|
755
|
+ @property
|
|
|
756
|
+ def welfare_image_url(self):
|
|
|
757
|
+ return qiniu_file_url(self.welfare_image.name, bucket='tamron') if self.is_upload_qiniu else upload_file_url(self.welfare_image)
|
|
|
758
|
+
|
|
|
759
|
+ @property
|
|
|
760
|
+ def data(self):
|
|
|
761
|
+ return {
|
|
|
762
|
+ 'welfare_id': self.welfare_id,
|
|
|
763
|
+ 'welfare_type': self.welfare_type,
|
|
|
764
|
+ 'welfare_type_str': dict(MemberActivityContributionWelfareInfo.WELFARE_TYPE).get(self.welfare_type),
|
|
|
765
|
+ 'welfare_title': self.welfare_title,
|
|
|
766
|
+ 'welfare_detail': self.welfare_detail,
|
|
|
767
|
+ 'welfare_value': self.welfare_value,
|
|
|
768
|
+ 'welfare_image_url': self.welfare_image_url,
|
|
|
769
|
+ 'welfare_image_path': self.welfare_image_path,
|
|
|
770
|
+ }
|