Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
n/a
0 / 0
n/a
0 / 0
CRAP
n/a
0 / 0
1<?php
2
3/**
4 * This file is part of the MADIS - RGPD Management application.
5 *
6 * @copyright Copyright (c) 2018-2019 Soluris - Solutions Numériques Territoriales Innovantes
7 *
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU Affero General Public License as published by
10 * the Free Software Foundation, either version 3 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Affero General Public License for more details.
17 *
18 * You should have received a copy of the GNU Affero General Public License
19 * along with this program. If not, see <https://www.gnu.org/licenses/>.
20 */
21
22declare(strict_types=1);
23
24namespace App\Domain\Registry\Repository;
25
26use App\Application\DDD\Repository\CRUDRepositoryInterface;
27use App\Application\Doctrine\Repository\DataTablesRepository;
28use App\Domain\User\Model\Collectivity;
29use App\Domain\User\Model\User;
30
31interface Treatment extends CRUDRepositoryInterface, DataTablesRepository
32{
33    /**
34     * Find all treatments.
35     *
36     * @param bool  $active Get active / inactive treatments
37     * @param array $order  Order results
38     *
39     * @return array The array of treatments
40     */
41    public function findAllActive(bool $active = true, array $order = []);
42
43    /**
44     * Find all treatments by associated collectivity.
45     *
46     * @param Collectivity $collectivity The collectivity to search with
47     * @param array        $order        Order results
48     *
49     * @return array The array of treatments given by the collectivity
50     */
51    public function findAllByCollectivity(Collectivity $collectivity, array $order = []);
52
53    /**
54     * Find all active treatments by associated collectivity.
55     *
56     * @param Collectivity $collectivity The collectivity to search with
57     * @param bool         $active       Get active / inactive treatment
58     * @param array        $order        Order results
59     *
60     * @return array The array of treatments given by the collectivity
61     */
62    public function findAllActiveByCollectivity(?Collectivity $collectivity = null, bool $active = true, array $order = []);
63
64    /**
65     * Find all active treatments by associated collectivity and hasModuleConformiteTraitement active.
66     *
67     * @param Collectivity|array $collectivity The collectivity to search with
68     * @param bool               $active       Get active / inactive treatment
69     * @param array              $order        Order results
70     *
71     * @return array The array of treatments given by the collectivity
72     */
73    public function findAllActiveByCollectivityWithHasModuleConformiteTraitement($collectivity = null, bool $active = true, array $order = []);
74
75    /**
76     * Count all by collectivity.
77     */
78    public function countAllByCollectivity(Collectivity $collectivity);
79
80    /**
81     * Get the last updated treatment by collectivity.
82     */
83    public function findOneOrNullLastUpdateByCollectivity(Collectivity $collectivity): ?\App\Domain\Registry\Model\Treatment;
84
85    /**
86     * Count all by collectivity.
87     */
88    public function countAllActiveByCollectivity(Collectivity $collectivity);
89
90    /**
91     * Return all treatment from active collectivity.
92     *
93     * @return array
94     */
95    public function findAllByActiveCollectivity(bool $active = true, ?User $user = null);
96
97    /**
98     * Count all with no conformite traitement by collectivity.
99     */
100    public function countAllWithNoConformiteTraitementByCollectivity(?Collectivity $collectivity);
101
102    /**
103     * Find all by collectivity of their clonedFrom.
104     */
105    public function findAllByClonedFromCollectivity(Collectivity $collectivity);
106
107    /**
108     * Set clonedFrom to null by collectivity.
109     */
110    public function resetClonedFromCollectivity(Collectivity $collectivity);
111}