| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 | # -*- encoding: utf-8 -*-"""@File    : CloudServiceController.py@Time    : 2022/12/8 10:23@Author  : stephen@Email   : zhangdongming@asj6.wecom.work@Software: PyCharm"""import jsonimport timefrom django.views import Viewfrom Ansjer.config import LOGGERfrom Model.models import CouponCombo, CouponModelfrom Object.Enums.RedisKeyConstant import RedisKeyConstantfrom Object.RedisObject import RedisObjectfrom Object.ResponseObject import ResponseObjectfrom Object.TokenObject import TokenObjectclass CloudServiceController(View):    def get(self, request, *args, **kwargs):        request.encoding = 'utf-8'        operation = kwargs.get('operation')        return self.validation(request.GET, request, operation)    def post(self, request, *args, **kwargs):        request.encoding = 'utf-8'        operation = kwargs.get('operation')        return self.validation(request.POST, request, operation)    def validation(self, request_dict, request, operation):        token = TokenObject(request.META.get('HTTP_AUTHORIZATION'))        lang = request_dict.get('lang', token.lang)        response = ResponseObject(lang)        if token.code != 0:            return response.json(token.code)        user_id = token.userID        if operation == 'save-photo':            return self.get_combo_list_by_coupon(user_id, response)        else:            return response.json(404)    @classmethod    def get_combo_list_by_coupon(cls, request_dict, response):        """        根据优惠券获取套餐列表        @param request_dict: couponId 优惠券ID        @param request_dict: couponType 优惠券类型        @param response: 响应结果        """        coupon_id = int(request_dict.get('couponId', 0))        coupon_type = int(request_dict.get('couponType', 0))        if coupon_id == 0:            return response.json(444)        coupon_combo_qs = CouponCombo.objects.filter(coupon_type=coupon_type, coupon_id=coupon_id).values('combo_id')        combo_list = []        if not coupon_combo_qs.exists():            return combo_list        for item in coupon_combo_qs:            combo_list.append(item['combo_id'])        return combo_list    @classmethod    def get_user_coupon_list(cls, user_id):        """        获取用户未使用优惠券配置ID列表        @param user_id: 用户id        @return: coupon_ids 列表,可能为空                  如果没有未使用的优惠券,返回空列表 []        """        try:            now_time = int(time.time())            coupon_conf_ids = CouponModel.objects.filter(                userID=user_id,                use_status=0,                distribute_time__lte=now_time,                valid_time__gt=now_time            ).values_list('coupon_config__id', flat=True)  # 使用 values_list 获取 ID 列表            return list(coupon_conf_ids)  # 可能为空        except Exception as e:            LOGGER.error('获取用户优惠券异常:userID:{}, error_line:{}, error_msg:{}'                         .format(user_id, e.__traceback__.tb_lineno, repr(e)))            return []    @classmethod    def get_combo_list(cls, coupon_type, coupon_id):        """        根据优惠券类型与优惠券ID,获取关联套餐列表        :param coupon_type: 优惠券类型        :param coupon_id: 优惠券ID        :return: 关联的套餐ID列表        """        try:            redis_obj = RedisObject()  # 创建 Redis 对象以访问缓存            # 构建 Redis 缓存键            conf_key = f'{RedisKeyConstant.BASIC_CLOUD_COUPON.value}{coupon_type}:{coupon_id}'            # 尝试从 Redis 获取数据            conf_data = redis_obj.get_data(conf_key)            if conf_data:  # 如果缓存中存在数据,则直接返回                return json.loads(conf_data)                # 从数据库中查询关联的套餐ID            combo_qs = CouponCombo.objects.filter(coupon_type=coupon_type, coupon_id=coupon_id).values('combo_id')            # 初始化套餐ID列表            combo_list = []            if combo_qs.exists():  # 检查查询集是否存在数据                for item in combo_qs:                    combo_list.append(item['combo_id'])  # 逐个添加套餐ID            # 将查询结果存入 Redis 缓存            redis_obj.set_data(conf_key, json.dumps(combo_list), expire=RedisKeyConstant.EXPIRE_TIME_24_HOURS)            return combo_list  # 返回套餐ID列表        except Exception as e:            # 记录异常信息和相关上下文            LOGGER.error('获取优惠券套餐异常: couponID: {}, error_line: {}, error_msg: {}'                         .format(coupon_id, e.__traceback__.tb_lineno, repr(e)))            return []  # 返回空列表以表示失败    @classmethod    def get_coupon_list(cls, coupon_type, combo_id):        """        根据优惠券类型与套餐ID,获取关联优惠券列表        @param coupon_type: 优惠券类型        @param combo_id: 套餐id        @return: coupon_list        """        coupon_combo_qs = CouponCombo.objects.filter(coupon_type=coupon_type, combo_id=combo_id) \            .values('coupon_id')        coupon_list = []        if not coupon_combo_qs.exists():            return coupon_list        for item in coupon_combo_qs:            coupon_list.append(item['coupon_id'])        return coupon_list
 |