AccessRepository.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440
  1. <?php
  2. namespace AppBundle\Entity\AccessAndFunction\Repository;
  3. use AppBundle\Entity\AccessAndFunction\Access;
  4. use AppBundle\Entity\AccessAndFunction\FunctionType;
  5. use AppBundle\Entity\HasItemQueryBuilderInterface;
  6. use AppBundle\Entity\Organization\Organization;
  7. use AppBundle\Entity\Person\Person;
  8. use AppBundle\Enum\AccessAndFunction\FunctionEnum;
  9. use AppBundle\Enum\AccessAndFunction\LicenseTypeEnum;
  10. use AppBundle\Enum\OnlineRegistration\ValidationStateEnum;
  11. use AppBundle\Services\AccessService;
  12. use Doctrine\ORM\EntityRepository;
  13. use Doctrine\ORM\QueryBuilder;
  14. /**
  15. * Description of AccessRepository
  16. *
  17. * @author Sébastien Hupin <sebastien.hupin at gmail.com>
  18. */
  19. class AccessRepository extends EntityRepository implements HasItemQueryBuilderInterface
  20. {
  21. /**
  22. * @param Person $person
  23. * @param bool $ignoreCheckNetworkOrganizationEndDate
  24. * @return array
  25. * @throws \Exception
  26. */
  27. public function findValidAccess(\AppBundle\Entity\Person\Person $person, $ignoreCheckNetworkOrganizationEndDate = FALSE, $controleLoginEnabled = true)
  28. {
  29. $filter = $this->_em->getFilters()->enable('activity_year');
  30. $filter->setParameter('disabledFilter', 1);
  31. $datetime = new \DateTime();
  32. $today = $datetime->format('Y-m-d');
  33. $qb = $this->createQueryBuilder('a');
  34. $qb
  35. ->innerJoin('AppBundle:Organization\Organization', 'o', 'WITH', 'o.id = a.organization')
  36. ->innerJoin('AppBundle:Network\NetworkOrganization', 'n', 'WITH', 'o.id = n.organization')
  37. ->where('a.person = :person')
  38. ->andWhere('n.startDate <= :today')
  39. ->setParameter('person', $person)
  40. ->setParameter('today', $today)
  41. ;
  42. if($controleLoginEnabled){
  43. $qb
  44. ->andWhere('a.loginEnabled = :loginEnabled')
  45. ->setParameter('loginEnabled', true);
  46. }
  47. if ($ignoreCheckNetworkOrganizationEndDate == FALSE) {
  48. $qb
  49. ->andWhere('n.endDate >= :today OR n.endDate = :emptydate OR n.endDate IS NULL')
  50. ->setParameter('emptydate', '0000-00-00');
  51. }
  52. $result = $qb->getQuery()->getResult();
  53. $filter->setParameter('disabledFilter', 0);
  54. return $result;
  55. }
  56. /**
  57. * @param AccessService $access
  58. * @return array
  59. */
  60. public function findValidTeacher(AccessService $access)
  61. {
  62. $qb = $this->createQueryBuilder('a');
  63. $qb->innerJoin('a.person', 'person')
  64. ->innerJoin('AppBundle:AccessAndFunction\OrganizationFunction', 'o', 'WITH', 'o.access = a.id')
  65. ->innerJoin('AppBundle:AccessAndFunction\FunctionType', 'ft', 'WITH', 'o.functionType = ft.id')
  66. ->where('ft.mission = :mission')
  67. ->andWhere('a.organization = :organization')
  68. ->setParameter('organization', $access->getOrganization())
  69. ->setParameter('mission', FunctionEnum::TEACHER)
  70. ->orderBy('person.name')
  71. ;
  72. return $qb->getQuery()->getResult();
  73. }
  74. /**
  75. * @param Access $access
  76. * @return array
  77. */
  78. public function doesHaveFunction($accessId, $function)
  79. {
  80. $qb = $this->createQueryBuilder('a');
  81. $qb->innerJoin('a.organizationFunction', 'o')
  82. ->innerJoin('o.functionType', 'ft')
  83. ->where('ft.mission = :mission')
  84. ->andWhere('a.id = :id')
  85. ->setParameter('id', $accessId)
  86. ->setParameter('mission', $function)
  87. ;
  88. return count($qb->getQuery()->getResult()) > 0;
  89. }
  90. /**
  91. * @param Access $access
  92. * @return array
  93. */
  94. public function doesHeStudentDuringPeriod(Access $access, $startDate, $enDate)
  95. {
  96. $filter = $this->_em->getFilters()->enable('activity_year');
  97. $filter->setParameter('disabledFilter', 1);
  98. $qb = $this->createQueryBuilder('a');
  99. $qb->innerJoin('a.organizationFunction', 'o')
  100. ->innerJoin('o.functionType', 'ft')
  101. ->where('ft.mission = :mission')
  102. ->andWhere('(o.startDate <= :enDate AND (o.endDate >= :startDate OR o.endDate IS NULL)) AND ((o.endDate >= :startDate OR o.endDate IS NULL) AND o.startDate <= :enDate)')
  103. ->andWhere('a.id = :id')
  104. ->setParameter('id', $access->getId())
  105. ->setParameter('mission', FunctionEnum::STUDENT)
  106. ->setParameter('startDate', $startDate)
  107. ->setParameter('enDate', $enDate);
  108. ;
  109. $filter->setParameter('disabledFilter', 0);
  110. return count($qb->getQuery()->getResult()) > 0;
  111. }
  112. /**
  113. * Used by Elastica to transform results to model
  114. *
  115. * @param string $entityAlias
  116. * @return Doctrine\ORM\QueryBuilder
  117. */
  118. public function createSearchQueryBuilder($entityAlias)
  119. {
  120. $qb = $this->createQueryBuilder($entityAlias);
  121. $qb->select($entityAlias, 'p', 'g')
  122. ->innerJoin($entityAlias.'.person', 'p')
  123. // ->leftJoin('p.addressPostal', 'a1', 'WITH', "a1.person = p.id AND a1.type = 'ADDRESS_PRINCIPAL'")
  124. // ->leftJoin('p.guardians', 'g', 'WITH', 'g.children = p.id AND g.isPrincipal = 1')
  125. // ->leftJoin(
  126. // 'g.children',
  127. // 'p2',
  128. // 'WITH',
  129. // 'p2.id = g.children'
  130. // )// ->leftJoin('p2.addressPostal', 'a2', 'WITH', "a2.person = p2.id AND a2.type = 'ADDRESS_PRINCIPAL'")
  131. ;
  132. return $qb;
  133. }
  134. public function findDuplicatePhysicalAcces($name,$givenName, Organization $organization)
  135. {
  136. $qb = $this->createQueryBuilder('a')
  137. ->innerJoin(Person::class, 'pers', 'WITH', 'a.person= pers.id')
  138. ->andWhere('pers.isPhysical = 1')
  139. ->andWhere('pers.givenName=:givenName')
  140. ->andWhere('pers.name=:name')
  141. ->andWhere('a.organization=:organizationId')
  142. ->setParameter(':givenName', $givenName)
  143. ->setParameter(':name', $name)
  144. ->setParameter(':organizationId', $organization);
  145. return $qb->getQuery()->getResult();
  146. }
  147. public function findDuplicateMoralAcces(Person $person, Organization $organization)
  148. {
  149. $qb = $this->createQueryBuilder('a')
  150. ->innerJoin(Person::class, 'pers', 'WITH', 'a.person= pers.id')
  151. ->andWhere('pers.isPhysical = 0')
  152. ->andWhere('pers.name=:name')
  153. ->andWhere('a.organization=:organizationId')
  154. ->setParameter(':name', $person->getName())
  155. ->setParameter(':organizationId', $organization);
  156. return $qb->getQuery()->getResult();
  157. }
  158. public function createDetailQueryBuilder(array $groups = null): QueryBuilder
  159. {
  160. if(is_array($groups) && in_array('access_details', $groups)){
  161. return $this
  162. ->createQueryBuilder('o')
  163. ->select('o', 'pe', 'pap', 'af')
  164. ->leftJoin('o.person', 'pe')
  165. ->leftJoin('pe.personAddressPostal', 'pap')
  166. ->leftJoin('o.accessFamily', 'af')
  167. ;
  168. }
  169. return $this->createQueryBuilder('o');
  170. }
  171. public function createListQueryBuilder(){
  172. return $this
  173. ->createQueryBuilder('o')
  174. ->select('o', 'person')
  175. ->innerJoin('o.person', 'person')
  176. ;
  177. }
  178. /**
  179. * @param Organization $organization
  180. * @param $mission
  181. * @return array
  182. */
  183. public function findByOrganizationAndMission(Organization $organization,$mission)
  184. {
  185. $datetime = new \DateTime();
  186. $today = $datetime->format('Y-m-d');
  187. $qb = $this->createQueryBuilder('a')
  188. ->innerJoin(Person::class, 'pers', 'WITH', 'a.person= pers.id')
  189. ->andWhere('pers.isPhysical = 1')
  190. ->andWhere('a.organization=:organizationId')
  191. ->innerJoin('a.organizationFunction', 'ofu')
  192. ->innerJoin('ofu.functionType', 'ft')
  193. ->andWhere('ft.mission=:mission')
  194. ->andWhere('ofu.startDate < :today AND (ofu.endDate >= :today OR ofu.endDate IS NULL)')
  195. ->setParameter('organizationId', $organization)
  196. ->setParameter('mission', $mission)
  197. ->setParameter('today', $today);
  198. return $qb->getQuery()->getResult();
  199. }
  200. /**
  201. * Retourne tous les accesses possédant une fonctions données d'une organisation
  202. * @param $organizationId
  203. * @return array
  204. */
  205. public function findAllAccessesByMission($organizationId, array $functions) {
  206. $queryBuilder =
  207. $this->createQueryBuilder('access');
  208. $queryBuilder
  209. ->select('access, access_wishes, access_billing, access_network_setting, access_communication, access_social')
  210. ->innerJoin('access.organization', 'organization')
  211. ->innerJoin('access.organizationFunction', 'ofu')
  212. ->innerJoin('ofu.functionType', 'ft')
  213. ->leftJoin('access.accessWishes', 'access_wishes')
  214. ->leftJoin('access.accessBilling', 'access_billing')
  215. ->leftJoin('access.accessNetworkSetting', 'access_network_setting')
  216. ->leftJoin('access.accessCommunication', 'access_communication')
  217. ->leftJoin('access.accessSocial', 'access_social')
  218. ->andWhere('ft.mission in (:mission)')
  219. ->andWhere('organization.id=:organizationId')
  220. ->andWhere('access.newAccess=:newAccess')
  221. ->setParameter('newAccess', false)
  222. ->setParameter('organizationId', $organizationId)
  223. ->setParameter('mission', $functions);
  224. $query = $queryBuilder->getQuery();
  225. $results = $query->getResult();
  226. return $results;
  227. }
  228. /**
  229. * Retourne tous les accesses possédant une fonctions données d'une organisation
  230. * @param $organizationId
  231. * @return array
  232. */
  233. public function findAllAccessesByMissionAndWithoutCompletingRegistration($organizationId, array $functions) {
  234. $queryBuilder =
  235. $this->createQueryBuilder('access');
  236. $queryBuilder
  237. ->select('access, access_wishes, access_billing, access_network_setting, access_communication, access_social,access_wish','access_family_wish')
  238. ->innerJoin('access.organization', 'organization')
  239. ->innerJoin('access.organizationFunction', 'ofu')
  240. ->innerJoin('ofu.functionType', 'ft')
  241. ->leftJoin('access.accessWishes', 'access_wishes')
  242. ->leftJoin('access.accessBilling', 'access_billing')
  243. ->leftJoin('access.accessNetworkSetting', 'access_network_setting')
  244. ->leftJoin('access.accessCommunication', 'access_communication')
  245. ->leftJoin('access.accessSocial', 'access_social')
  246. ->leftJoin('access.accessWishes', 'access_wish')
  247. ->leftJoin('access_wish.accessFamilyWish', 'access_family_wish')
  248. ->andWhere('ft.mission in (:mission)')
  249. ->andWhere('organization.id=:organizationId')
  250. ->andWhere('access.newAccess=:newAccess')
  251. ->andWhere('access_wish.id is NULL OR access_family_wish.registrationCompleted = 0')
  252. ->setParameter('newAccess', false)
  253. ->setParameter('organizationId', $organizationId)
  254. ->setParameter('mission', $functions);
  255. $query = $queryBuilder->getQuery();
  256. $results = $query->getResult();
  257. return $results;
  258. }
  259. public function findAllAccessesByAccessWishOpenForNewEducation($organizationId) {
  260. $currentYear = (new \DateTime())->format('Y');
  261. $queryBuilder =
  262. $this->createQueryBuilder('access');
  263. $queryBuilder
  264. ->select('access')
  265. ->innerJoin('access.organization', 'organization')
  266. ->leftJoin('access.accessWishes', 'access_wishes')
  267. ->andWhere('access_wishes.validationState =:validationState')
  268. ->andWhere('organization.id=:organizationId')
  269. ->andWhere('(access_wishes.createDate >= :startDate and access_wishes.createDate <= :endDate)')
  270. ->setParameter('organizationId', $organizationId)
  271. ->setParameter('validationState', ValidationStateEnum::OPEN_FOR_EDUCATIONS)
  272. ->setParameter('startDate', new \DateTime($currentYear.'-01-01'))
  273. ->setParameter('endDate', new \DateTime($currentYear.'-12-31'))
  274. ;
  275. $query = $queryBuilder->getQuery();
  276. $results = $query->getResult();
  277. return $results;
  278. }
  279. /**
  280. * Get all students for a teacher
  281. * @param Access $teacher
  282. * @return Array<Access>
  283. */
  284. public function findStudent(Access $teacher) {
  285. $queryBuilder =
  286. $this->createQueryBuilder('o');
  287. $queryBuilder->innerJoin('o.educationStudent', 'es')
  288. ->innerJoin('es.teachers', 'teacher')
  289. ->andWhere($queryBuilder->expr()->eq('teacher.id', ':teacher'))
  290. ->setParameter(':teacher', $teacher);
  291. $query = $queryBuilder->getQuery();
  292. $results = $query->getResult();
  293. return $results;
  294. }
  295. /**
  296. * @param Organization $organization
  297. * @param $startDate
  298. * @param $enDate
  299. * @return array
  300. */
  301. public function findByStudentsByDates(Organization $organization,$startDate,$enDate)
  302. {
  303. $qb = $this->createQueryBuilder('a')
  304. ->innerJoin(Person::class, 'pers', 'WITH', 'a.person= pers.id')
  305. ->andWhere('pers.isPhysical = 1')
  306. ->andWhere('a.organization=:organizationId')
  307. ->innerJoin('a.organizationFunction', 'ofu')
  308. ->innerJoin('ofu.functionType', 'ft')
  309. ->andWhere('ft.mission=:mission')
  310. ->andWhere('(ofu.startDate <= :enDate AND (ofu.endDate >= :startDate OR ofu.endDate IS NULL)) AND ((ofu.endDate >= :startDate OR ofu.endDate IS NULL) AND ofu.startDate <= :enDate)')
  311. ->setParameter('organizationId', $organization)
  312. ->setParameter('mission', FunctionEnum::STUDENT)
  313. ->setParameter('startDate', $startDate)
  314. ->setParameter('enDate', $enDate);
  315. return $qb->getQuery()->getResult();
  316. }
  317. /**
  318. * @param $accessIds
  319. * @param $organization
  320. * @return array
  321. */
  322. public function findAccessByIds($accessIds,$organization)
  323. {
  324. $queryBuilder = $this->createQueryBuilder('o');
  325. $queryBuilder
  326. ->andWhere(
  327. $queryBuilder->expr()->in('o.id', ':ids'))
  328. ->andWhere('o.organization=:organizationId')
  329. ->setParameter('ids', $accessIds)
  330. ->setParameter('organizationId', $organization);
  331. return $queryBuilder->getQuery()->getResult();
  332. }
  333. public function findAccessWhoAreReEnrolled(Organization $organization){
  334. $datetimeNow = new \Datetime('now');
  335. $currentYear = $datetimeNow->format('Y');
  336. $pastYear = $currentYear-1;
  337. $filter = $this->_em->getFilters()->enable('activity_year');
  338. $filter->setParameter('disabledFilter', 1);
  339. $queryBuilder = $this->createQueryBuilder('o');
  340. $queryBuilder
  341. ->innerJoin('o.educationStudent', 'es')
  342. ->andWhere('es.startYear=:pastYear')
  343. ->innerJoin('o.educationStudent', 'es2')
  344. ->andWhere('es2.startYear=:currentYear')
  345. ->andWhere('o.organization=:organizationId');
  346. $queryBuilder
  347. ->setParameter('pastYear', $pastYear)
  348. ->setParameter('currentYear', $currentYear)
  349. ->setParameter('organizationId', $organization)
  350. ->groupBy('o.id');
  351. $result = $queryBuilder->getQuery()->getResult();
  352. $filter->setParameter('disabledFilter', 0);
  353. return $result;
  354. }
  355. public function findAccessWhoAreEnrolled(Organization $organization){
  356. $datetimeNow = new \Datetime('now');
  357. $currentYear = $datetimeNow->format('Y');
  358. $pastYear = $currentYear-1;
  359. $filter = $this->_em->getFilters()->enable('activity_year');
  360. $filter->setParameter('disabledFilter', 1);
  361. $queryBuilder = $this->createQueryBuilder('o');
  362. $queryBuilder
  363. ->innerJoin('o.educationStudent', 'es2')
  364. ->andWhere('es2.startYear=:currentYear')
  365. ->andWhere('o.organization=:organizationId');
  366. $queryBuilder
  367. ->setParameter('currentYear', $currentYear)
  368. ->setParameter('organizationId', $organization)
  369. ->groupBy('o.id');
  370. $result = $queryBuilder->getQuery()->getResult();
  371. $filter->setParameter('disabledFilter', 0);
  372. return $result;
  373. }
  374. }