""" @author: luojunhui @description: GetOffVideos Daily """ import json import time import requests import schedule from tqdm import tqdm from applications import PQMySQL, Functions, log 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": "存在视频下架失败\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) log( task="getOffVideosDaily", function="getLongArticlesVideos", message="查找到视频 id_list,一共{}条视频".format(len(result)) ) 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; """ try: cls.pqMysql.update( sql=select_sql, params=video_id ) log( task="getOffVideosDaily", function="updateVideoIdStatus", message="成功修改视频状态", data={"video_id": video_id} ) except Exception as e: log( task="getOffVideosDaily", function="updateVideoIdStatus", message="修改视频状态失败--- 推测 sql 问题,报错信息:{}".format(e), status="fail" ) @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, timeout=10 ) if response.status_code == 200: result = response.json() if result.get("code", None) == 0: cls.updateVideoIdStatus(video_id=video_id) else: log( task="getOffVideosDaily", function="changeVideoIdStatus", message="请求票圈修改状态异常---video_id = {}".format(video_id), data=result ) else: log( task="getOffVideosDaily", function="changeVideoIdStatus", status="fail", message="请求票圈修改状态异常,状态码非 200 ---video_id = {}".format(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] for video_id in tqdm(vid_list): try: cls.changeVideoIdStatus(video_id=video_id) except Exception as e: log( task="getOffVideosDaily", function="task1", status="fail", message="task1下架单个视频失败,video_id={}, 报错信息={}".format(video_id, e), ) @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] for vid in vid_list: try: cls.changeVideoIdStatus(video_id=vid) except Exception as e: log( task="getOffVideosDaily", function="task2", status="fail", message="task2下架单个视频失败,video_id={}, 报错信息={}".format(vid, e), ) time.sleep(10) 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(0.5) # log( # task="getOffVideos", # function="main", # message="自动下架视频任务正常执行" # )