/**
  * Show a job executions report
  *
  * @param Request $request
  * @param int     $id
  *
  * @return \Symfony\Component\HttpFoundation\Response|JsonResponse
  */
 public function showAction(Request $request, $id)
 {
     $jobExecution = $this->findOr404('Akeneo\\Component\\Batch\\Model\\JobExecution', $id);
     $this->eventDispatcher->dispatch(JobExecutionEvents::PRE_SHOW, new GenericEvent($jobExecution));
     if ('json' === $request->getRequestFormat()) {
         $archives = [];
         foreach ($this->archivist->getArchives($jobExecution) as $archiveName => $files) {
             $label = $this->translator->transchoice(sprintf('pim_import_export.download_archive.%s', $archiveName), count($files));
             $archives[$archiveName] = ['label' => ucfirst($label), 'files' => $files];
         }
         if (!$this->jobExecutionManager->checkRunningStatus($jobExecution)) {
             $this->jobExecutionManager->markAsFailed($jobExecution);
         }
         // limit the number of step execution returned to avoid memory overflow
         $context = ['limit_warnings' => 100];
         return new JsonResponse(['jobExecution' => $this->serializer->normalize($jobExecution, 'json', $context), 'hasLog' => file_exists($jobExecution->getLogFile()), 'archives' => $archives]);
     }
     return $this->render('PimEnrichBundle:JobTracker:show.html.twig', ['execution' => $jobExecution]);
 }
 /**
  * Reports the approximate distance in time between two times given in seconds
  * or in a valid ISO string like.
  * For example, if the distance is 47 minutes, it'll return
  * "about 1 hour". See the source for the complete wording list.
  *
  * Integers are interpreted as seconds. So, by example to check the distance of time between
  * a created user and their last login:
  * {{ user.createdAt|distance_of_time_in_words(user.lastLoginAt) }} returns "less than a minute".
  *
  * Set include_seconds to true if you want more detailed approximations if distance < 1 minute
  * Set include_months to true if you want approximations in months if days > 30
  *
  * @param string|\DateTime $from_time
  * @param string|\DateTime $to_time
  * @param bool             $include_seconds True to return distance in seconds when it's lower than a minute.
  * @param bool             $include_months
  *
  * @return string
  */
 public function distanceOfTimeInWordsFilter($from_time, $to_time = null, $include_seconds = false, $include_months = false)
 {
     $datetime_transformer = new DateTimeToStringTransformer(null, null, 'Y-m-d H:i:s');
     $timestamp_transformer = new DateTimeToTimestampTransformer();
     // Transform “from” to timestamp
     if ($from_time instanceof \DateTime) {
         $from_time = $timestamp_transformer->transform($from_time);
     } elseif (!is_numeric($from_time)) {
         $from_time = $datetime_transformer->reverseTransform($from_time);
         $from_time = $timestamp_transformer->transform($from_time);
     }
     $to_time = empty($to_time) ? new \DateTime('now') : $to_time;
     // Transform “to” to timestamp
     if ($to_time instanceof \DateTime) {
         $to_time = $timestamp_transformer->transform($to_time);
     } elseif (!is_numeric($to_time)) {
         $to_time = $datetime_transformer->reverseTransform($to_time);
         $to_time = $timestamp_transformer->transform($to_time);
     }
     $future = $to_time < $from_time;
     $distance_in_minutes = round(abs($to_time - $from_time) / 60);
     $distance_in_seconds = round(abs($to_time - $from_time));
     if ($future) {
         return $this->future($distance_in_minutes, $include_seconds, $distance_in_seconds);
     }
     if ($distance_in_minutes <= 1) {
         if ($include_seconds) {
             if ($distance_in_seconds < 5) {
                 return $this->translator->trans('less than %seconds seconds ago', array('%seconds' => 5));
             }
             if ($distance_in_seconds < 10) {
                 return $this->translator->trans('less than %seconds seconds ago', array('%seconds' => 10));
             }
             if ($distance_in_seconds < 20) {
                 return $this->translator->trans('less than %seconds seconds ago', array('%seconds' => 20));
             }
             if ($distance_in_seconds < 40) {
                 return $this->translator->trans('half a minute ago');
             }
             if ($distance_in_seconds < 60) {
                 return $this->translator->trans('less than a minute ago');
             }
             return $this->translator->trans('1 minute ago');
         }
         return $distance_in_minutes == 0 ? $this->translator->trans('less than a minute ago') : $this->translator->trans('1 minute ago');
     }
     if ($distance_in_minutes <= 45) {
         return $this->translator->trans('%minutes minutes ago', array('%minutes' => $distance_in_minutes));
     }
     if ($distance_in_minutes <= 90) {
         return $this->translator->trans('about 1 hour ago');
     }
     if ($distance_in_minutes <= 1440) {
         return $this->translator->trans('about %hours hours ago', array('%hours' => round($distance_in_minutes / 60)));
     }
     if ($distance_in_minutes <= 2880) {
         return $this->translator->trans('1 day ago');
     }
     $distance_in_days = round($distance_in_minutes / 1440);
     if (!$include_months || $distance_in_days <= 30) {
         return $this->translator->trans('%days days ago', array('%days' => round($distance_in_days)));
     }
     if ($distance_in_days < 345) {
         return $this->translator->transchoice('{1} 1 month ago |]1,Inf[ %months months ago', round($distance_in_days / 30), array('%months' => round($distance_in_days / 30)));
     }
     return $this->translator->transchoice('{1} 1 year ago |]1,Inf[ %years years ago', round($distance_in_days / 365), array('%years' => round($distance_in_days / 365)));
 }