/** * Set search session * * @return \Zend\Http\Response */ public function indexAction() { if ($this->getRequest()->isPost()) { $request = $this->getRequest(); $post = $request->getPost()->toArray(); $inputFilter = new ContenutiFormSearchInpuFilter(); $formSearch = new ContenutiFormSearch(); $formSearch->addAnno(); //$formSearch->addInHome(); //$formSearch->addSottosezioni(); $formSearch->addCheckExpired(); $formSearch->setData($post); if ($formSearch->isValid()) { $inputFilter->exchangeArray($formSearch->getData()); $sessioContainer = new SessionContainer(); $sessioContainer->offsetSet(self::sessionIdentifier, array('testo' => $inputFilter->testo, 'sottosezioni' => $inputFilter->sottosezioni, 'inhome' => $inputFilter->inhome)); $referer = $this->getRequest()->getHeader('Referer'); if (is_object($referer)) { return $this->redirect()->toUrl($referer->getUri()); } } $mainLayout = $this->initializeFrontendWebsite(); $moduleUrl = $this->url()->fromRoute('main', array('lang' => 'it')); $referer = $this->getRequest()->getHeader('Referer'); $refererUrl = is_object($referer) ? $referer->getUri() : $moduleUrl; $this->layout()->setVariables(array('formMessages' => $formSearch->getMessages(), 'refererUrl' => $refererUrl, 'moduleUrl' => $moduleUrl, 'moduleLabel' => "Contenuti", 'templatePartial' => 'form-message.phtml')); $this->layout()->setTemplate($mainLayout); } else { $referer = $this->getRequest()->getHeader('Referer'); if (is_object($referer)) { return $this->redirect()->toUrl($referer->getUri()); } return $this->redirect()->toRoute('main'); } }
public function csvAction() { if ($this->getRequest()->isPost()) { $request = $this->getRequest(); $post = array_merge_recursive($request->getPost()->toArray(), $request->getFiles()->toArray()); $form = new ContenutiFormSearch(); $form->addSubmitButton(); $form->setBindOnValidate(false); $form->setData($post); if ($form->isValid()) { $sessionContainer = new SessionContainer(); $sessionContainer->offsetSet('contenutiFormSearch', $post); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); $wrapper = new ContenutiGetterWrapper(new ContenutiGetter($em)); $wrapper->setInput(array('limit' => 1500)); $wrapper->setupQueryBuilder(); $records = $wrapper->getRecords(); $csvExportHelper = new CsvExportHelper(); if (!empty($records)) { $arrayContent = array(); $arrayContent[] = array('Titolo', 'Sottotitolo', 'Testo'); foreach ($records as $record) { $arrayContent[] = array($record['titolo'], $record['sommario'], $record['testo']); } $content = $csvExportHelper->makeCsvLine($arrayContent); $response = $this->getResponse(); $response->getHeaders()->addHeaderLine('Content-Type', 'text/csv')->addHeaderLine('Content-Disposition', 'attachment; filename="contenuti_' . date("dmYHis") . '.csv"')->addHeaderLine('Accept-Ranges', 'bytes')->addHeaderLine('Content-Length', strlen($content)); $response->setContent($content); return $response; } } } return $this->redirectForUnvalidAccess(); }