X-Git-Url: https://git.rapsys.eu/airbundle/blobdiff_plain/a3948b3c5f82553dc361d7ae0bfb34b716be7b05..e223215d4451312944232cbd8e69f0a6784fb51a:/DataFixtures/AirFixtures.php

diff --git a/DataFixtures/AirFixtures.php b/DataFixtures/AirFixtures.php
index 475b9f2..7b3e3a3 100644
--- a/DataFixtures/AirFixtures.php
+++ b/DataFixtures/AirFixtures.php
@@ -2,46 +2,78 @@
 
 namespace Rapsys\AirBundle\DataFixtures;
 
-use Rapsys\AirBundle\Entity\Title;
+use Doctrine\Bundle\FixturesBundle\Fixture;
+use Doctrine\Persistence\ObjectManager;
+use Symfony\Component\DependencyInjection\ContainerAwareInterface;
+use Symfony\Component\DependencyInjection\ContainerInterface;
+use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
+
+use Rapsys\AirBundle\Entity\Civility;
 use Rapsys\AirBundle\Entity\Group;
 use Rapsys\AirBundle\Entity\User;
 use Rapsys\AirBundle\Entity\Location;
 use Rapsys\AirBundle\Entity\Slot;
 
-class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Symfony\Component\DependencyInjection\ContainerAwareInterface {
+class AirFixtures extends Fixture implements ContainerAwareInterface {
 	/**
 	 * @var ContainerInterface
 	 */
 	private $container;
 
-	public function setContainer(\Symfony\Component\DependencyInjection\ContainerInterface $container = null) {
+	/**
+	 * @var UserPasswordHasherInterface
+	 */
+	private $hasher;
+
+	public function setContainer(ContainerInterface $container = null) {
 		$this->container = $container;
+		$this->hasher = $this->container->get('security.password_hasher_factory');
 	}
 
 	/**
 	 * {@inheritDoc}
 	 */
-	public function load(\Doctrine\Common\Persistence\ObjectManager $manager) {
-		$encoder = $this->container->get('security.password_encoder');
+	public function load(ObjectManager $manager) {
+		//Civility tree
+		$civilityTree = array(
+			'Mister',
+			'Madam',
+			'Miss'
+		);
+
+		//Create titles
+		$civilitys = array();
+		foreach($civilityTree as $civilityData) {
+			$civility = new Civility();
+			$civility->setTitle($civilityData);
+			$civility->setCreated(new \DateTime('now'));
+			$civility->setUpdated(new \DateTime('now'));
+			$manager->persist($civility);
+			$civilitys[$civilityData] = $civility;
+			unset($civility);
+		}
+
+		//TODO: insert countries from https://raw.githubusercontent.com/raramuridesign/mysql-country-list/master/country-lists/mysql-country-list-detailed-info.sql
+		#CREATE TABLE `countries` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `code` varchar(2) NOT NULL, `alpha` varchar(3) NOT NULL, `title` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL, `created` datetime NOT NULL, `updated` datetime NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `code` (`code`), UNIQUE KEY `alpha` (`alpha`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
+		#insert into countries (code, alpha, title, created, updated) select countryCode, isoAlpha3, countryName, NOW(), NOW() FROM apps_countries_detailed ORDER BY countryCode ASC, isoAlpha3 ASC;
 
-		//Title tree
-		$titleTree = array(
-			'Mr.' => 'Mister',
-			'Mrs.' => 'Madam',
-			'Ms.' => 'Miss'
+		//Dance tree
+		$danceTree = array(
+			'Argentine Tango' => [
+			   'Milonga', 'Class and milonga', 'Public class', 'Private class'
+			]
 		);
 
 		//Create titles
-		$titles = array();
-		foreach($titleTree as $shortData => $titleData) {
-			$title = new Title();
-			$title->setShort($shortData);
-			$title->setTitle($titleData);
-			$title->setCreated(new \DateTime('now'));
-			$title->setUpdated(new \DateTime('now'));
-			$manager->persist($title);
-			$titles[$shortData] = $title;
-			unset($title);
+		$dances = array();
+		foreach($danceTree as $danceTitle => $danceData) {
+			foreach($danceData as $danceType) {
+				$dance = new Dance($danceTitle, $danceType);
+				$dance->setCreated(new \DateTime('now'));
+				$dance->setUpdated(new \DateTime('now'));
+				$manager->persist($dance);
+				unset($dance);
+			}
 		}
 
 		//Group tree
@@ -80,7 +112,7 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 				'phone' => '+33677952829',
 				'password' => 'test'
 			),
-			array(
+			/*array(
 				'short' => 'Mr.',
 				'group' => 'Senior',
 				'mail' => 'denis.courvoisier@wanadoo.fr',
@@ -89,7 +121,7 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 				'surname' => 'Courvoisier',
 				'phone' => '+33600000000',
 				'password' => 'test'
-			),
+			),*/
 			array(
 				'short' => 'Mr.',
 				'group' => 'Senior',
@@ -115,15 +147,13 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 		//Create users
 		$users = array();
 		foreach($userTree as $userData) {
-			$user = new User();
-			$user->setMail($userData['mail']);
+			$user = new User($userData['mail']);
 			$user->setPseudonym($userData['pseudonym']);
 			$user->setForename($userData['forename']);
 			$user->setSurname($userData['surname']);
 			$user->setPhone($userData['phone']);
-			$user->setPassword($encoder->encodePassword($user, $userData['password']));
-			$user->setActive(true);
-			$user->setTitle($titles[$userData['short']]);
+			$user->setPassword($this->hasher->hashPassword($user, $userData['password']));
+			$user->setCivility($civilitys[$userData['short']]);
 			$user->addGroup($groups[$userData['group']]);
 			$user->setCreated(new \DateTime('now'));
 			$user->setUpdated(new \DateTime('now'));
@@ -139,7 +169,7 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 		//XXX: adding a new zipcode here requires matching accuweather uris in Command/WeatherCommand.php
 		$locationTree = [
 			[
-				'title' => 'Opera Garnier',
+				'title' => 'Garnier opera',
 				'short' => 'Garnier',
 				'address' => '10 Place de l\'Opéra',
 				'zipcode' => '75009',
@@ -170,7 +200,7 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 				'hotspot' => false
 			],
 			[
-				'title' => 'Colette square',
+				'title' => 'Colette place',
 				'short' => 'Colette',
 				'address' => 'Galerie du Théâtre Français',
 				'zipcode' => '75001',
@@ -180,7 +210,7 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 				'hotspot' => false
 			],
 			[
-				'title' => 'Swan Island',
+				'title' => 'Swan island',
 				'short' => 'Swan',
 				'address' => 'Allée des Cygnes',
 				'zipcode' => '75015',
@@ -258,6 +288,26 @@ class AirFixtures extends \Doctrine\Bundle\FixturesBundle\Fixture implements \Sy
 				'latitude' => 48.892503,
 				'longitude' => 2.389300,
 				'hotspot' => false
+			],
+			[
+				'title' => 'Louvre palace',
+				'short' => 'Louvre',
+				'address' => 'Quai François Mitterrand',
+				'zipcode' => '75001',
+				'city' => 'Paris',
+				'latitude' => 48.860386,
+				'longitude' => 2.332611,
+				'hotspot' => false
+			],
+			[
+				'title' => 'Monde garden',
+				'short' => 'Monde',
+				'address' => '63 avenue Pierre Mendès-France',
+				'zipcode' => '75013',
+				'city' => 'Paris',
+				'latitude' => 48.840451,
+				'longitude' => 2.367638,
+				'hotspot' => false
 			]
 		];