use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
-use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorage;
+use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
class EntryFilterType extends AbstractType
{
/**
* Repository & user are used to get a list of language entries for this user.
*
- * @param EntityRepository $entryRepository
- * @param TokenStorage $token
+ * @param EntityRepository $entryRepository
+ * @param TokenStorageInterface $tokenStorage
*/
- public function __construct(EntityRepository $entryRepository, TokenStorage $token)
+ public function __construct(EntityRepository $entryRepository, TokenStorageInterface $tokenStorage)
{
$this->repository = $entryRepository;
- $this->user = $token->getToken()->getUser();
+
+ $this->user = $tokenStorage->getToken() ? $tokenStorage->getToken()->getUser() : null;
+
+ if (null === $this->user || !is_object($this->user)) {
+ return null;
+ }
}
public function buildForm(FormBuilderInterface $builder, array $options)
if (null === $lower && null === $upper) {
// no value? no filter
return;
- } else if (null === $lower && null !== $upper) {
+ } elseif (null === $lower && null !== $upper) {
// only lower value is defined: query all entries with reading LOWER THAN this value
$expression = $filterQuery->getExpr()->lte($field, $max);
- } else if (null !== $lower && null === $upper) {
+ } elseif (null !== $lower && null === $upper) {
// only upper value is defined: query all entries with reading GREATER THAN this value
$expression = $filterQuery->getExpr()->gte($field, $min);
} else {