1
|
|
|
<?php |
2
|
|
|
/** |
3
|
|
|
* YAWIK |
4
|
|
|
* |
5
|
|
|
* @filesource |
6
|
|
|
* @copyright (c) 2013 - 2016 Cross Solution (http://cross-solution.de) |
7
|
|
|
* @license MIT |
8
|
|
|
*/ |
9
|
|
|
|
10
|
|
|
/** FileController.php */ |
11
|
|
|
namespace Core\Controller; |
12
|
|
|
|
13
|
|
|
use Core\Listener\Events\FileEvent; |
14
|
|
|
use Organizations\Entity\OrganizationImage; |
15
|
|
|
use Zend\Mvc\Controller\AbstractActionController; |
16
|
|
|
use Zend\View\Model\JsonModel; |
17
|
|
|
use Zend\Mvc\MvcEvent; |
18
|
|
|
use Core\Entity\PermissionsInterface; |
19
|
|
|
|
20
|
|
|
/** |
21
|
|
|
* Class FileController |
22
|
|
|
* |
23
|
|
|
* @method \Acl\Controller\Plugin\Acl acl() |
24
|
|
|
* @package Core\Controller |
25
|
|
|
*/ |
26
|
|
|
class FileController extends AbstractActionController |
27
|
|
|
{ |
28
|
|
View Code Duplication |
protected function attachDefaultListeners() |
|
|
|
|
29
|
|
|
{ |
30
|
|
|
parent::attachDefaultListeners(); |
31
|
|
|
$events = $this->getEventManager(); |
32
|
|
|
$events->attach(MvcEvent::EVENT_DISPATCH, array($this, 'preDispatch'), 10); |
33
|
|
|
|
34
|
|
|
$serviceLocator = $this->serviceLocator; |
35
|
|
|
$defaultServices = $serviceLocator->get('DefaultListeners'); |
36
|
|
|
$events->attach($defaultServices); |
|
|
|
|
37
|
|
|
} |
38
|
|
|
|
39
|
|
|
public function preDispatch(MvcEvent $e) |
40
|
|
|
{ |
41
|
|
|
if ('delete' == $this->params()->fromQuery('do') && $this->getRequest()->isXmlHttpRequest()) { |
|
|
|
|
42
|
|
|
$routeMatch = $e->getRouteMatch(); |
43
|
|
|
$routeMatch->setParam('action', 'delete'); |
44
|
|
|
} |
45
|
|
|
} |
46
|
|
|
|
47
|
|
|
protected function getFile() |
48
|
|
|
{ |
49
|
|
|
$fileStoreName = $this->params('filestore'); |
50
|
|
|
list($module, $entityName) = explode('.', $fileStoreName); |
51
|
|
|
$response = $this->getResponse(); |
52
|
|
|
|
53
|
|
|
try { |
54
|
|
|
$repository = $this->serviceLocator->get('repositories')->get($module . '/' . $entityName); |
55
|
|
|
} catch (\Exception $e) { |
56
|
|
|
$response->setStatusCode(404); |
57
|
|
|
$this->getEvent()->setParam('exception', $e); |
58
|
|
|
return; |
59
|
|
|
} |
60
|
|
|
$fileId = $this->params('fileId', 0); |
61
|
|
|
if (preg_match('/^(.*)\..*$/', $fileId, $baseFileName)) { |
62
|
|
|
$fileId = $baseFileName[1]; |
63
|
|
|
} |
64
|
|
|
$file = $repository->find($fileId); |
65
|
|
|
|
66
|
|
|
if (!$file) { |
67
|
|
|
$response->setStatusCode(404); |
68
|
|
|
} |
69
|
|
|
return $file; |
70
|
|
|
} |
71
|
|
|
|
72
|
|
|
/** |
73
|
|
|
* @return \Zend\Http\PhpEnvironment\Response |
74
|
|
|
*/ |
75
|
|
|
public function indexAction() |
76
|
|
|
{ |
77
|
|
|
/* @var \Zend\Http\PhpEnvironment\Response $response */ |
78
|
|
|
$response = $this->getResponse(); |
79
|
|
|
/* @var \Core\Entity\FileEntity $file */ |
80
|
|
|
$file = $this->getFile(); |
81
|
|
|
|
82
|
|
|
if (!$file) { |
83
|
|
|
return $response; |
84
|
|
|
} |
85
|
|
|
|
86
|
|
|
$this->acl($file); |
|
|
|
|
87
|
|
|
|
88
|
|
|
$headers=$response->getHeaders(); |
89
|
|
|
|
90
|
|
|
$headers->addHeaderline('Content-Type', $file->getType()) |
91
|
|
|
->addHeaderline('Content-Length', $file->getLength()); |
92
|
|
|
|
93
|
|
|
if ($file instanceof OrganizationImage) { |
94
|
|
|
$expireDate = new \DateTime(); |
95
|
|
|
$expireDate->add(new \DateInterval('P1Y')); |
96
|
|
|
|
97
|
|
|
// $headers->addHeaderline('Expires', $expireDate->format(\DateTime::W3C)) |
|
|
|
|
98
|
|
|
// ->addHeaderLine('ETag', $file->getId()) |
99
|
|
|
// ->addHeaderline('Cache-Control', 'public') |
100
|
|
|
// ->addHeaderline('Pragma', 'cache'); |
101
|
|
|
} |
102
|
|
|
|
103
|
|
|
$response->sendHeaders(); |
104
|
|
|
|
105
|
|
|
$resource = $file->getResource(); |
106
|
|
|
|
107
|
|
|
while (!feof($resource)) { |
108
|
|
|
echo fread($resource, 1024); |
109
|
|
|
} |
110
|
|
|
return $response; |
111
|
|
|
} |
112
|
|
|
|
113
|
|
|
public function deleteAction() |
114
|
|
|
{ |
115
|
|
|
$file = $this->getFile(); |
116
|
|
|
if (!$file) { |
117
|
|
|
$this->response->setStatusCode(500); |
|
|
|
|
118
|
|
|
return new JsonModel( |
119
|
|
|
array( |
120
|
|
|
'result' => false, |
121
|
|
|
'message' => ($ex = $this->getEvent()->getParam('exception')) |
122
|
|
|
? $ex->getMessage() |
123
|
|
|
: 'File not found.' |
124
|
|
|
) |
125
|
|
|
); |
126
|
|
|
} |
127
|
|
|
|
128
|
|
|
$this->acl($file, PermissionsInterface::PERMISSION_CHANGE); |
|
|
|
|
129
|
|
|
|
130
|
|
|
|
131
|
|
|
/* @var \Core\EventManager\EventManager $events */ |
132
|
|
|
$events = $this->serviceLocator->get('Core/File/Events'); |
133
|
|
|
$event = $events->getEvent(FileEvent::EVENT_DELETE, $this, ['file' => $file]); |
134
|
|
|
$results = $events->triggerEventUntil(function($r) { return true === $r; }, $event); |
135
|
|
|
|
136
|
|
|
if (true !== $results->last()) { |
137
|
|
|
$this->serviceLocator->get('repositories')->remove($file); |
138
|
|
|
} |
139
|
|
|
|
140
|
|
|
return new JsonModel( |
141
|
|
|
array( |
142
|
|
|
'result' => true |
143
|
|
|
) |
144
|
|
|
); |
145
|
|
|
} |
146
|
|
|
} |
147
|
|
|
|
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.