| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  | import * as plugins from './taskbuffer.plugins'; | 
					
						
							|  |  |  | import * as helpers from './taskbuffer.classes.helpers'; | 
					
						
							| 
									
										
										
										
											2016-05-04 03:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-01 13:17:15 +02:00
										 |  |  | export interface ITaskFunction { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |   (x?: any): PromiseLike<any>; | 
					
						
							| 
									
										
										
										
											2016-08-01 13:17:15 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-04 03:44:54 +02:00
										 |  |  | export class Task { | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |   // man datory properties
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |   name: string; | 
					
						
							|  |  |  |   taskFunction: ITaskFunction; | 
					
						
							|  |  |  |   buffered: boolean; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |   bufferMax: number; | 
					
						
							|  |  |  |   execDelay: number; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // tasks to run before and after
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |   preTask: Task; | 
					
						
							|  |  |  |   afterTask: Task; | 
					
						
							| 
									
										
										
										
											2016-05-04 03:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   // initialize by default
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |   running: boolean = false; | 
					
						
							|  |  |  |   bufferRunner = new helpers.BufferRunner(this); | 
					
						
							|  |  |  |   cycleCounter = new helpers.CycleCounter(this); | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |   idle: boolean = true; | 
					
						
							|  |  |  |   private _state: string = 'ready'; | 
					
						
							| 
									
										
										
										
											2016-08-01 16:10:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |   constructor(optionsArg: { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * the task function to run, must return promise | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     taskFunction: ITaskFunction; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * any other task to run before | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     preTask?: Task; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * any other task to run after | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     afterTask?: Task; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * wether this task should run buffered | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     buffered?: boolean; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * the maximum buffer | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     bufferMax?: number; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * the execution delay, before the task is executed | 
					
						
							|  |  |  |      * only makes sense when running in buffered mode | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     execDelay?: number; | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * the name of the task | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     name?: string; | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   }) { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     this.taskFunction = optionsArg.taskFunction; | 
					
						
							|  |  |  |     this.preTask = optionsArg.preTask; | 
					
						
							|  |  |  |     this.afterTask = optionsArg.afterTask; | 
					
						
							|  |  |  |     this.idle = !this.running; | 
					
						
							|  |  |  |     this.buffered = optionsArg.buffered; | 
					
						
							|  |  |  |     this.bufferMax = optionsArg.bufferMax; | 
					
						
							|  |  |  |     this.execDelay = optionsArg.execDelay; | 
					
						
							|  |  |  |     this.name = optionsArg.name; | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * trigger the task. Will trigger buffered if this.buffered is true | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |   trigger(x?): Promise<any> { | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |     if (this.buffered) { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |       return this.triggerBuffered(x); | 
					
						
							| 
									
										
										
										
											2017-06-09 23:33:41 +02:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |       return this.triggerUnBuffered(x); | 
					
						
							| 
									
										
										
										
											2017-06-09 23:33:41 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-08-01 13:17:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * trigger task unbuffered. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |   triggerUnBuffered(x?): Promise<any> { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     return helpers.runTask(this, { x: x }); | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-05-04 03:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * trigger task buffered. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |   triggerBuffered(x?): Promise<any> { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     return this.bufferRunner.trigger(x); | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  |   get state(): string { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |     return this._state; | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-07-10 12:42:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   set state(stateArg: string) { | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |     if (stateArg === 'locked') { | 
					
						
							| 
									
										
										
										
											2018-08-04 17:53:22 +02:00
										 |  |  |       this._state = 'locked'; | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2019-01-15 00:17:44 +01:00
										 |  |  |       plugins.smartlog.defaultLogger.log('error', 'state type ' + stateArg + ' could not be set'); | 
					
						
							| 
									
										
										
										
											2016-05-04 03:44:54 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-02-15 22:52:29 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-06-09 23:33:41 +02:00
										 |  |  | } |