Completed
Push — master ( a72e46...934ba3 )
by Mauro
02:23
created

TaskRepository::getTasksQuery()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 4
rs 10
cc 1
eloc 2
nc 1
nop 0
1
<?php
2
3
namespace App\Repository;
4
5
use App\Service\MessageService;
6
7
/**
8
 * Tasks Repository.
9
 */
10
class TaskRepository extends BaseRepository
11
{
12
    /**
13
     * @param object $database
14
     */
15
    public function __construct(\PDO $database = null)
16
    {
17
        $this->database = $database;
18
    }
19
20
    /**
21
     * Check if the task exists.
22
     *
23
     * @param int $taskId
24
     * @return array $task
25
     * @throws \Exception
26
     */
27
    public function checkTask($taskId)
28
    {
29
        $query = $this->getTaskQuery();
30
        $statement = $this->database->prepare($query);
31
        $statement->bindParam('id', $taskId);
32
        $statement->execute();
33
        $task = $statement->fetchObject();
34
        if (empty($task)) {
35
            throw new \Exception(MessageService::TASK_NOT_FOUND, 404);
36
        }
37
38
        return $task;
39
    }
40
41
    /**
42
     * Get all tasks.
43
     *
44
     * @return array
45
     */
46
    public function getTasks()
47
    {
48
        $query = $this->getTasksQuery();
49
        $statement = $this->database->prepare($query);
50
        $statement->execute();
51
52
        return $statement->fetchAll();
53
    }
54
55
    /**
56
     * Search tasks by name.
57
     *
58
     * @param string $tasksName
59
     * @return array
60
     * @throws \Exception
61
     */
62 View Code Duplication
    public function searchTasks($tasksName)
63
    {
64
        $query = $this->searchTasksQuery();
65
        $statement = $this->database->prepare($query);
66
        $query = '%' . $tasksName . '%';
67
        $statement->bindParam('query', $query);
68
        $statement->execute();
69
        $tasks = $statement->fetchAll();
70
        if (!$tasks) {
71
            throw new \Exception(MessageService::TASK_NOT_FOUND, 404);
72
        }
73
74
        return $tasks;
75
    }
76
77
    /**
78
     * Create a task.
79
     *
80
     * @param array $data
81
     * @return array
82
     * @throws \Exception
83
     */
84
    public function createTask($data)
85
    {
86
        $query = $this->createTaskQuery();
87
        $statement = $this->database->prepare($query);
88
        $statement->bindParam('task', $data['task']);
89
        $statement->bindParam('status', $data['status']);
90
        $statement->execute();
91
        $task = $this->checkTask($this->database->lastInsertId());
92
93
        return $task;
94
    }
95
96
    /**
97
     * Update a task.
98
     *
99
     * @param array $data
100
     * @param int $taskId
101
     * @return array
102
     */
103
    public function updateTask($data, $taskId)
104
    {
105
        $query = $this->updateTaskQuery();
106
        $statement = $this->database->prepare($query);
107
        $statement->bindParam('id', $taskId);
108
        $statement->bindParam('task', $data['task']);
109
        $statement->bindParam('status', $data['status']);
110
        $statement->execute();
111
        $task = $this->checkTask($taskId);
112
113
        return $task;
114
    }
115
116
    /**
117
     * Delete a task.
118
     *
119
     * @param int $taskId
120
     * @return void
121
     */
122
    public function deleteTask($taskId)
123
    {
124
        $query = $this->deleteTaskQuery();
125
        $statement = $this->database->prepare($query);
126
        $statement->bindParam('id', $taskId);
127
        $statement->execute();
128
    }
129
130
    /**
131
     * Get Task Sql Query.
132
     *
133
     * @return string
134
     */
135
    public function getTaskQuery()
136
    {
137
        return 'SELECT * FROM tasks WHERE id=:id';
138
    }
139
140
    public function getTasksQuery()
141
    {
142
        return 'SELECT * FROM tasks ORDER BY task';
143
    }
144
145
    public function searchTasksQuery()
146
    {
147
        return 'SELECT * FROM tasks WHERE UPPER(task) LIKE :query ORDER BY task';
148
    }
149
150
    public function createTaskQuery()
151
    {
152
        return 'INSERT INTO tasks (task, status) VALUES (:task, :status)';
153
    }
154
155
    public function updateTaskQuery()
156
    {
157
        return 'UPDATE tasks SET task=:task, status=:status WHERE id=:id';
158
    }
159
160
    public function deleteTaskQuery()
161
    {
162
        return 'DELETE FROM tasks WHERE id=:id';
163
    }
164
}
165