| 
					
				 | 
			
			
				@@ -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("自动下架视频任务正常执行") 
			 |