# -*- coding: utf-8 -*- """Generate fs_qw_task_sys_job_seed.sql from original fs-qw-task @Scheduled config.""" from pathlib import Path # (job_name, invoke_target, cron_expression, remark) # cron from git HEAD fs-qw-task before migration to fs-task QW_JOBS = [ ("\u4f01\u5fae-SOP\u89c4\u5219\u68c0\u67e5", "qwTask.qwCheckSopRuleTime()", "0 10 1 * * ?", "\u539f qwTask @Scheduled 0 10 1 * * ?"), ("\u4f01\u5fae-\u5ba2\u6237\u6253\u6807\u7b7e", "qwTask.addTag()", "0 0/20 * * * ?", "\u539f qwTask @Scheduled 0 0/20 * * * ?"), ("\u4f01\u5fae-\u8425\u671f\u751f\u6210SOP\u65e5\u5fd7", "qwTask.selectSopUserLogsListByTime()", "0 5 * * * ?", "\u539f qwTask @Scheduled 0 5 * * * ?"), ("\u4f01\u5fae-\u5fae\u4fe1SOP\u5904\u7406", "qwTask.wxSop()", "0 5 * * * ?", "\u539f qwTask @Scheduled 0 5 * * * ?"), ("\u4f01\u5fae-\u5b98\u65b9\u63a5\u53e3\u7fa4\u53d1(\u5355\u94fe)", "qwTask.SendQwApiSopLogTimer()", "0 20 1 * * ?", "\u539f qwTask @Scheduled 0 20 1 * * ?"), ("\u4f01\u5fae-\u5b98\u65b9\u63a5\u53e3\u7fa4\u53d1(\u65b0\u7248)", "qwTask.SendQwApiSopLogTimerNew()", "0 10 0,1 * * ?", "\u539f qwTask @Scheduled 0 10 0,1 * * ?"), ("\u4f01\u5fae-\u83b7\u53d6\u7fa4\u53d1\u7ed3\u679c", "qwTask.GetQwApiSopLogResultTimerNew()", "0 0 8 * * ?", "\u539f qwTask @Scheduled 0 0 8 * * ?"), ("\u4f01\u5fae-\u5ba2\u6237\u7fa4\u53d1\u5904\u7406", "qwTask.sendQwGroupMsgTask()", "0 0/10 * * * ?", "\u539f qwTask @Scheduled 0 0/10 * * * ?"), ("\u4f01\u5fae-\u53d1\u9001\u8f6c\u6362\u6d88\u606f", "qwTask.sendQwBySop()", "0 0 8 * * ?", "\u539f qwTask @Scheduled 0 0 8 * * ?"), ("\u4f01\u5fae-\u6807\u7b7e\u5907\u6ce8\u8865\u507f", "qwTask.qwExternalErrRetryTimer()", "0 0/3 * * * ?", "\u539f qwTask @Scheduled 0 0/3 * * * ?"), ("\u4f01\u5fae-\u8865\u53d1\u8fc7\u671f\u5b8c\u8bfe\u6d88\u606f", "qwTask.updateQwSopLogsByCancel()", "0 0 * * * ?", "\u539f qwTask @Scheduled 0 0 * * * ?"), ("\u4f01\u5fae-\u6279\u91cf\u5904\u7406\u8fc7\u671f\u6d88\u606f", "qwTask.batchProcessingExpiredMessages()", "0 0/8 * * * ?", "\u539f qwTask @Scheduled 0 0/8 * * * ?"), ("\u4f01\u5fae-\u6e05\u7406\u5386\u53f2SOP\u65e5\u5fd7", "qwTask.deleteQwSopLogsByDate()", "0 10 0 * * ?", "\u539f qwTask @Scheduled 0 10 0 * * ?"), ("\u4f01\u5fae-\u4fee\u590d\u8425\u671f\u5f02\u5e38\u6570\u636e", "qwTask.processRepairQwSopLogsTimer()", "0 30 0/3 * * ?", "\u539f qwTask @Scheduled 0 30 0/3 * * ?"), ("\u4f01\u5fae-E\u7ea7\u672a\u770b\u8bfe\u6062\u590d", "qwTask.processSopUserLogsInfoByIsDaysNotStudy()", "0 35 2 * * ?", "\u539f qwTask @Scheduled 0 35 2 * * ?"), ("\u4f01\u5fae-\u5ba2\u6237\u5206\u7ea7\u8bc4\u7ea7", "qwTask.processQwSopExternalContactRatingTimer()", "0 45 3 * * ?", "\u539f qwTask @Scheduled 0 45 3 * * ?"), ("\u4f01\u5fae-\u8d857\u5929\u672a\u770b\u8bfe\u6807E\u7ea7", "qwTask.processQwSopExternalContactRatingMoreSevenDaysTimer()", "0 30 3 * * ?", "\u539f qwTask @Scheduled 0 30 3 * * ?"), ("\u4f01\u5fae-\u66f4\u65b0\u524d\u4e00\u5929\u5f85\u53d1\u9001", "qwTask.updateQwSopLogsDayBefore()", "0 3 0 * * ?", "\u539f qwTask @Scheduled 0 3 0 * * ?"), ("\u4f01\u5fae-\u540c\u6b65\u5916\u90e8\u8054\u7cfb\u4ebaUnionId", "qwTask.updateQwExternalContactUnionid()", "0 1 0 */2 * ?", "\u539f qwTask @Scheduled 0 1 0 */2 * ?"), ("\u4f01\u5fae-\u81ea\u52a8\u62c9\u4eba\u8fdb\u7fa4", "qwTask.autoPullGroup()", "0 0 16 * * ?", "\u539f qwTask @Scheduled 0 0 16 * * ?"), ("\u770b\u8bfe-\u68c0\u67e5\u770b\u8bfe\u72b6\u6001", "courseWatchLogScheduler.checkWatchStatus()", "0 0/1 * * * ?", "\u539f fixedRate 60000\uff0c\u7528 cron \u8fd1\u4f3c\u6bcf\u5206\u949f"), ("\u770b\u8bfe-\u521b\u5efa\u5b8c\u8bfe\u6d88\u606f", "courseWatchLogScheduler.createCourseFinishMsg()", "0 0/5 * * * ?", "\u539f fixedRate 300000\uff0c\u7528 cron \u8fd1\u4f3c\u6bcf5\u5206\u949f"), ("\u770b\u8bfe-\u5220\u9664\u8fc7\u671f\u77ed\u94fe", "courseWatchLogScheduler.delCourseExpireLink()", "0 0 0 * * ?", "\u539f CourseWatchLogScheduler @Scheduled 0 0 0 * * ?"), ("\u4f01\u5fae-\u540c\u6b65\u4f01\u5fae\u5458\u5de5", "qwUserAsyncTask.syncQwUserAsync()", "0 0 0/3 * * ?", "\u539f QwUserAsyncTask @Scheduled 0 0 0/3 * * ?"), ("\u770b\u8bfe-\u4f1a\u5458\u770b\u8bfe\u7edf\u8ba1", "userCourseWatchCountTask.userCourseCountTask()", "0 */20 * * * ?", "\u539f UserCourseWatchCountTask @Scheduled 0 */20 * * * ?"), ("\u770b\u8bfe-\u5237\u65b0\u8bfe\u7a0b\u914d\u7f6e\u7f13\u5b58", "sopLogsTaskServiceImpl.refreshCourseConfig()", "0 0/1 * * * ?", "\u539f SopLogsTaskServiceImpl fixedDelay 60000"), ("\u4f01\u5fae-\u5237\u65b0\u8bc4\u7ea7\u914d\u7f6e", "qwExternalContactRatingServiceImpl.refreshRatingConfig()", "0 50 0/6 * * ?", "\u539f QwExternalContactRatingServiceImpl @Scheduled"), ("\u4f01\u5fae-\u5237\u65b0\u8d857\u5929\u8bc4\u7ea7\u914d\u7f6e", "qwExternalContactRatingMoreSevenDaysServiceImpl.refreshRatingConfig()", "0 50 0/6 * * ?", "\u539f QwExternalContactRatingMoreSevenDaysServiceImpl @Scheduled"), ] HEADER = ( "-- fs-qw-task \u8fc1\u79fb\u81f3 fs-task \u540e\u7684 sys_job \u79cd\u5b50\u6570\u636e\n" "-- job_group=QW_TASK\uff1bstatus=0 \u542f\u7528\uff0cstatus=1 \u6682\u505c\uff08\u9ed8\u8ba4\u6682\u505c\uff09\n" "-- invoke_target \u987b\u4e0e fs-task \u6a21\u5757 Spring Bean \u65b9\u6cd5\u4e00\u81f4\n\n" ) def render_job(job_name, invoke_target, cron, remark): return ( "INSERT INTO sys_job (job_name, job_group, invoke_target, cron_expression, misfire_policy, concurrent, status, create_by, create_time, remark)\n" f"SELECT '{job_name}', 'QW_TASK', '{invoke_target}', '{cron}', '3', '1', '1', 'admin', NOW(), '{remark}'\n" f"WHERE NOT EXISTS (SELECT 1 FROM sys_job WHERE invoke_target = '{invoke_target}');\n" ) def main(): lines = [HEADER] for job in QW_JOBS: lines.append(render_job(*job)) lines.append("\n") lines.append( "-- \u5907\u6ce8\uff1aselectChatSopUserLogsListByTime \u539f @Scheduled \u5df2\u6ce8\u91ca\uff0c\u672a\u5199\u5165\n" "-- \u5907\u6ce8\uff1acheckFsUserWatchStatus(fixedRate 30s) \u672a\u8fc1\u79fb\u81f3 fs-task\uff0c\u672a\u5199\u5165\n" ) out = Path(__file__).resolve().parent / "fs_qw_task_sys_job_seed.sql" out.write_text("".join(lines), encoding="utf-8") print("OK", out, "jobs=", len(QW_JOBS)) if __name__ == "__main__": main()