Overview

Namespaces

  • ApiBundle
    • DataFixtures
      • Faker
        • Provider
    • DependencyInjection
    • Doctrine
      • DBAL
        • Type
      • ORM
        • Filter
          • User
    • Entity
    • EventListener
      • Doctrine
    • Manager
    • Utils
  • FrontBundle
    • Bundle
      • UserBundle
    • Client
      • Exception
    • Controller
    • DependencyInjection
    • Form
      • DataTransformer
      • Type
    • Menu
    • Security
      • Http
        • Authentication
    • Services
      • Http
    • Twig
    • Utils

Classes

  • ApiBundle\ApiBundle
  • ApiBundle\DataFixtures\Faker\Provider\DateTimeProvider
  • ApiBundle\DataFixtures\Faker\Provider\JobProvider
  • ApiBundle\DataFixtures\Faker\Provider\MandateProvider
  • ApiBundle\DataFixtures\Faker\Provider\StudentConventionProvider
  • ApiBundle\DataFixtures\Faker\Provider\UserProvider
  • ApiBundle\DependencyInjection\ApiExtension
  • ApiBundle\Doctrine\DBAL\Type\UTCDateTimeType
  • ApiBundle\Doctrine\ORM\Filter\AbstractResourceSearchFilter
  • ApiBundle\Doctrine\ORM\Filter\User\UserMandateFilter
  • ApiBundle\Doctrine\ORM\Filter\User\UserTypeFilter
  • ApiBundle\Entity\Address
  • ApiBundle\Entity\Job
  • ApiBundle\Entity\Mandate
  • ApiBundle\Entity\StudentConvention
  • ApiBundle\Entity\User
  • ApiBundle\EventListener\Doctrine\JobListener
  • ApiBundle\EventListener\Doctrine\MandateListener
  • ApiBundle\Manager\JobManager
  • ApiBundle\Manager\MandateManager
  • ApiBundle\Manager\UserManager
  • ApiBundle\Utils\UserRoles
  • FrontBundle\Bundle\UserBundle\FrontUserBundle
  • FrontBundle\Client\ApiClient
  • FrontBundle\Controller\BaseController
  • FrontBundle\Controller\DashboardController
  • FrontBundle\Controller\JobController
  • FrontBundle\Controller\MandateController
  • FrontBundle\Controller\UserController
  • FrontBundle\DependencyInjection\FrontExtension
  • FrontBundle\Form\DataTransformer\MandateDateTransformer
  • FrontBundle\Form\DataTransformer\StudentConventionTransformer
  • FrontBundle\Form\Type\JobFilteringType
  • FrontBundle\Form\Type\JobType
  • FrontBundle\Form\Type\MandateType
  • FrontBundle\Form\Type\StudentConventionType
  • FrontBundle\Form\Type\UserFilteringType
  • FrontBundle\Form\Type\UserType
  • FrontBundle\FrontBundle
  • FrontBundle\Menu\MenuBuilder
  • FrontBundle\Security\Http\Authentication\AuthenticationSuccessHandler
  • FrontBundle\Services\Http\RequestBuilder
  • FrontBundle\Services\Http\UrlBuilder
  • FrontBundle\Twig\FrontExtension
  • FrontBundle\Utils\IriHelper
  • FrontBundle\Utils\RoleHierarchyHelper

Interfaces

  • ApiBundle\Manager\NonPersistentEntityManagerInterface
  • FrontBundle\Client\ClientInterface
  • FrontBundle\Client\Exception\ClientException
  • FrontBundle\Controller\ApiControllerInterface
  • Overview
  • Namespace
  • Class
 1:  2:  3:  4:  5:  6:  7:  8:  9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: 70: 71: 72: 73: 74: 75: 76: 77: 78: 
<?php

/*
 * This file is part of the Incipio package.
 *
 * (c) Théo FIDRY <theo.fidry@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace ApiBundle\DataFixtures\Faker\Provider;

use Faker\Provider\DateTime as FakerDateTimeProvider;

/**
 * Faker provider for mandates.
 *
 * @see    ApiBundle\Entity\Mandate
 *
 * @author Théo FIDRY <theo.fidry@gmail.com>
 */
class MandateProvider extends FakerDateTimeProvider
{
    /**
     * Generate a datetime starting from the date given and on a period going from 3 month to 2 years.
     *
     * @param \DateTime $startDate
     *
     * @return \DateTime
     */
    public function endMandateDateTime(\DateTime $startDate)
    {
        $year = (int) $startDate->format('Y');
        $month = (int) $startDate->format('m');

        $startDate = new \DateTime();
        $startDate->setDate($year, $month + 3, 01);

        $endDate = new \DateTime();
        $endDate->setDate($year + 2, $month, 01);

        return $this->dateTimeBetween($startDate, $endDate);
    }

    /**
     * Generate a datetime from the year given.
     *
     * @example
     *   startMandateDateTime()       -> DateTime('2015-05-30 19:28:21')
     *   startMandateDateTime('now')  -> DateTime('2015-05-29 22:30:48')
     *   startMandateDateTime('2014') -> DateTime('2014-02-27 20:52:14')
     *   startMandateDateTime(2012)   -> DateTime('2012-08-23 11:47:02')
     *
     * @param string|int $year A year in integer or string format. If value is invalid, the current year is taken.
     *
     * @return \DateTime
     */
    public function startMandateDateTime($year = 'now')
    {
        // Insure input value is taken as an integer
        if ('string' === gettype($year)) {
            $year = (int) $year;
        }

        // Check if the integer value is a year (and not before J.-C.), if not take this time's year
        if (1000 > $year || 10000 <= $year) {
            $now = new \DateTime();
            $year = (int) $now->format('Y');
        }

        $startDate = new \DateTime(sprintf('%d-01-01', $year));
        $endDate = new \DateTime(sprintf('%d-12-31', $year));

        return $this->dateTimeBetween($startDate, $endDate);
    }
}
API documentation generated by ApiGen