user.py 9.62 KB
#!/usr/bin/env python
# -*- coding: utf-8 -*-

from django.conf import settings
from django.core.management.base import BaseCommand, CommandError
import traceback
import logging
from libs.es import ESPerform
from django.db import models
import datetime
import time
from libs.tools import tzlc

from .group_user_role import GroupUserRole
from .tag import AccountUserTag
from .topic import Topic
from .user_extra import UserExtra
from .pictorial import PictorialFollow
from .topic import Topic


class User(models.Model):
    class Meta:
        verbose_name = u'用户'
        db_table = 'account_user'

    id = models.IntegerField(verbose_name="主键ID", primary_key=True)
    user_id = models.BigIntegerField(verbose_name=u'用户id', unique=True)
    nick_name = models.CharField(verbose_name=u'昵称', max_length=255, default='')
    profile_pic = models.CharField(verbose_name=u'头像', max_length=300)
    gender = models.SmallIntegerField(verbose_name=u'性别')
    city_id = models.CharField(verbose_name=u'城市id', max_length=60)
    country_id = models.CharField(verbose_name=u'国家id', max_length=40)
    is_online = models.BooleanField(verbose_name="是否上线")
    is_deleted = models.BooleanField(verbose_name='是否删除')
    create_time = models.DateTimeField(verbose_name=u'创建时间', default=datetime.datetime.fromtimestamp(0))
    update_time = models.DateTimeField(verbose_name=u'更新时间', default=datetime.datetime.fromtimestamp(0))

    @classmethod
    def get_user_nick_name(cls, user_id):
        try:
            nick_name = User.objects.using(settings.SLAVE_DB_NAME).filter(user_id=user_id).values_list(
                "nick_name").first()

            return nick_name[0]
        except:
            logging.error("catch exception,err_msg:%s" % traceback.format_exc())
            return ""

    def get_is_recommend_flag(self):
        is_shadow = False
        is_recommend = False
        query_sql = UserExtra.objects.using(settings.SLAVE_DB_NAME).filter(user_id=self.user_id, is_deleted=False,
                                                                           is_online=True)
        for record in query_sql:
            is_recommend = record.is_recommend
            is_shadow = record.is_shadow

        return (is_recommend, is_shadow)

    def get_latest_topic_time_val(self):
        latest_topic_time_val = -1

        # 获取该用户最新发帖时间
        topic_records = Topic.objects.using(settings.SLAVE_DB_NAME).filter(user_id=self.user_id).order_by(
            "-update_time").values_list("update_time",
                                        flat=True).first()
        if topic_records:
            tzlc_topic_update_time = tzlc(topic_records)
            latest_topic_time_val = int(time.mktime(tzlc_topic_update_time.timetuple()))

        return latest_topic_time_val

    def get_follow_user_id_list(self):
        follow_user_id_list = list()
        user_follows = self.userfollow.filter(is_online=True)
        for user_follow in user_follows:
            follow_user_id_list.append(user_follow.follow_id)
        follow_user_detail_list = list()
        logging.info("get follow_user_id_list :%s" % follow_user_id_list)
        for i in range(0, len(follow_user_id_list), 1000):
            logging.info("get follow_user_id_list :%s" % follow_user_id_list[i:i + 1000])
            sql_data_list = User.objects.using(settings.SLAVE_DB_NAME).filter(
                user_id__in=follow_user_id_list[i:i + 1000])
            for detail_data in sql_data_list:
                item = {
                    "user_id": detail_data.user_id,
                    "country_id": detail_data.country_id
                }
                follow_user_detail_list.append(item)

        return follow_user_detail_list

    def get_attention_group_id_list(self):
        try:
            attention_group_id_list = list()
            query_results = GroupUserRole.objects.using(settings.SLAVE_DB_NAME).filter(is_online=True,
                                                                                       user_id=self.user_id)
            for item in query_results:
                item_dict = {
                    "group_id": item.group_id,
                    "update_time_val": time.mktime(tzlc(item.update_time).timetuple())
                }
                attention_group_id_list.append(item_dict)

            return attention_group_id_list
        except:
            logging.error("catch exception,err_msg:%s" % traceback.format_exc())
            return []

    def get_attention_pictorial_id_list(self):
        try:
            attention_pictorial_id_list = list()
            query_results = PictorialFollow.objects.using(settings.SLAVE_DB_NAME).filter(is_online=True,
                                                                                         user_id=self.user_id)
            logging.info("get PictorialFollow:%s" % query_results)
            for item in query_results:
                item_dict = {
                    "pictorial_id": item.pictorial_id,
                    "update_time_val": time.mktime(tzlc(item.update_time).timetuple())
                }
                attention_pictorial_id_list.append(item_dict)
            logging.info("get user_id:%s" % self.user_id)

            logging.info("get same_pictorial_user_id_list:%s" % attention_pictorial_id_list)

            return attention_pictorial_id_list
        except:
            logging.error("catch exception,err_msg:%s" % traceback.format_exc())
            return []

    def get_pick_user_id_list(self):
        pick_topic_id_list = list()
        user_picks = self.user_pick.using(settings.SLAVE_DB_NAME).filter(is_deleted=False, is_pick=True)
        for user_pick in user_picks:
            pick_topic_id_list.append(user_pick.picktopic_id)

        pick_user_id_list = []
        for i in range(0, len(pick_topic_id_list), 1000):
            topic_sql_list = Topic.objects.using(settings.SLAVE_DB_NAME).filter(id__in=pick_topic_id_list[i:i + 1000])
            for topic_data in topic_sql_list:
                pick_user_id_list.append(topic_data.user_id)

        pick_user_id_list = tuple(pick_user_id_list)
        pick_user_detail_list = list()

        for i in range(0, len(pick_user_id_list), 1000):
            sql_data_list = User.objects.using(settings.SLAVE_DB_NAME).filter(user_id__in=pick_user_id_list[i:i + 1000])
            for detail_data in sql_data_list:
                item = {
                    "user_id": detail_data.user_id,
                    "country_id": detail_data.country_id
                }
                pick_user_detail_list.append(item)

        return pick_user_detail_list

    def get_same_pictorial_user_id_list(self):

        # todo 有的同组数据过大,导致celery cpu过高,暂时限制同组的数据大小,后续可能会去掉同组的数据
        same_pictorial_user_id_list = list()
        pictorial_items_list = list(
            PictorialFollow.objects.using(settings.SLAVE_DB_NAME).filter(user_id=self.user_id).values_list(
                "pictorial_id", flat=True))
        for pictorial_id in pictorial_items_list:
            user_items_list = list(
                PictorialFollow.objects.using(settings.SLAVE_DB_NAME).filter(pictorial_id=pictorial_id).values_list(
                    "user_id", flat=True))
            for user_id in user_items_list:
                same_pictorial_user_id_list.append(user_id)
                if len(same_pictorial_user_id_list) >= 100:
                    break
            if len(same_pictorial_user_id_list) >= 100:
                break

        logging.info("get   same  user_id:%s" % self.user_id)
        logging.info("get same_pictorial_user_id_list:%s" % same_pictorial_user_id_list)

        same_pictorial_detail_list = list()
        for i in range(0, len(same_pictorial_user_id_list), 200):
            sql_data_list = User.objects.using(settings.SLAVE_DB_NAME).filter(
                user_id__in=same_pictorial_user_id_list[i:i + 1000])
            for detail_data in sql_data_list:
                item = {
                    "user_id": detail_data.user_id,
                    "country_id": detail_data.country_id
                }
                same_pictorial_detail_list.append(item)

        return same_pictorial_detail_list

    def get_user_tag_id_list(self):
        try:
            user_tag_id_list = list()

            query_results = AccountUserTag.objects.using(settings.SLAVE_DB_NAME).filter(user=self.user_id,
                                                                                        is_deleted=False)
            for item in query_results:
                user_tag_id_list.append(item.tag_id)

            return user_tag_id_list
        except:
            logging.error("catch exception,err_msg:%s" % traceback.format_exc())
            return []

    def get_user_useful_tag_id_list(self):
        try:
            user_useful_tag_id_list = list()

            query_results = AccountUserTag.objects.using(settings.SLAVE_DB_NAME).filter(user=self.user_id,
                                                                                        is_body_esthetics=1,
                                                                                        is_deleted=False)
            for item in query_results:
                user_useful_tag_id_list.append(item.tag_id)

            return user_useful_tag_id_list
        except:
            logging.error("catch exception,err_msg:%s" % traceback.format_exc())
            return []

    def get_topic_number(self):
        try:
            number = Topic.objects.filter(user_id=self.user_id).count()
            return number
        except:
            logging.error("catch exception,err_msg:%s" % traceback.format_exc())
            return 0