| 
									
										
										
										
											2018-09-22 22:01:32 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Grocy\Services; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class TasksService extends BaseService | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	public function GetCurrent() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$sql = 'SELECT * from tasks_current'; | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		return $this->getDatabaseService()->ExecuteDbQuery($sql)->fetchAll(\PDO::FETCH_OBJ); | 
					
						
							| 
									
										
										
										
											2018-09-22 22:01:32 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-23 19:26:13 +02:00
										 |  |  | 	public function MarkTaskAsCompleted($taskId, $doneTime) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (!$this->TaskExists($taskId)) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			throw new \Exception('Task does not exist'); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$taskRow = $this->getDatabase()->tasks()->where('id = :1', $taskId)->fetch(); | 
					
						
							| 
									
										
										
										
											2018-09-23 19:26:13 +02:00
										 |  |  | 		$taskRow->update(array( | 
					
						
							|  |  |  | 			'done' => 1, | 
					
						
							|  |  |  | 			'done_timestamp' => $doneTime | 
					
						
							|  |  |  | 		)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-06 20:34:01 +02:00
										 |  |  | 	public function UndoTask($taskId) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (!$this->TaskExists($taskId)) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			throw new \Exception('Task does not exist'); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$taskRow = $this->getDatabase()->tasks()->where('id = :1', $taskId)->fetch(); | 
					
						
							| 
									
										
										
										
											2019-07-06 20:34:01 +02:00
										 |  |  | 		$taskRow->update(array( | 
					
						
							|  |  |  | 			'done' => 0, | 
					
						
							|  |  |  | 			'done_timestamp' => null | 
					
						
							|  |  |  | 		)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-22 22:01:32 +02:00
										 |  |  | 	private function TaskExists($taskId) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$taskRow = $this->getDatabase()->tasks()->where('id = :1', $taskId)->fetch(); | 
					
						
							| 
									
										
										
										
											2018-09-22 22:01:32 +02:00
										 |  |  | 		return $taskRow !== null; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |