|  | @@ -0,0 +1,194 @@
 | 
	
		
			
				|  |  | +"""
 | 
	
		
			
				|  |  | +@author: luojunhui
 | 
	
		
			
				|  |  | +@description: GetOffVideos Daily
 | 
	
		
			
				|  |  | +"""
 | 
	
		
			
				|  |  | +import json
 | 
	
		
			
				|  |  | +import time
 | 
	
		
			
				|  |  | +from concurrent.futures.thread import ThreadPoolExecutor
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +import requests
 | 
	
		
			
				|  |  | +import schedule
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +from applications import PQMySQL, Functions
 | 
	
		
			
				|  |  | +from applications.decoratorApi import retryOnTimeout
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +@retryOnTimeout()
 | 
	
		
			
				|  |  | +def bot(account_list):
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    机器人
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    url = "https://open.feishu.cn/open-apis/bot/v2/hook/b44333f2-16c0-4cb1-af01-d135f8704410"
 | 
	
		
			
				|  |  | +    headers = {"Content-Type": "application/json"}
 | 
	
		
			
				|  |  | +    payload = {
 | 
	
		
			
				|  |  | +        "msg_type": "interactive",
 | 
	
		
			
				|  |  | +        "card": {
 | 
	
		
			
				|  |  | +            "elements": [
 | 
	
		
			
				|  |  | +                {
 | 
	
		
			
				|  |  | +                    "tag": "div",
 | 
	
		
			
				|  |  | +                    "text": {
 | 
	
		
			
				|  |  | +                        "content": "存在视频下架失败<at id=all></at>\n",
 | 
	
		
			
				|  |  | +                        "tag": "lark_md",
 | 
	
		
			
				|  |  | +                    },
 | 
	
		
			
				|  |  | +                },
 | 
	
		
			
				|  |  | +                {
 | 
	
		
			
				|  |  | +                    "tag": "div",
 | 
	
		
			
				|  |  | +                    "text": {
 | 
	
		
			
				|  |  | +                        "content": json.dumps(
 | 
	
		
			
				|  |  | +                            account_list, ensure_ascii=False, indent=4
 | 
	
		
			
				|  |  | +                        ),
 | 
	
		
			
				|  |  | +                        "tag": "lark_md",
 | 
	
		
			
				|  |  | +                    },
 | 
	
		
			
				|  |  | +                },
 | 
	
		
			
				|  |  | +            ],
 | 
	
		
			
				|  |  | +            "header": {"title": {"content": "【重点关注】", "tag": "plain_text"}},
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +    requests.request("POST", url=url, headers=headers, data=json.dumps(payload), timeout=10)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +class AutoGetOffVideos(object):
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    自动下架视频
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    pqMysql = PQMySQL()
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @classmethod
 | 
	
		
			
				|  |  | +    def getLongArticlesVideos(cls, time_stamp):
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        获取待下架的视频
 | 
	
		
			
				|  |  | +        :return:
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        select_sql = f"""
 | 
	
		
			
				|  |  | +        SELECT video_id
 | 
	
		
			
				|  |  | +        FROM get_off_videos
 | 
	
		
			
				|  |  | +        WHERE video_status = 1 and publish_time < {time_stamp};
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        result = cls.pqMysql.select(sql=select_sql)
 | 
	
		
			
				|  |  | +        return result
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @classmethod
 | 
	
		
			
				|  |  | +    def updateVideoIdStatus(cls, video_id):
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        修改数据库内视频状态
 | 
	
		
			
				|  |  | +        :param video_id:
 | 
	
		
			
				|  |  | +        :return:
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        time_stamp = int(time.time())
 | 
	
		
			
				|  |  | +        select_sql = f"""
 | 
	
		
			
				|  |  | +                UPDATE get_off_videos
 | 
	
		
			
				|  |  | +                SET video_status = 0, get_off_time = {time_stamp}
 | 
	
		
			
				|  |  | +                WHERE video_id = %s;
 | 
	
		
			
				|  |  | +                """
 | 
	
		
			
				|  |  | +        cls.pqMysql.update(
 | 
	
		
			
				|  |  | +            sql=select_sql,
 | 
	
		
			
				|  |  | +            params=video_id
 | 
	
		
			
				|  |  | +        )
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @classmethod
 | 
	
		
			
				|  |  | +    def changeVideoIdStatus(cls, video_id):
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        修改视频规则
 | 
	
		
			
				|  |  | +        :return:
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        url = "https://admin.piaoquantv.com/manager/video/audit/v2/updateAuditStatus"
 | 
	
		
			
				|  |  | +        payload = "videoId={}&auditStatus=2&updateReasonJson=&rejectReasonJson=%5B%7B%22reason%22%3A%22%E9%95%BF%E6%96%87%E8%87%AA%E5%8A%A8%E4%B8%8B%E6%9E%B6%22%2C%22reasonId%22%3A-1%7D%5D&adminUid=206".format(
 | 
	
		
			
				|  |  | +            video_id)
 | 
	
		
			
				|  |  | +        headers = {
 | 
	
		
			
				|  |  | +            'accept': 'application/json',
 | 
	
		
			
				|  |  | +            'accept-language': 'en,zh;q=0.9,zh-CN;q=0.8',
 | 
	
		
			
				|  |  | +            'content-type': 'application/x-www-form-urlencoded;charset=UTF-8',
 | 
	
		
			
				|  |  | +            'cookie': 'SESSION=NTljNTg2YjktMTU0MC00YWQ5LWE4ZTktNDFhODY0NzM3NTcx',
 | 
	
		
			
				|  |  | +            'origin': 'https://admin.piaoquantv.com',
 | 
	
		
			
				|  |  | +            'priority': 'u=1, i',
 | 
	
		
			
				|  |  | +            'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Google Chrome";v="126"',
 | 
	
		
			
				|  |  | +            'sec-ch-ua-mobile': '?0',
 | 
	
		
			
				|  |  | +            'sec-ch-ua-platform': '"macOS"',
 | 
	
		
			
				|  |  | +            'sec-fetch-dest': 'empty',
 | 
	
		
			
				|  |  | +            'sec-fetch-mode': 'cors',
 | 
	
		
			
				|  |  | +            'sec-fetch-site': 'same-origin',
 | 
	
		
			
				|  |  | +            'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36'
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        response = requests.request(
 | 
	
		
			
				|  |  | +            "POST",
 | 
	
		
			
				|  |  | +            url,
 | 
	
		
			
				|  |  | +            headers=headers,
 | 
	
		
			
				|  |  | +            data=payload
 | 
	
		
			
				|  |  | +        )
 | 
	
		
			
				|  |  | +        if response.status_code == 2:
 | 
	
		
			
				|  |  | +            result = response.json()
 | 
	
		
			
				|  |  | +            if result.get("code", None) == 0:
 | 
	
		
			
				|  |  | +                cls.updateVideoIdStatus(video_id=video_id)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @classmethod
 | 
	
		
			
				|  |  | +    def task1(cls):
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        已经请求超过3天的视频全部下架
 | 
	
		
			
				|  |  | +        :return:
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        now_stamp = int(time.time())
 | 
	
		
			
				|  |  | +        three_days_before = now_stamp - 3 * 24 * 60 * 60
 | 
	
		
			
				|  |  | +        video_set = cls.getLongArticlesVideos(time_stamp=three_days_before)
 | 
	
		
			
				|  |  | +        vid_list = [i[0] for i in video_set]
 | 
	
		
			
				|  |  | +        with ThreadPoolExecutor(max_workers=8) as Pool1:
 | 
	
		
			
				|  |  | +            Pool1.map(cls.changeVideoIdStatus, vid_list)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @classmethod
 | 
	
		
			
				|  |  | +    def task2(cls):
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        校验 3 天前发布的视频是否已经下架
 | 
	
		
			
				|  |  | +        :return:
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        three_days_ago = int(time.time()) - 3 * 24 * 3600
 | 
	
		
			
				|  |  | +        sql = f"""
 | 
	
		
			
				|  |  | +        SELECT video_id
 | 
	
		
			
				|  |  | +        FROM get_off_videos
 | 
	
		
			
				|  |  | +        WHERE publish_time < {three_days_ago} and video_status = 1;
 | 
	
		
			
				|  |  | +        """
 | 
	
		
			
				|  |  | +        vid_tuple = cls.pqMysql.select(sql)
 | 
	
		
			
				|  |  | +        if vid_tuple:
 | 
	
		
			
				|  |  | +            vid_list = [i[0] for i in vid_tuple]
 | 
	
		
			
				|  |  | +            with ThreadPoolExecutor(max_workers=8) as Pool1:
 | 
	
		
			
				|  |  | +                Pool1.map(cls.changeVideoIdStatus, vid_list)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            vid_tuple2 = cls.pqMysql.select(sql)
 | 
	
		
			
				|  |  | +            if vid_tuple2:
 | 
	
		
			
				|  |  | +                vid_list2 = [i[0] for i in vid_tuple2]
 | 
	
		
			
				|  |  | +                bot(vid_list2)
 | 
	
		
			
				|  |  | +            else:
 | 
	
		
			
				|  |  | +                return
 | 
	
		
			
				|  |  | +        else:
 | 
	
		
			
				|  |  | +            return
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +def getOffJob():
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    下架任务
 | 
	
		
			
				|  |  | +    :return:
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    AGV = AutoGetOffVideos()
 | 
	
		
			
				|  |  | +    AGV.task1()
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +def checkJob():
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    校验 3 天前发布的视频是否已经被下架
 | 
	
		
			
				|  |  | +    :return:
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    AGV = AutoGetOffVideos()
 | 
	
		
			
				|  |  | +    AGV.task2()
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +if __name__ == '__main__':
 | 
	
		
			
				|  |  | +    schedule.every().day.at("09:30").do(Functions().job_with_thread, getOffJob)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    schedule.every().day.at("10:30").do(Functions().job_with_thread, checkJob)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    schedule.every().day.at("14:30").do(Functions().job_with_thread, getOffJob)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    schedule.every().day.at("15:00").do(Functions().job_with_thread, checkJob)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    while True:
 | 
	
		
			
				|  |  | +        schedule.run_pending()
 | 
	
		
			
				|  |  | +        time.sleep(1)
 | 
	
		
			
				|  |  | +        print("自动下架视频任务正常执行")
 |