*/
- public function getCollection(string $resourceClass, string $operationName = null)
+ public function getCollection(string $resourceClass, ?string $operationName = null)
{
$boolQuery = new Query\BoolQuery();
$query = new Query();
diff --git a/src/Entity/AccessToken.php b/src/Entity/AccessToken.php
deleted file mode 100644
index a3fcc5b..0000000
--- a/src/Entity/AccessToken.php
+++ /dev/null
@@ -1,37 +0,0 @@
-user;
- }
-
- public function setUser(UserInterface $user): self
- {
- $this->user = $user;
-
- return $this;
- }
-}
diff --git a/src/Entity/Diocese.php b/src/Entity/Diocese.php
index d4fc507..211454a 100644
--- a/src/Entity/Diocese.php
+++ b/src/Entity/Diocese.php
@@ -11,48 +11,61 @@
/**
* @ApiResource()
+ *
* @ORM\Table(name="dioceses")
+ *
* @ORM\Entity(repositoryClass="App\Repository\DioceseRepository")
*/
class Diocese
{
/**
* @ORM\Id()
+ *
* @ORM\GeneratedValue()
+ *
* @ORM\Column(type="integer", name="diocese_id")
+ *
* @Groups("diocese")
*/
private ?int $id = null;
/**
* @ORM\Column(type="string", length=255)
+ *
* @Groups("diocese")
*/
private string $name = '';
/**
* @ORM\ManyToOne(targetEntity="App\Entity\Place", inversedBy="dioceses")
+ *
* @ORM\JoinColumn(nullable=true, referencedColumnName="place_id")
+ *
* @Groups("place")
*/
private ?Place $country = null;
/**
* @ORM\Column(type="string", length=255)
+ *
* @Groups("diocese")
*/
private string $website = '';
/**
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private ?\DateTimeInterface $createdAt = null;
/**
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private ?\DateTimeInterface $updatedAt = null;
diff --git a/src/Entity/Parish.php b/src/Entity/Parish.php
index 05e22b5..9c4967d 100644
--- a/src/Entity/Parish.php
+++ b/src/Entity/Parish.php
@@ -11,67 +11,84 @@
/**
* @ApiResource()
+ *
* @ORM\Table(name="parishes")
+ *
* @ORM\Entity(repositoryClass="App\Repository\ParishRepository")
*/
class Parish
{
/**
* @ORM\Id()
+ *
* @ORM\GeneratedValue()
+ *
* @ORM\Column(type="integer", name="parish_id")
+ *
* @Groups("parish")
*/
private ?int $id = null;
/**
* @ORM\Column(type="string", length=255)
+ *
* @Groups("parish")
*/
private string $name = '';
/**
* @ORM\ManyToOne(targetEntity="App\Entity\Diocese", inversedBy="parishes")
+ *
* @ORM\JoinColumn(nullable=true, referencedColumnName="diocese_id")
+ *
* @Groups("diocese")
*/
private ?Diocese $diocese = null;
/**
* @ORM\ManyToOne(targetEntity="App\Entity\Place", inversedBy="parishes")
+ *
* @ORM\JoinColumn(nullable=true, referencedColumnName="place_id")
+ *
* @Groups("place")
*/
private ?Place $country = null;
/**
* @ORM\Column(type="string", length=255)
+ *
* @Groups("parish")
*/
private string $messesinfoId = '';
/**
* @ORM\Column(type="string", length=255)
+ *
* @Groups("parish")
*/
private string $website = '';
/**
* @ORM\Column(type="string", length=255)
+ *
* @Groups("parish")
*/
private string $zipCode = '';
/**
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private ?\DateTimeInterface $createdAt = null;
/**
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private ?\DateTimeInterface $updatedAt = null;
diff --git a/src/Entity/Photo.php b/src/Entity/Photo.php
index d304d21..305e1d2 100644
--- a/src/Entity/Photo.php
+++ b/src/Entity/Photo.php
@@ -15,7 +15,9 @@
* @see http://schema.org/Thing Documentation on Schema.org
*
* @ORM\Entity
+ *
* @ORM\Table(name="photos")
+ *
* @ApiResource(iri="http://schema.org/Thing")
*/
class Photo
@@ -24,7 +26,9 @@ class Photo
* @var int|null
*
* @ORM\Id
+ *
* @ORM\GeneratedValue(strategy="AUTO")
+ *
* @ORM\Column(type="integer", name="photo_id")
*/
private $id;
@@ -33,6 +37,7 @@ class Photo
* @var WikidataChurch
*
* @ORM\ManyToOne(targetEntity="WikidataChurch", inversedBy="photos")
+ *
* @ORM\JoinColumn(nullable=true, referencedColumnName="wikidata_church_id")
*/
private $wikidataChurch;
@@ -41,6 +46,7 @@ class Photo
* @var TheodiaChurch
*
* @ORM\ManyToOne(targetEntity="TheodiaChurch", inversedBy="photos")
+ *
* @ORM\JoinColumn(nullable=true, referencedColumnName="theodia_church_id")
*/
private $theodiaChurch;
@@ -49,6 +55,7 @@ class Photo
* @var string|null URL of the item
*
* @ORM\Column(type="text", nullable=true)
+ *
* @ApiProperty(iri="http://schema.org/url")
*/
private $url;
@@ -57,7 +64,9 @@ class Photo
* @var \DateTimeInterface
*
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private $createdAt;
@@ -66,7 +75,9 @@ class Photo
* @var \DateTimeInterface
*
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private $updatedAt;
diff --git a/src/Entity/Place.php b/src/Entity/Place.php
index 242a0d3..920351e 100644
--- a/src/Entity/Place.php
+++ b/src/Entity/Place.php
@@ -20,7 +20,9 @@
* @see http://schema.org/Thing Documentation on Schema.org
*
* @ORM\Entity
+ *
* @ORM\Table(name="places")
+ *
* @ApiResource(attributes={
* "normalization_context"={"groups"={"place","church"},"enable_max_depth"="true"}
* })
@@ -29,34 +31,43 @@ class Place
{
/**
* @ORM\Id
+ *
* @ORM\GeneratedValue(strategy="AUTO")
+ *
* @ORM\Column(type="integer", name="place_id")
+ *
* @Groups("place")
*/
private ?int $id = null;
/**
* @ORM\ManyToOne(targetEntity="Place", inversedBy="children")
+ *
* @ORM\JoinColumn(nullable=true, referencedColumnName="place_id")
*/
private ?Place $parent = null;
/**
* @ORM\Column(type="text", nullable=true)
+ *
* @ApiProperty(iri="http://schema.org/name")
+ *
* @Groups("place")
*/
private ?string $name = null;
/**
* @ORM\Column(type="text", nullable=true)
+ *
* @Groups("place")
*/
private ?string $countryCode = null;
/**
* @ORM\Column(name="type", type="PlaceType", nullable=false)
+ *
* @DoctrineAssert\Enum(entity="App\Enum\PlaceType")
+ *
* @Groups("place")
*/
private ?string $type = null;
@@ -73,14 +84,18 @@ class Place
/**
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private ?\DateTimeInterface $createdAt = null;
/**
* @ORM\Column(type="datetime")
+ *
* @Assert\DateTime
+ *
* @Assert\NotNull
*/
private ?\DateTimeInterface $updatedAt = null;
diff --git a/src/Entity/RefreshToken.php b/src/Entity/RefreshToken.php
deleted file mode 100644
index 54773ce..0000000
--- a/src/Entity/RefreshToken.php
+++ /dev/null
@@ -1,37 +0,0 @@
- self::MASS,
self::CONFESSION => self::CONFESSION,
self::ADORATION => self::ADORATION,
diff --git a/src/Enum/PlaceType.php b/src/Enum/PlaceType.php
index 7e42429..7377d97 100644
--- a/src/Enum/PlaceType.php
+++ b/src/Enum/PlaceType.php
@@ -12,7 +12,7 @@ final class PlaceType extends AbstractEnumType
public const AREA = 'area';
public const UNKNOWN = 'unknown';
- protected static $choices = [
+ protected static array $choices = [
self::CITY => self::CITY,
self::COUNTRY => self::COUNTRY,
self::STATE => self::STATE,
diff --git a/src/Enum/Rite.php b/src/Enum/Rite.php
index d8f2699..22e5d0c 100644
--- a/src/Enum/Rite.php
+++ b/src/Enum/Rite.php
@@ -22,7 +22,7 @@ final class Rite extends AbstractEnumType
public const ARMENIAN_RITE = 14;
public const GE_EZ_RITE = 15;
- protected static $choices = [
+ protected static array $choices = [
self::ROMAN_RITE_ORDINARY => self::ROMAN_RITE_ORDINARY,
self::ROMAN_RITE_EXTRAORDINARY => self::ROMAN_RITE_EXTRAORDINARY,
self::AMBROSIAN_RITE => self::AMBROSIAN_RITE,
diff --git a/src/Kernel.php b/src/Kernel.php
index 9b1c2c7..779cd1f 100644
--- a/src/Kernel.php
+++ b/src/Kernel.php
@@ -3,61 +3,9 @@
namespace App;
use Symfony\Bundle\FrameworkBundle\Kernel\MicroKernelTrait;
-use Symfony\Component\Config\Loader\LoaderInterface;
-use Symfony\Component\Config\Resource\FileResource;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\HttpKernel\Bundle\BundleInterface;
use Symfony\Component\HttpKernel\Kernel as BaseKernel;
-use Symfony\Component\Routing\RouteCollectionBuilder;
class Kernel extends BaseKernel
{
use MicroKernelTrait;
-
- public const CONFIG_EXTS = '.{php,xml,yaml,yml}';
-
- public function getCacheDir()
- {
- return $this->getProjectDir().'/var/cache/'.$this->environment;
- }
-
- public function getLogDir()
- {
- return $this->getProjectDir().'/var/log';
- }
-
- public function registerBundles()
- {
- $contents = require $this->getProjectDir().'/config/bundles.php';
- /** @var BundleInterface $class */
- foreach ($contents as $class => $envs) {
- if (isset($envs['all']) || isset($envs[$this->environment])) {
- yield new $class();
- }
- }
- }
-
- protected function configureContainer(ContainerBuilder $container, LoaderInterface $loader): void
- {
- $container->addResource(new FileResource($this->getProjectDir().'/config/bundles.php'));
- // Feel free to remove the "container.autowiring.strict_mode" parameter
- // if you are using symfony/dependency-injection 4.0+ as it's the default behavior
- $container->setParameter('container.autowiring.strict_mode', true);
- $container->setParameter('container.dumper.inline_class_loader', true);
- $confDir = $this->getProjectDir().'/config';
-
- $loader->load($confDir.'/{packages}/*'.self::CONFIG_EXTS, 'glob');
- $loader->load($confDir.'/{packages}/'.$this->environment.'/**/*'.self::CONFIG_EXTS, 'glob');
- $loader->load($confDir.'/{services}'.self::CONFIG_EXTS, 'glob');
- $loader->load($confDir.'/{services}_'.$this->environment.self::CONFIG_EXTS, 'glob');
- }
-
- protected function configureRoutes(RouteCollectionBuilder $routes): void
- {
- $confDir = $this->getProjectDir().'/config';
-
- $routes->import($confDir.'/{routes}/*'.self::CONFIG_EXTS, '/', 'glob');
- $routes->import($confDir.'/{routes}/'.$this->environment.'/**/*'.self::CONFIG_EXTS, '/', 'glob');
- $routes->import($confDir.'/{routes}'.self::CONFIG_EXTS, '/', 'glob');
- }
}
diff --git a/src/Listener/ApiLoggerListener.php b/src/Listener/ApiLoggerListener.php
index 9bdfe14..11c8d55 100644
--- a/src/Listener/ApiLoggerListener.php
+++ b/src/Listener/ApiLoggerListener.php
@@ -3,8 +3,6 @@
namespace App\Listener;
use App\Entity\AccessToken;
-use FOS\OAuthServerBundle\Security\Authentication\Token\OAuthToken;
-use FOS\OAuthServerBundle\Storage\OAuthStorage;
use Gedmo\Loggable\LoggableListener;
use Stof\DoctrineExtensionsBundle\EventListener\LoggerListener;
use Symfony\Component\HttpKernel\Event\RequestEvent;
@@ -17,19 +15,19 @@ class ApiLoggerListener extends LoggerListener
{
private AuthorizationCheckerInterface $authorizationChecker;
private LoggableListener $loggableListener;
- private OAuthStorage $oAuthStorage;
+ // private OAuthStorage $oAuthStorage;
private TokenStorageInterface $tokenStorage;
public function __construct(
LoggableListener $loggableListener,
TokenStorageInterface $tokenStorage,
- AuthorizationCheckerInterface $authorizationChecker,
- OAuthStorage $oAuthStorage
+ AuthorizationCheckerInterface $authorizationChecker
+ // OAuthStorage $oAuthStorage
) {
$this->loggableListener = $loggableListener;
$this->tokenStorage = $tokenStorage;
$this->authorizationChecker = $authorizationChecker;
- $this->oAuthStorage = $oAuthStorage;
+ // $this->oAuthStorage = $oAuthStorage;
}
public function onKernelRequest(RequestEvent $event): void
@@ -51,14 +49,14 @@ public function onKernelRequest(RequestEvent $event): void
return;
}
- if (null !== $this->oAuthStorage && $token instanceof OAuthToken) {
- /** @var AccessToken $accessToken */
+ /*if (null !== $this->oAuthStorage && $token instanceof OAuthToken) {
+ /** @var AccessToken $accessToken * /
$accessToken = $this->oAuthStorage->getAccessToken($token->getToken());
$user = $accessToken->getUser();
if (null !== $user) {
$username = $user->getUsername();
$this->loggableListener->setUsername($username);
}
- }
+ }*/
}
}
diff --git a/src/Repository/ChurchRepository.php b/src/Repository/ChurchRepository.php
index b9a6006..c03ae46 100644
--- a/src/Repository/ChurchRepository.php
+++ b/src/Repository/ChurchRepository.php
@@ -4,7 +4,7 @@
use App\Entity\Church;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
-use Doctrine\Common\Persistence\ManagerRegistry;
+use Doctrine\Persistence\ManagerRegistry;
/**
* @method Church|null find($id, $lockMode = null, $lockVersion = null)
diff --git a/src/Repository/DioceseRepository.php b/src/Repository/DioceseRepository.php
index 15594dc..e3fc150 100644
--- a/src/Repository/DioceseRepository.php
+++ b/src/Repository/DioceseRepository.php
@@ -4,7 +4,7 @@
use App\Entity\Diocese;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
-use Doctrine\Common\Persistence\ManagerRegistry;
+use Doctrine\Persistence\ManagerRegistry;
/**
* @method Diocese|null find($id, $lockMode = null, $lockVersion = null)
diff --git a/src/Repository/ParishRepository.php b/src/Repository/ParishRepository.php
index b66d582..7d91320 100644
--- a/src/Repository/ParishRepository.php
+++ b/src/Repository/ParishRepository.php
@@ -4,7 +4,7 @@
use App\Entity\Parish;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
-use Doctrine\Common\Persistence\ManagerRegistry;
+use Doctrine\Persistence\ManagerRegistry;
/**
* @method Parish|null find($id, $lockMode = null, $lockVersion = null)
diff --git a/symfony.lock b/symfony.lock
index 8b77540..eb3fda8 100644
--- a/symfony.lock
+++ b/symfony.lock
@@ -50,9 +50,6 @@
"ref": "ae205d5114e719deb64d2110f56ef910787d1e04"
}
},
- "doctrine/doctrine-cache-bundle": {
- "version": "1.3.3"
- },
"doctrine/doctrine-migrations-bundle": {
"version": "1.2",
"recipe": {
@@ -83,9 +80,6 @@
"doctrine/persistence": {
"version": "v1.0.0"
},
- "doctrine/reflection": {
- "version": "v1.0.0"
- },
"elasticsearch/elasticsearch": {
"version": "v6.0.1"
},
@@ -122,21 +116,12 @@
"ref": "3f73f240ee0c3719e89f1c994ce66904e2ef84f6"
}
},
- "friendsofsymfony/oauth-server-bundle": {
- "version": "1.6.1"
- },
- "friendsofsymfony/oauth2-php": {
- "version": "1.2.3"
- },
"friendsofsymfony/user-bundle": {
"version": "v2.1.2"
},
"gedmo/doctrine-extensions": {
"version": "v2.4.36"
},
- "jdorn/sql-formatter": {
- "version": "v1.2.17"
- },
"myclabs/deep-copy": {
"version": "1.8.1"
},
@@ -158,15 +143,9 @@
"ocramius/package-versions": {
"version": "1.3.0"
},
- "ocramius/proxy-manager": {
- "version": "2.1.1"
- },
"pagerfanta/pagerfanta": {
"version": "v1.1.0"
},
- "paragonie/random_compat": {
- "version": "v2.0.17"
- },
"phar-io/manifest": {
"version": "1.0.1"
},
@@ -176,8 +155,17 @@
"php": {
"version": "7.1"
},
- "php-cs-fixer/diff": {
- "version": "v1.3.1"
+ "php-http/discovery": {
+ "version": "1.19",
+ "recipe": {
+ "repo": "github.com/symfony/recipes",
+ "branch": "main",
+ "version": "1.18",
+ "ref": "f45b5dd173a27873ab19f5e3180b2f661c21de02"
+ },
+ "files": [
+ "config/packages/http_discovery.yaml"
+ ]
},
"phpdocumentor/reflection-common": {
"version": "1.0.1"
@@ -188,9 +176,6 @@
"phpdocumentor/type-resolver": {
"version": "0.4.0"
},
- "phpspec/prophecy": {
- "version": "1.8.0"
- },
"phpstan/phpstan": {
"version": "0.12.51"
},
@@ -212,9 +197,6 @@
"phpunit/php-timer": {
"version": "1.0.9"
},
- "phpunit/php-token-stream": {
- "version": "2.0.2"
- },
"phpunit/phpunit": {
"version": "4.7",
"recipe": {
@@ -224,9 +206,6 @@
"ref": "c276fa48d4713de91eb410289b3b1834acb7e403"
}
},
- "phpunit/phpunit-mock-objects": {
- "version": "5.0.8"
- },
"psr/cache": {
"version": "1.0.1"
},
@@ -326,8 +305,17 @@
"symfony/css-selector": {
"version": "v4.2.1"
},
- "symfony/debug": {
- "version": "v4.1.1"
+ "symfony/debug-bundle": {
+ "version": "5.4",
+ "recipe": {
+ "repo": "github.com/symfony/recipes",
+ "branch": "main",
+ "version": "5.3",
+ "ref": "5aa8aa48234c8eb6dbdd7b3cd5d791485d2cec4b"
+ },
+ "files": [
+ "config/packages/debug.yaml"
+ ]
},
"symfony/dependency-injection": {
"version": "v4.1.1"
@@ -389,15 +377,6 @@
"symfony/http-kernel": {
"version": "v4.1.1"
},
- "symfony/inflector": {
- "version": "v4.1.1"
- },
- "symfony/intl": {
- "version": "v4.1.3"
- },
- "symfony/lts": {
- "version": "4-dev"
- },
"symfony/maker-bundle": {
"version": "1.0",
"recipe": {
@@ -407,30 +386,36 @@
"ref": "fadbfe33303a76e25cb63401050439aa9b1a9c7f"
}
},
- "symfony/mime": {
- "version": "v4.4.0"
- },
"symfony/options-resolver": {
"version": "v4.1.1"
},
"symfony/orm-pack": {
"version": "v2.0.0"
},
+ "symfony/phpunit-bridge": {
+ "version": "7.1",
+ "recipe": {
+ "repo": "github.com/symfony/recipes",
+ "branch": "main",
+ "version": "6.3",
+ "ref": "a411a0480041243d97382cac7984f7dce7813c08"
+ },
+ "files": [
+ ".env.test",
+ "bin/phpunit",
+ "phpunit.xml.dist",
+ "tests/bootstrap.php"
+ ]
+ },
"symfony/polyfill-intl-icu": {
"version": "v1.8.0"
},
- "symfony/polyfill-intl-idn": {
- "version": "v1.12.0"
- },
"symfony/polyfill-intl-normalizer": {
"version": "v1.19.0"
},
"symfony/polyfill-mbstring": {
"version": "v1.8.0"
},
- "symfony/polyfill-php72": {
- "version": "v1.10.0"
- },
"symfony/polyfill-php73": {
"version": "v1.12.0"
},
@@ -539,15 +524,6 @@
"ref": "6bdfa1a95f6b2e677ab985cd1af2eae35d62e0f6"
}
},
- "symfony/web-server-bundle": {
- "version": "3.3",
- "recipe": {
- "repo": "github.com/symfony/recipes",
- "branch": "master",
- "version": "3.3",
- "ref": "dae9b39fd6717970be7601101ce5aa960bf53d9a"
- }
- },
"symfony/webpack-encore-pack": {
"version": "1.0",
"recipe": {
@@ -563,6 +539,9 @@
"theseer/tokenizer": {
"version": "1.1.0"
},
+ "twig/extra-bundle": {
+ "version": "v3.10.0"
+ },
"twig/twig": {
"version": "v2.5.0"
},
diff --git a/templates/home/index.html.twig b/templates/home/index.html.twig
index 1524a62..71fec51 100644
--- a/templates/home/index.html.twig
+++ b/templates/home/index.html.twig
@@ -31,7 +31,7 @@
🕊 Open source
-
Un projet en PHP, MySQL et ElasticSearch, se reposant sur Symfony 4, API Platform, FOSElasticaBundle, FOSOAuthServerBundle.
+
Un projet en PHP, MySQL et ElasticSearch, se reposant sur Symfony, API Platform, FOSElasticaBundle{# , FOSOAuthServerBundle#}.
diff --git a/tests/bootstrap.php b/tests/bootstrap.php
new file mode 100644
index 0000000..47a5855
--- /dev/null
+++ b/tests/bootstrap.php
@@ -0,0 +1,13 @@
+bootEnv(dirname(__DIR__).'/.env');
+}
+
+if ($_SERVER['APP_DEBUG']) {
+ umask(0000);
+}