| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 | import jsonimport loggingimport timefrom django.db import transactionfrom django.views.generic.base import Viewfrom Ansjer.config import SERVER_TYPEfrom Model.models import AppSetModel, PromotionRuleModel, PopupsConfig, RedDotsConfig, Device_Info, UidSetModel, \    UserOperationLog, Order_Modelfrom Object.RedisObject import RedisObjectfrom Object.ResponseObject import ResponseObjectfrom Object.TokenObject import TokenObjectfrom Object.utils import LocalDateTimeUtilfrom Service.ModelService import ModelServiceLOGGER = logging.getLogger('info')class AppSetView(View):    def get(self, request, *args, **kwargs):        request.encoding = 'utf-8'        operation = kwargs.get('operation', None)        return self.validation(request.GET, operation)    def post(self, request, *args, **kwargs):        request.encoding = 'utf-8'        operation = kwargs.get('operation', None)        return self.validation(request.POST, operation)    def validation(self, request_dict, operation):        response = ResponseObject()        if operation == 'query':            return self.do_query(request_dict, response)        token = request_dict.get('token', None)        tko = TokenObject(token)        if tko.code != 0:            return response.json(tko.code)        user_id = tko.userID        if operation == 'page_set':  # app弹窗标记红点设置            return self.do_page_set(user_id, request_dict, response)        elif operation == 'ai-preview':            return self.save_user_popups_log(user_id, request_dict, response)        elif operation == 'admin_query':            return self.do_admin_query(user_id, request_dict, response)        elif operation == 'admin_update':            return self.do_admin_update(user_id, request_dict, response)        else:            return response.json(414)    @staticmethod    def do_query(request_dict, response):        """        查询app配置        @param request_dict: 请求数据        @request_dict lang: 语言        @request_dict appBundleId: app包id        @param response: 响应        @return: response        """        lang = request_dict.get('lang', None)        appBundleId = request_dict.get('appBundleId', None)        if not appBundleId:            return response.json(444, 'appBundleId')        app_set_qs = AppSetModel.objects.filter(appBundleId=appBundleId).values('content')        if not app_set_qs.exists():            return response.json(173)        try:            if not app_set_qs[0]['content']:                return response.json(0)            dict_json = json.loads(app_set_qs[0]['content'])            # 加入促销弹窗            promotion = PromotionRuleModel.objects.filter(status=1).values('startTime', 'endTime', 'popups')            if promotion.exists():                dict_json['popupsStartTime'] = promotion[0]['startTime']                dict_json['popupsEndTime'] = promotion[0]['endTime']                dict_json['popupsContent'] = json.loads(promotion[0]['popups']).get(lang, '')                dict_json['nowTime'] = int(time.time())            if 'editionUpgrading' in dict_json:                dict_json['editionUpgrading'] = ''                if dict_json['editionUpgrading'] == 1:                    if lang == 'cn':                        dict_json['editionUpgrading'] = '正在升级,请稍后登录'                    else:                        dict_json['editionUpgrading'] = 'Upgrading, please sign in later'            return response.json(0, dict_json)        except Exception as e:            return response.json(500, '错误行数:{errLine}, 错误信息: {errmsg}'.format(errLine=e.__traceback__.tb_lineno,                                                                              errmsg=repr(e)))    def do_admin_query(self, userID, request_dict, response):        # 查询和添加权限        own_perm = ModelService.check_perm(userID, 40)        if not own_perm:            return response.json(404)        appBundleId = request_dict.get('appBundleId', None)        sm_qs = AppSetModel.objects.filter(appBundleId=appBundleId)        count = sm_qs.count()        nowTime = int(time.time())        if count > 0:            sm_qs = sm_qs.values('id', 'appBundleId', 'content', 'addTime', 'updTime')            return response.json(0, {'data': list(sm_qs), 'count': count})        else:            AppSetModel.objects.create(                appBundleId=appBundleId,                addTime=nowTime,                updTime=nowTime            )            return response.json(0)    def do_admin_update(self, userID, request_dict, response):        # 修改的权限        own_perm = ModelService.check_perm(userID, 50)        if not own_perm:            return response.json(404)        appBundleId = request_dict.get('appBundleId', None)        content = request_dict.get('content', None)        nowTime = int(time.time())        sm_qs = AppSetModel.objects.filter(appBundleId=appBundleId)        redis = RedisObject()        if SERVER_TYPE != "Ansjer.formal_settings":            key_id = "www" + appBundleId        else:            key_id = "test" + appBundleId        redis.del_data(key=key_id)        if sm_qs.exists():            sm_qs.update(content=content, updTime=nowTime)            return response.json(0)        else:            return response.json(173)    @staticmethod    def do_page_set(userID, request_dict, response):        """        初始化加载红点以及弹窗数据        """        try:            lang = request_dict.get('lang', 'en')            dict_json = {}            now_time = int(time.time())            dict_json['popups'] = {                'title': '',                'content': '',                'status': 0,                'tag': 1,            }            with transaction.atomic():                # AI弹窗                dict_json['aiPopups'] = AppSetView.get_ai_init_data(userID, lang)                # 弹窗                popups_obj = PopupsConfig.objects.filter(lang=lang).values('title', 'content', 'start_time', 'end_time',                                                                           'tag')                if popups_obj.exists():                    popups_status = 0                    if popups_obj[0]['start_time'] <= now_time <= popups_obj[0]['end_time']:                        popups_status = 1                    dict_json['popups'] = {                        'title': popups_obj[0]['title'],                        'content': popups_obj[0]['content'],                        'status': popups_status,                        'tag': popups_obj[0]['tag'],                    }                # 红点标记                dict_json['red_dots'] = []                red_dots_obj = RedDotsConfig.objects.values('module', 'start_time', 'end_time')                is_show_red_dots = AppSetView.check_user_is_show_red_dot(userID)  # 是否显示红点                for red_dots in red_dots_obj:                    red_dots_status = 0                    if red_dots['start_time'] <= now_time <= red_dots['end_time']:                        red_dots_status = 1                        ai_detection = red_dots['module']                        if ai_detection == 'ai_detects_purchases':                            red_dots_status = 1 if is_show_red_dots else 0                    dict_json['red_dots'].append({                        'module': red_dots['module'],                        'status': red_dots_status,                    })                dict_json['red_dots'] = list(dict_json['red_dots'])                return response.json(0, dict_json)        except Exception as e:            LOGGER.info('异常详情,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))            return response.json(500)    @staticmethod    def get_ai_init_data(user_id, lang):        """        初始化获取AI弹窗数据        @param user_id: 用户id        @param lang: 语言        @return: popups_qs        """        now_time = int(time.time())        popups_qs = PopupsConfig.objects.filter(tag=2, lang=lang) \            .values('title', 'content', 'start_time', 'end_time', 'tag')        if not popups_qs.exists():            return {}        ai_device = AppSetView.get_user_ai_device(user_id)        if not ai_device:            return {}        # 当前时间小于弹窗开始时间或者大于结束时间 则返回空字符串        if not popups_qs[0]['start_time'] <= now_time <= popups_qs[0]['end_time']:            return {}        user_ai_log_qs = UserOperationLog.objects.filter(user_id=user_id, type=2).values('created_time')        user_log = {'user_id': user_id, 'status': 1, 'type': 2, 'created_time': now_time, 'updated_time': now_time}        popups_status = 0        # 用户有AI设备 没有操作过弹窗则显示        if not user_ai_log_qs.exists():            popups_status = 1            UserOperationLog.objects.create(**user_log)        else:            now_date = int(LocalDateTimeUtil.time_stamp_to_time(now_time, '%Y%m%d'))            created_date = int(LocalDateTimeUtil.time_stamp_to_time(user_ai_log_qs[0]['created_time'], '%Y%m%d'))            if user_ai_log_qs.count() == 1 and now_date > created_date:                popups_status = 1                UserOperationLog.objects.create(**user_log)        return {            'title': popups_qs[0]['title'],            'content': popups_qs[0]['content'],            'status': popups_status,            'tag': popups_qs[0]['tag'],        }    @staticmethod    def get_user_ai_device(user_id):        """        获取用户设备是否有有支持AI功能        @param user_id: 用户ID        @return: True|False        """        device_info = Device_Info.objects.filter(userID_id=user_id, isExist=1).values('UID')        if not device_info.exists():            return False        uid_list = []        for item in device_info:            uid_list.append(item['UID'])        uid_info_qs = UidSetModel.objects.filter(uid__in=uid_list).values('is_ai')        if not uid_info_qs.exists():            return False        if 1 or 0 in uid_info_qs:            return True        return False    @staticmethod    def check_user_is_show_red_dot(user_id):        """        获取用户是否显示红点        用户体验过AI免费套餐不显示 OR 用户操作记录阅读过AI介绍界面不显示        @param user_id: 用户ID        @return: True | False        """        order_qs = Order_Model.objects.filter(userID_id=user_id, order_type=2, status=1, payType=10)        ai_red_dot_qs = UserOperationLog.objects.filter(user_id=user_id, type=4)        return not ai_red_dot_qs.exists() and not order_qs.exists()    @classmethod    def save_user_popups_log(cls, user_id, request_dict, response):        """        保存用户预览AI介绍页面记录        @param request_dict: type        @param user_id: 用户id        @param response: 响应对象        """        try:            rq_type = request_dict.get('type', 0)            now_time = int(time.time())            user_log = {'user_id': user_id, 'status': 1, 'type': int(rq_type), 'created_time': now_time,                        'updated_time': now_time}            UserOperationLog.objects.create(**user_log)        except Exception as e:            LOGGER.info('异常详情,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))            return response.json(500)        return response.json(0)
 |