| @@ 47-86 (lines=40) @@ | ||
| 44 | * @param bool|int $deleted |
|
| 45 | * @return Notebook[]|Notebook |
|
| 46 | */ |
|
| 47 | public function find($notebook_id = null, $user_id = null, $deleted = false) { |
|
| 48 | $qb = $this->db->getQueryBuilder(); |
|
| 49 | $qb->select('g.*', 'g.guid as guid', $qb->createFunction('COUNT(n.id) as note_count')) //'COUNT(n.id) as note_count' |
|
| 50 | ->from('nextnote_groups', 'g') |
|
| 51 | ->leftJoin('g','nextnote_notes','n', $qb->expr()->eq('g.id', 'n.notebook'))->groupBy(['g.id']); |
|
| 52 | ||
| 53 | $where = []; |
|
| 54 | if($notebook_id){ |
|
| 55 | $where['g.id'] = $notebook_id; |
|
| 56 | } |
|
| 57 | ||
| 58 | if ($user_id !== null) { |
|
| 59 | $where['g.uid'] = $user_id; |
|
| 60 | } |
|
| 61 | ||
| 62 | if ($deleted !== false) { |
|
| 63 | $where['g.deleted'] = $deleted; |
|
| 64 | } |
|
| 65 | $i = 0; |
|
| 66 | foreach ($where as $field => $value){ |
|
| 67 | if($i === 0){ |
|
| 68 | $qb->where($qb->expr()->eq($field, $qb->createNamedParameter($value))); |
|
| 69 | } else { |
|
| 70 | $qb->andWhere($qb->expr()->eq($field, $qb->createNamedParameter($value))); |
|
| 71 | } |
|
| 72 | $i++; |
|
| 73 | } |
|
| 74 | ||
| 75 | $result = $qb->execute(); |
|
| 76 | ||
| 77 | /** |
|
| 78 | * @var $results Notebook[] |
|
| 79 | */ |
|
| 80 | $results = []; |
|
| 81 | while ($item = $result->fetch()) { |
|
| 82 | $results[] = $this->makeEntityFromDBResult($item); |
|
| 83 | } |
|
| 84 | $result->closeCursor(); |
|
| 85 | return $results; |
|
| 86 | } |
|
| 87 | ||
| 88 | /** |
|
| 89 | * @param $group_name |
|
| @@ 94-133 (lines=40) @@ | ||
| 91 | * @param bool $deleted |
|
| 92 | * @return Notebook[]|Notebook |
|
| 93 | */ |
|
| 94 | public function findByName($group_name, $user_id = null, $deleted = false) { |
|
| 95 | $qb = $this->db->getQueryBuilder(); |
|
| 96 | $qb->select('g.*', 'g.guid as guid', $qb->createFunction('COUNT(n.id) as note_count')) //'COUNT(n.id) as note_count' |
|
| 97 | ->from('nextnote_groups', 'g') |
|
| 98 | ->leftJoin('g','nextnote_notes','n', $qb->expr()->eq('g.id', 'n.notebook'))->groupBy(['g.id']); |
|
| 99 | ||
| 100 | $where = []; |
|
| 101 | if($group_name){ |
|
| 102 | $where['g.name'] = $group_name; |
|
| 103 | } |
|
| 104 | ||
| 105 | if ($user_id !== null) { |
|
| 106 | $where['g.uid'] = $user_id; |
|
| 107 | } |
|
| 108 | ||
| 109 | if ($deleted !== false) { |
|
| 110 | $where['g.deleted'] = $deleted; |
|
| 111 | } |
|
| 112 | $i = 0; |
|
| 113 | foreach ($where as $field => $value){ |
|
| 114 | if($i === 0){ |
|
| 115 | $qb->where($qb->expr()->eq($field, $qb->createNamedParameter($value))); |
|
| 116 | } else { |
|
| 117 | $qb->andWhere($qb->expr()->eq($field, $qb->createNamedParameter($value))); |
|
| 118 | } |
|
| 119 | $i++; |
|
| 120 | } |
|
| 121 | ||
| 122 | $result = $qb->execute(); |
|
| 123 | ||
| 124 | /** |
|
| 125 | * @var $results Notebook[] |
|
| 126 | */ |
|
| 127 | $results = []; |
|
| 128 | while ($item = $result->fetch()) { |
|
| 129 | $results[] = $this->makeEntityFromDBResult($item); |
|
| 130 | } |
|
| 131 | $result->closeCursor(); |
|
| 132 | return $results; |
|
| 133 | } |
|
| 134 | ||
| 135 | /** |
|
| 136 | * Creates a group |
|