Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. <?php
  2. namespace backend\controllers;
  3. use Yii;
  4. use common\models\User;
  5. use yii\data\ActiveDataProvider;
  6. use yii\web\Controller;
  7. use yii\web\NotFoundHttpException;
  8. use yii\filters\VerbFilter;
  9. use yii\filters\AccessControl;
  10. use kartik\mpdf\Pdf;
  11. use common\models\Etablissement;
  12. use common\models\Commande ;
  13. use common\models\CommandeAuto ;
  14. use common\models\Production ;
  15. /**
  16. * UserController implements the CRUD actions for User model.
  17. */
  18. class CronController extends BackendController
  19. {
  20. public function behaviors()
  21. {
  22. return [
  23. 'verbs' => [
  24. 'class' => VerbFilter::className(),
  25. 'actions' => [
  26. 'delete' => ['post'],
  27. ],
  28. ],
  29. 'access' => [
  30. 'class' => AccessControl::className(),
  31. 'rules' => [
  32. [
  33. 'allow' => true,
  34. 'roles' => ['?'],
  35. ]
  36. ],
  37. ],
  38. ];
  39. }
  40. public function actionInitBddDemo($key = '')
  41. {
  42. if($key == '45432df6e842ac71aa0b5bb6b9f25d44' && YII_ENV == 'demo')
  43. {
  44. $arr_noms = [
  45. 'Martin', 'Bernard', 'Thomas','Petit','Robert', 'Richard','Durand','Dubois',
  46. 'Moreau', 'Laurent', 'Simon', 'Michel', 'Lefebvre', 'Leroy', 'Roux', 'David',
  47. 'Bertrand', 'Morel', 'Fournier', 'Girard', 'Bonnet', 'Dupont','Lambert', 'Fontaine',
  48. 'Rousseau', 'Vincent', 'Muller','Lefevre', 'Faure', 'Andre', 'Mercier', 'Blanc', 'Guerin',
  49. 'Boyer', 'Garnier', 'Chevalier', 'François','Legrand','Gauthier','Garcia','Perrin',
  50. 'Robin','Clement','Morin','Nicolas','Henry','Roussel','Mathieu','Gautier','Masson',
  51. 'Marchand','Duval','Denis','Dumont','Marie','Lemaire','Noël','Meyer','Dufour',
  52. 'Meunier','Brun','Blanchard','Giraud','Joly','Rivière','Lucas','Brunet','Gaillard','Barbier',
  53. 'Arnaud','Martinez','Gerard','Roche','Renard','Schmitt','Roy','Leroux','Colin','Vidal',
  54. 'Caron','Picard','Roger','Fabre','Aubert','Lemoine','Renaud','Dumas','Lacroix','Olivier',
  55. 'Philippe','Bourgeois','Pierre','Benoit','Rey','Leclerc','Payet','Rolland','Lecomte','Lopez',
  56. 'Jean','Dupuis','Guillot','Hubert','Berger','Carpentier','Sanchez','Dupuis','Moulin',
  57. 'Louis','Deschamps','Huet','Vasseur','Perez','Trouillot','Fusillier','Massenot','Boucher','Fleury',
  58. 'Royer','Klein','Jacquet','Jaquin','Adam','Paris','Poirier','Aubry','Guyot','Carré','Charles',
  59. 'Charpentier','Menard','Bailly','Bertin','Le Gall','Collet','Leger','Bouvier','Millet','Daniel',
  60. 'Langlois','Pelletier','Perrier','Leblanc','Lebrun','Monnier','Michaud','Laporte','Carlier',
  61. 'Pasquier','Delaunay','Lamy','Gilbert','Lejeune','Pichon','Cordier','Barthelemy','Perret','Reynaud',
  62. 'Humbert','Marechal','Bernard','Lemaitre','Gay','Bouchet','Da Silva','Chauvin','Chevalier','Tessier',
  63. 'Poulain','Girondin','Gillet','Guichard'
  64. ];
  65. $arr_prenoms = [
  66. 'Adel','Antonin','Armand','Arnaud','Aymeric','Baptiste','Barnabé','Bernard','Brice','Baudouin',
  67. 'Camille','Cassandre','Célestin','Christian','Clément','Cyril','Claude','Damien','Daniel','David',
  68. 'Delphin','Denis','Didier','Dimitri','Dorothée','Désiré','Edgard','Etienne','Eugène','Eudes','Eric',
  69. 'Fabien','Fabrice','Flavien','Florent','Francois','Frédéric','Gabin','Gabriel','Gautier','Gilles','Guy',
  70. 'Hervé','Huvert','Hugues','Hector','Jacques','Jason','Jean','Jeannot','Johan','Julien','Léon','Lionel','Loïc',
  71. 'Lucas','Luc','Lucien','Maurice','Maxence','Maxime','Michel','Morgan','Nicolas','Normand','Norbert','Olivier,',
  72. 'Pascal','Patrice','Pierrick','Raphael','Roland','Stéphane','Sylvain','Sylvestre','Timothée','Thomas','Tristan',
  73. 'Ulysse','Vincent','Victor','Vivien',
  74. 'Adeline','Albane','Alix','Amélie','Arielle','Aurelle','Blandine','Blanche','Brigitte','Berthe','Camille','Capucine',
  75. 'Catherine','Cécile','Charlotte','Chloé','Claudine','Clémenence','Constance','Cyrielle','Corinne','Danielle',
  76. 'Delphine','Denise','Dominique','Diane','Édith','Éliane','Éléonore','Émilie','Emmanuelle','Ève','Évelyne',
  77. 'Fanny','Flavie','Flore','Françoise', 'Gabrielle','Gaëlle','Geneviève','Georgette','Germaine','Gertrude','Gisèle',
  78. 'Gwenaëlle','Hélène','Héloïse','Henriette','Huguette','Inès','Isabelle','Jacqueline','Jeanne','Joëlle','Joséphine',
  79. 'Juliette','Justine','Julie','Laura','Laure','Léa','Léonie','Lucie','Lucienne','Lorraine','Lucille','Ludivine','Lydie',
  80. 'Margot','Marion','Marlène','Marthe','Mélodie','Monique','Noémie','Nadine','Nadège','Océane','Odette','Odile','Paulette',
  81. 'Rose','Roseline','Renée','Sabine','Sophie','Suzanne','Sylvie','Thérèse',
  82. ];
  83. $arr_noms_checked = [] ;
  84. $arr_prenoms_checked = [] ;
  85. $users = User::find()
  86. ->joinWith('userEtablissement')
  87. ->where('user_etablissement.id_etablissement = 1')
  88. ->all() ;
  89. foreach($users as $u)
  90. {
  91. if($u->email != 'boulanger@laboiteapain.net')
  92. {
  93. do {
  94. $i_nom = rand(0, count($arr_noms)-1) ;
  95. $i_prenom = rand(0, count($arr_prenoms)-1) ;
  96. } while(isset($arr_noms_checked[$i_nom]) || isset($arr_prenoms_checked[$i_prenom])) ;
  97. $arr_noms_checked[$i_nom] = true ;
  98. $arr_prenoms_checked[$i_prenom] = true ;
  99. $nom = $arr_noms[$i_nom] ;
  100. $prenom = $arr_prenoms[$i_prenom] ;
  101. $u->nom = $nom ;
  102. $u->prenom = $prenom ;
  103. $email = strtolower($prenom).'.'.strtolower($nom).'@yopmail.com' ;
  104. $email = htmlentities($email, ENT_NOQUOTES, 'utf-8');
  105. $email = preg_replace('#&([A-za-z])(?:acute|cedil|caron|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $email);
  106. $email = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $email); // pour les ligatures e.g. '&oelig;'
  107. $email = preg_replace('#&[^;]+;#', '', $email); // supprime les autres caractères
  108. $u->email = $email ;
  109. $u->telephone = '0600000000' ;
  110. }
  111. else {
  112. /*
  113. * Le hash du mot de passe en production est volontairement corrompu
  114. * pour empêcher la connexion des utilisateurs via ce compte en prod.
  115. * Lors de l'initialisation des utilisateurs sur l'espace de démo,
  116. * on remet le bon hash pour que ce compte soit disponible.
  117. */
  118. $u->password_hash = '$2y$13$2D5T3Eo0pySmtlAuEGcfmOdTR5mleog8Y6YPGhop/ych6pbj6aN2y' ;
  119. }
  120. $u->save();
  121. }
  122. $commandes = Commande::find()
  123. ->where('username IS NOT NULL')
  124. ->all() ;
  125. foreach($commandes as $c)
  126. {
  127. do {
  128. $i_nom = rand(0, count($arr_noms)-1) ;
  129. $i_prenom = rand(0, count($arr_prenoms)-1) ;
  130. } while(isset($arr_noms_checked[$i_nom]) || isset($arr_prenoms_checked[$i_prenom])) ;
  131. $arr_noms_checked[$i_nom] = true ;
  132. $arr_prenoms_checked[$i_prenom] = true ;
  133. $nom = $arr_noms[$i_nom] ;
  134. $prenom = $arr_prenoms[$i_prenom] ;
  135. $c->username = $prenom.' '.$nom ;
  136. $c->save() ;
  137. }
  138. $commandes_auto = CommandeAuto::find()
  139. ->where('username IS NOT NULL')
  140. ->all() ;
  141. foreach($commandes_auto as $c)
  142. {
  143. do {
  144. $i_nom = rand(0, count($arr_noms)-1) ;
  145. $i_prenom = rand(0, count($arr_prenoms)-1) ;
  146. } while(isset($arr_noms_checked[$i_nom]) || isset($arr_prenoms_checked[$i_prenom])) ;
  147. $arr_noms_checked[$i_nom] = true ;
  148. $arr_prenoms_checked[$i_prenom] = true ;
  149. $nom = $arr_noms[$i_nom] ;
  150. $prenom = $arr_prenoms[$i_prenom] ;
  151. $c->username = $prenom.' '.$nom ;
  152. $c->save() ;
  153. }
  154. }
  155. }
  156. public function actionSendCommandes($key = '')
  157. {
  158. if($key == '64ac0bdab7e9f5e48c4d991ec5201d57')
  159. {
  160. $heure = date('H') ;
  161. if($heure == '00')
  162. {
  163. $date = date('Y-m-d') ;
  164. }
  165. else {
  166. $date = date('Y-m-d', time()+24*60*60) ;
  167. }
  168. $etablissements = Etablissement::find()->all() ;
  169. foreach($etablissements as $e)
  170. {
  171. $production = Production::findOne([
  172. 'date' => $date,
  173. 'actif' => 1,
  174. 'id_etablissement' => $e['id'],
  175. ]) ;
  176. if($production && $heure == $e['heure_limite_commande'])
  177. {
  178. $commandes = Commande::find()
  179. ->with('commandeProduits', 'user')
  180. ->joinWith('production')
  181. ->where(['production.date' => $date])
  182. ->andWhere(['production.id_etablissement' => $e['id']])
  183. ->orderBy('date ASC')
  184. ->all();
  185. $user = User::findOne([
  186. 'id_etablissement' => $e['id'],
  187. 'status' => User::STATUS_BOULANGER
  188. ]) ;
  189. $mail = Yii::$app->mailer->compose(
  190. [
  191. 'html' => 'cronRecapCommandes-html',
  192. 'text' => 'cronRecapCommandes-text',
  193. ],
  194. [
  195. 'date' => $date,
  196. 'commandes' => $commandes
  197. ]
  198. )
  199. ->setTo($user->email)
  200. ->setFrom([Yii::$app->params['adminEmail'] => 'La boîte à pain']) ;
  201. if(count($commandes))
  202. {
  203. $sujet = '[La boîte à pain] Commandes du '.date('d/m',strtotime($date)) ;
  204. // génération du pdf de commande
  205. Yii::$app->runAction('commande/report-cron', [
  206. 'date' => $date,
  207. 'save' => true,
  208. 'id_etablissement' => $e['id'] ,
  209. 'key' => '64ac0bdab7e9f5e48c4d991ec5201d57'
  210. ]);
  211. $mail->attach(Yii::getAlias('@app/web/pdf/Commandes-'.$date.'-'.$e['id'].'.pdf')) ;
  212. }
  213. else {
  214. $sujet = '[La boîte à pain] Aucune commande' ;
  215. }
  216. $mail->setSubject($sujet)
  217. ->send();
  218. }
  219. }
  220. }
  221. }
  222. }