diff options
author | phecho <phecho@163.com> | 2016-12-13 19:49:16 +0800 |
---|---|---|
committer | phecho <phecho@163.com> | 2016-12-13 19:49:16 +0800 |
commit | 89feb0ae03c5a492526df077b2a3b382b0428ca8 (patch) | |
tree | 19d2c52ecdeda45179957515b7e9fb8b1acc3300 /app/Controller/FileViewerController.php | |
parent | f83178bef8084bfe57963b1820e73b4a9ab0bab5 (diff) |
Implement feature #2843
Diffstat (limited to 'app/Controller/FileViewerController.php')
-rw-r--r-- | app/Controller/FileViewerController.php | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/app/Controller/FileViewerController.php b/app/Controller/FileViewerController.php index 518f5b0b..3e0182ba 100644 --- a/app/Controller/FileViewerController.php +++ b/app/Controller/FileViewerController.php @@ -83,6 +83,31 @@ class FileViewerController extends BaseController } /** + * Display file in browser + * + * @access public + */ + public function browser() + { + $file = $this->getFile(); + $etag = md5($file['path']); + $this->response->withContentType($this->helper->file->getBrowserViewType($file['name'])); + $this->response->withCache(5 * 86400, $etag); + + if ($this->request->getHeader('If-None-Match') === '"'.$etag.'"') { + $this->response->status(304); + } else { + + try { + $this->response->send(); + $this->objectStorage->output($file['path']); + } catch (ObjectStorageException $e) { + $this->logger->error($e->getMessage()); + } + } + } + + /** * Display image thumbnail * * @access public |