|
@@ -13,7 +13,8 @@ from django.views import View
|
|
|
|
|
|
from Ansjer.config import LOGGER
|
|
|
from Controller.UnicomCombo.UnicomComboController import UnicomComboView
|
|
|
-from Model.models import UnicomDeviceInfo, Order_Model, UnicomComboExperienceHistory, UnicomCombo
|
|
|
+from Model.models import UnicomDeviceInfo, Order_Model, UnicomComboExperienceHistory, UnicomCombo, ExchangeCode, \
|
|
|
+ LogModel
|
|
|
from Object.Enums.WXOperatorEnum import WXOperatorEnum
|
|
|
from Object.Enums.WXStartTypeEnum import WXStartTypeEnum
|
|
|
from Object.ResponseObject import ResponseObject
|
|
@@ -53,6 +54,8 @@ class WXTechController(View):
|
|
|
def validation(self, request_dict, request, operation):
|
|
|
if operation == 'deleteCardPackage':
|
|
|
return self.delete_card_package(request_dict, ResponseObject('cn'))
|
|
|
+ elif operation == 'packageRefund':
|
|
|
+ return self.wx_package_refund(request_dict, ResponseObject('cn'))
|
|
|
token_code, user_id, response = CommonService \
|
|
|
.verify_token_get_user_id(request_dict, request)
|
|
|
if token_code != 0:
|
|
@@ -63,6 +66,38 @@ class WXTechController(View):
|
|
|
return self.get_experience_package(request_dict, response)
|
|
|
elif operation == 'createOrder':
|
|
|
return self.create_order_package(request_dict, response)
|
|
|
+ elif operation == 'exchangePackage':
|
|
|
+ return self.wx_exchange_package(request_dict, response, request, user_id)
|
|
|
+
|
|
|
+ @classmethod
|
|
|
+ def wx_package_refund(cls, request_dict, response):
|
|
|
+ """
|
|
|
+ 五兴套餐退订
|
|
|
+ """
|
|
|
+ try:
|
|
|
+ serial_number = request_dict.get('serialNumber', None)
|
|
|
+ if not serial_number:
|
|
|
+ return response(444)
|
|
|
+ device_qs = UnicomDeviceInfo.objects.filter(serial_no=serial_number).values('iccid')
|
|
|
+ if not device_qs.exists():
|
|
|
+ return response(173)
|
|
|
+ uid = CommonService.query_uid_with_serial(serial_number)
|
|
|
+ order_info_qs = Order_Model.objects.filter(UID=uid, order_type=3).values('trade_no') \
|
|
|
+ .order_by('-payTime')
|
|
|
+ if not order_info_qs.exists():
|
|
|
+ return response(173)
|
|
|
+ iccid = device_qs[0]['iccid']
|
|
|
+ trade_no = order_info_qs[0]['trade_no']
|
|
|
+ data = {'iccid': iccid, 'operator': 3, 'orderNumber': trade_no}
|
|
|
+ wx_tech = WXTechObject()
|
|
|
+ res = wx_tech.package_refund(**data)
|
|
|
+ if res['code'] == '0':
|
|
|
+ return response.json(0)
|
|
|
+ return response.json(10059)
|
|
|
+ except Exception as e:
|
|
|
+ LOGGER.info('*****WXTechController.get_cards_info:errLine:{}, errMsg:{}'
|
|
|
+ .format(e.__traceback__.tb_lineno, repr(e)))
|
|
|
+ return response.json(500, repr(e))
|
|
|
|
|
|
@classmethod
|
|
|
def get_cards_info(cls, request_dict, response):
|
|
@@ -157,12 +192,17 @@ class WXTechController(View):
|
|
|
return response.json(500, repr(e))
|
|
|
|
|
|
@classmethod
|
|
|
- def created_order(cls, serial_no, user_id, trade_no):
|
|
|
+ def created_order(cls, serial_no, user_id, trade_no, combo_id=None):
|
|
|
"""
|
|
|
创建系统订单
|
|
|
"""
|
|
|
- combo_info_qs = UnicomCombo.objects.filter(combo_type=1, status=0, is_del=False) \
|
|
|
- .values('id', 'combo_name', 'price', 'virtual_price', 'remark').order_by('sort')
|
|
|
+ combo_info_qs = UnicomCombo.objects.filter(is_del=False)
|
|
|
+ if combo_id:
|
|
|
+ combo_info_qs = combo_info_qs.filter(id=int(combo_id))
|
|
|
+ else:
|
|
|
+ combo_info_qs = combo_info_qs.filter(combo_type=1, status=0)
|
|
|
+ combo_info_qs = combo_info_qs.values('id', 'combo_name', 'price', 'virtual_price', 'remark') \
|
|
|
+ .order_by('sort')
|
|
|
if not combo_info_qs.exists():
|
|
|
return False
|
|
|
combo_info_vo = combo_info_qs[0]
|
|
@@ -211,3 +251,82 @@ class WXTechController(View):
|
|
|
LOGGER.info('*****WXTechController.delete_card_package:errLine:{}, errMsg:{}'
|
|
|
.format(e.__traceback__.tb_lineno, repr(e)))
|
|
|
return response.json(500, repr(e))
|
|
|
+
|
|
|
+ @classmethod
|
|
|
+ def wx_exchange_package(cls, request_dict, response, request, user_id):
|
|
|
+ """
|
|
|
+ 使用兑换码订购五兴五年流量套餐包
|
|
|
+ """
|
|
|
+ ip = CommonService.get_ip_address(request)
|
|
|
+ try:
|
|
|
+ code = request_dict.get('code')
|
|
|
+ serial_number = request_dict.get('serialNumber')
|
|
|
+ LOGGER.info('*****WXTechController.wx_exchange_package:params,{}'.format(request_dict))
|
|
|
+ if not all([code, serial_number]):
|
|
|
+ return response.json(444) # 参数缺失
|
|
|
+ # 校验兑换码格式是否正确
|
|
|
+ if not (code.isalnum() and len(code) == 10):
|
|
|
+ return response.json(10040) # 兑换码格式错误
|
|
|
+ card_type = 1
|
|
|
+ device_info_qs = UnicomDeviceInfo.objects.filter(serial_no=serial_number, card_type=card_type) \
|
|
|
+ .values('iccid')
|
|
|
+ if not device_info_qs.exists():
|
|
|
+ return response.json(173) # 设备信息不存在
|
|
|
+ # 查询兑换码信息
|
|
|
+ exchange_code_qs = ExchangeCode.objects.filter(code=code, status=False, package_type=card_type) \
|
|
|
+ .values('package_id', 'expire_time')
|
|
|
+ if not exchange_code_qs.exists():
|
|
|
+ return response.json(10040) # 兑换码无效
|
|
|
+ combo_id = exchange_code_qs[0]['package_id']
|
|
|
+ # 获取五兴套餐套餐编码
|
|
|
+ package_info_qs = UnicomCombo.objects.filter(id=combo_id, is_del=False) \
|
|
|
+ .values('package_id')
|
|
|
+ if not package_info_qs.exists():
|
|
|
+ return response.json(173)
|
|
|
+ package_code = package_info_qs[0]['package_id']
|
|
|
+ iccid = device_info_qs[0]['iccid']
|
|
|
+ # 五兴订购流量包请求参数
|
|
|
+ data = {'iccid': iccid, 'operator': WXOperatorEnum.TELECOM.value,
|
|
|
+ 'startType': str(WXStartTypeEnum.EFFECTIVE_IMMEDIATELY.value), 'packageCode': package_code}
|
|
|
+ wx_tech = WXTechObject()
|
|
|
+ # 请求五兴API订购套餐接口
|
|
|
+ res = wx_tech.create_order_package(**data)
|
|
|
+ LOGGER.info('*****五兴订购年卡套餐结果:{}'.format(res))
|
|
|
+ if res['code'] == '0':
|
|
|
+ trade_no = res['data']['orderNumber']
|
|
|
+ cls.created_order(serial_number, user_id, trade_no, combo_id)
|
|
|
+ exchange_code_qs.update(status=True, updated_time=int(time.time()))
|
|
|
+ cls.save_log(ip, 200, '兑换成功{},{}'.format(serial_number, code))
|
|
|
+ return response.json(0)
|
|
|
+ cls.save_log(ip, 10040, '兑换失败{},{}'.format(serial_number, code))
|
|
|
+ return response.json(10040)
|
|
|
+ except Exception as e:
|
|
|
+ LOGGER.info('*****WXTechController.wx_exchange_package:errLine:{}, errMsg:{}'
|
|
|
+ .format(e.__traceback__.tb_lineno, repr(e)))
|
|
|
+ cls.save_log(ip, 500, '兑换内部错误')
|
|
|
+ return response.json(500, repr(e))
|
|
|
+
|
|
|
+ @staticmethod
|
|
|
+ def save_log(ip, code, operation):
|
|
|
+ """
|
|
|
+ 保存操作日志
|
|
|
+ @param ip: ip地址
|
|
|
+ @param code: 状态码
|
|
|
+ @param operation: 操作说明
|
|
|
+ @return: 保存结果
|
|
|
+ """
|
|
|
+ try:
|
|
|
+ log = {
|
|
|
+ 'ip': ip,
|
|
|
+ 'user_id': 1,
|
|
|
+ 'status': code,
|
|
|
+ 'time': int(time.time()),
|
|
|
+ 'operation': operation,
|
|
|
+ 'url': 'unicom/open/wxtech/exchangePackage',
|
|
|
+ }
|
|
|
+ LogModel.objects.create(**log)
|
|
|
+ return True
|
|
|
+ except Exception as e:
|
|
|
+ LOGGER.info('*****WXTechController.save_log:errLine:{}, errMsg:{}'
|
|
|
+ .format(e.__traceback__.tb_lineno, repr(e)))
|
|
|
+ return False
|