mirror of
				https://github.com/whyour/qinglong.git
				synced 2025-10-25 05:16:06 +08:00 
			
		
		
		
	webhook 通知 body 增加 text/plain 类型,修复多定时任务服务重启未初始化
This commit is contained in:
		
							parent
							
								
									f056b611a4
								
							
						
					
					
						commit
						de9e9ce627
					
				|  | @ -61,7 +61,8 @@ export async function getNetIp(req: any) { | |||
|       ...req.ips, | ||||
|       req.socket.remoteAddress, | ||||
|     ]), | ||||
|   ]; | ||||
|   ].filter(Boolean); | ||||
| 
 | ||||
|   let ip = ipArray[0]; | ||||
| 
 | ||||
|   if (ipArray.length > 1) { | ||||
|  | @ -82,6 +83,7 @@ export async function getNetIp(req: any) { | |||
|       break; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   ip = ip.substr(ip.lastIndexOf(':') + 1, ip.length); | ||||
|   if (ip.includes('127.0') || ip.includes('192.168') || ip.includes('10.7')) { | ||||
|     ip = ''; | ||||
|  | @ -347,9 +349,12 @@ export function parseBody( | |||
|   contentType: | ||||
|     | 'application/json' | ||||
|     | 'multipart/form-data' | ||||
|     | 'application/x-www-form-urlencoded', | ||||
|     | 'application/x-www-form-urlencoded' | ||||
|     | 'text/plain', | ||||
| ) { | ||||
|   if (!body) return ''; | ||||
|   if (contentType === 'text/plain' || !body) { | ||||
|     return body; | ||||
|   } | ||||
| 
 | ||||
|   const parsed: any = {}; | ||||
|   let key; | ||||
|  |  | |||
|  | @ -26,9 +26,9 @@ import omit from 'lodash/omit'; | |||
| export default class CronService { | ||||
|   constructor(@Inject('logger') private logger: winston.Logger) {} | ||||
| 
 | ||||
|   private isSixCron(cron: Crontab) { | ||||
|     const { schedule } = cron; | ||||
|     if (Number(schedule?.split(/ +/).length) > 5) { | ||||
|   private isNodeCron(cron: Crontab) { | ||||
|     const { schedule, extra_schedules } = cron; | ||||
|     if (Number(schedule?.split(/ +/).length) > 5 || extra_schedules?.length) { | ||||
|       return true; | ||||
|     } | ||||
|     return false; | ||||
|  | @ -38,7 +38,7 @@ export default class CronService { | |||
|     const tab = new Crontab(payload); | ||||
|     tab.saved = false; | ||||
|     const doc = await this.insert(tab); | ||||
|     if (this.isSixCron(doc) || doc.extra_schedules?.length) { | ||||
|     if (this.isNodeCron(doc)) { | ||||
|       await cronClient.addCron([ | ||||
|         { | ||||
|           name: doc.name || '', | ||||
|  | @ -65,10 +65,10 @@ export default class CronService { | |||
|     if (doc.isDisabled === 1) { | ||||
|       return newDoc; | ||||
|     } | ||||
|     if (this.isSixCron(doc) || doc.extra_schedules?.length) { | ||||
|     if (this.isNodeCron(doc)) { | ||||
|       await cronClient.delCron([String(doc.id)]); | ||||
|     } | ||||
|     if (this.isSixCron(newDoc) || newDoc.extra_schedules?.length) { | ||||
|     if (this.isNodeCron(newDoc)) { | ||||
|       await cronClient.addCron([ | ||||
|         { | ||||
|           name: doc.name || '', | ||||
|  | @ -472,7 +472,7 @@ export default class CronService { | |||
|     await CrontabModel.update({ isDisabled: 0 }, { where: { id: ids } }); | ||||
|     const docs = await CrontabModel.findAll({ where: { id: ids } }); | ||||
|     const sixCron = docs | ||||
|       .filter((x) => this.isSixCron(x)) | ||||
|       .filter((x) => this.isNodeCron(x)) | ||||
|       .map((doc) => ({ | ||||
|         name: doc.name || '', | ||||
|         id: String(doc.id), | ||||
|  | @ -613,7 +613,7 @@ export default class CronService { | |||
|     this.set_crontab(tabs); | ||||
| 
 | ||||
|     const sixCron = tabs.data | ||||
|       .filter((x) => this.isSixCron(x) && x.isDisabled !== 1) | ||||
|       .filter((x) => this.isNodeCron(x) && x.isDisabled !== 1) | ||||
|       .map((doc) => ({ | ||||
|         name: doc.name || '', | ||||
|         id: String(doc.id), | ||||
|  |  | |||
|  | @ -659,9 +659,11 @@ export default class NotificationService { | |||
|       webhookUrl, | ||||
|       webhookBody, | ||||
|     ); | ||||
| 
 | ||||
|     if (!formatUrl && !formatBody) { | ||||
|       return false; | ||||
|       throw new Error('Url 或者 Body 中必须包含 $title') | ||||
|     } | ||||
| 
 | ||||
|     const headers = parseHeaders(webhookHeaders); | ||||
|     const body = parseBody(formatBody, webhookContentType); | ||||
|     const bodyParam = this.formatBody(webhookContentType, body); | ||||
|  | @ -692,6 +694,7 @@ export default class NotificationService { | |||
|       case 'multipart/form-data': | ||||
|         return { form: body }; | ||||
|       case 'application/x-www-form-urlencoded': | ||||
|       case 'text/plain': | ||||
|         return { body }; | ||||
|     } | ||||
|     return {}; | ||||
|  |  | |||
|  | @ -21,8 +21,7 @@ DiskWarn=90 | |||
| ## 设置定时任务执行的超时时间,例如1h,后缀"s"代表秒(默认值), "m"代表分, "h"代表小时, "d"代表天 | ||||
| CommandTimeoutTime="" | ||||
| 
 | ||||
| ## 在运行 task 命令时,随机延迟启动任务的最大延迟时间 | ||||
| ## 默认给javascript任务加随机延迟,如 RandomDelay="300" ,表示任务将在 1-300 秒内随机延迟一个秒数,然后再运行,取消延迟赋值为空 | ||||
| ## 在运行 task 命令时,随机延迟启动任务的最大延迟时间,如 RandomDelay="300" ,表示任务将在 1-300 秒内随机延迟一个秒数,然后再运行,取消延迟赋值为空 | ||||
| RandomDelay="" | ||||
| 
 | ||||
| ## 需要随机延迟运行任务的文件后缀,直接写后缀名即可,多个后缀用空格分开,例如: js py ts | ||||
|  | @ -33,8 +32,8 @@ RandomDelayFileExtensions="" | |||
| ## 默认是第0分钟和第30分钟,例如21:00或21:30分的任务将会准点运行。不需要准点运行赋值为空 | ||||
| RandomDelayIgnoredMinutes="" | ||||
| 
 | ||||
| ## 如果你自己会写shell脚本,并且希望在每次运行 ql update 命令时,额外运行你的 shell 脚本,请赋值为 "true",默认为true | ||||
| EnableExtraShell="true" | ||||
| ## 如果你自己会写shell脚本,并且希望在每次容器启动时,额外运行你的 shell 脚本,请赋值为 "true" | ||||
| EnableExtraShell="" | ||||
| 
 | ||||
| ## 是否自动启动bot,默认不启动,设置为true时自动启动,目前需要自行克隆bot仓库所需代码,存到ql/repo目录下,文件夹命名为dockerbot | ||||
| AutoStartBot="" | ||||
|  |  | |||
|  | @ -1350,7 +1350,9 @@ function parseHeaders(headers) { | |||
| } | ||||
| 
 | ||||
| function parseBody(body, contentType) { | ||||
|   if (!body) return ''; | ||||
|   if (contentType === 'text/plain' || !body) { | ||||
|     return body; | ||||
|   } | ||||
| 
 | ||||
|   const parsed = {}; | ||||
|   let key; | ||||
|  |  | |||
|  | @ -749,8 +749,8 @@ def parse_headers(headers): | |||
| 
 | ||||
| 
 | ||||
| def parse_body(body, content_type): | ||||
|     if not body: | ||||
|         return "" | ||||
|     if not body or content_type == "text/plain": | ||||
|         return body | ||||
| 
 | ||||
|     parsed = {} | ||||
|     lines = body.split("\n") | ||||
|  |  | |||
|  | @ -369,6 +369,7 @@ export default { | |||
|         tip: intl.get('请求头Content-Type'), | ||||
|         required: true, | ||||
|         items: [ | ||||
|           { value: 'text/plain' }, | ||||
|           { value: 'application/json' }, | ||||
|           { value: 'multipart/form-data' }, | ||||
|           { value: 'application/x-www-form-urlencoded' }, | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 whyour
						whyour