Example #1
0
 public function refresh($user_id)
 {
     $adapter = $this->sm->get('Zend\\Db\\Adapter\\Adapter');
     $sql = new Sql($adapter);
     do {
         //Generate new hash
         $hash = Application\Model\Util::unique_id();
         //Check if hash is taken
         $select = $sql->select('tokens_table')->where(array('hash' => $hash));
         $selectString = $sql->getSqlStringForSqlObject($select);
         $results = $adapter->query($selectString, $adapter::QUERY_MODE_EXECUTE)->toArray()[0];
     } while ($results);
     //Disable old hashs
     $update = $sql->update('tokens_table')->set(array('enabled' => 0))->where(array('user_id' => $user_id));
     $selectString = $sql->getSqlStringForSqlObject($update);
     $adapter->query($selectString, $adapter::QUERY_MODE_EXECUTE);
     //Create new hash on table
     $insert = $sql->insert('tokens_table')->values(array('user_id' => $user_id, 'hash' => $hash, 'enabled' => true));
     $selectString = $sql->getSqlStringForSqlObject($insert);
     $adapter->query($selectString, $adapter::QUERY_MODE_EXECUTE);
 }
Example #2
0
 /**
  * AllBooks Action
  *
  * Show list of all books and handle Filters and Navigation
  * @return Ambigous <\Zend\Http\Response, \Zend\Stdlib\ResponseInterface>|\Zend\View\Model\ViewModel
  */
 public function allbooksAction()
 {
     //Redirect if not logged
     if (!$this->logged) {
         return $this->redirect()->toRoute('application/default', array('controller' => 'index', 'action' => 'index'));
     }
     //Get query and parameters
     $query = $this->getRequest()->getQuery()->getArrayCopy();
     $params = $this->params()->fromRoute();
     //Update filters
     if (array_key_exists('id', $params)) {
         $filters = unserialize(base64_decode(urldecode($params['id'])));
     } else {
         $filters = array();
     }
     $filters = Application\Model\Util::updateFilter($filters, $query);
     $userFilters = Application\Model\Util::updateParam($filters, array('status' => 'ok'));
     $url = $this->url()->fromRoute('application/default', array('controller' => 'index', 'action' => 'allbooks', 'id' => $filters ? urldecode(base64_encode(serialize($filters))) : null));
     //Setup pages
     $pageSize = 10;
     $page = array_key_exists('page', $query) ? $query['page'] : 1;
     $page = is_numeric($page) ? $page : 1;
     $page = $page <= 0 ? 1 : $page;
     //Apply filters on database
     $sm = $this->getServiceLocator();
     $books = new Books($sm);
     $bookList = $books->listBooks($userFilters);
     $size = count($bookList);
     //List available filters
     $availParams = array();
     if (!array_key_exists('author', $filters)) {
         $availParams = array_merge($availParams, array('Author' => $books->listParams($userFilters, 'author')));
     }
     if (!array_key_exists('serie', $filters)) {
         $availParams = array_merge($availParams, array('Serie' => $books->listParams($userFilters, 'serie')));
     }
     if (!array_key_exists('language', $filters)) {
         $availParams = array_merge($availParams, array('Language' => $books->listParams($userFilters, 'language')));
     }
     $availParams = array_merge($availParams, array('Genre' => $books->listParams($userFilters, 'genre')));
     //Filter non-useful filter params
     foreach ($availParams as $key => $value) {
         for ($i = count($availParams[$key]) - 1; $i >= 0; $i--) {
             if ($availParams[$key][$i]['count'] == $size || $availParams[$key][$i][strtolower($key)] == '') {
                 unset($availParams[$key][$i]);
             }
         }
         if (count($availParams[$key]) == 0) {
             unset($availParams[$key]);
         }
     }
     //Filter results for the page
     $pageMax = ceil($size / $pageSize);
     $page = $page > $pageMax ? $pageMax : $page;
     $pageBookList = array_slice($bookList->toArray(), ($page - 1) * $pageSize, $pageSize);
     //Configure pagination
     $pages = array(array('class' => $page == 1 ? 'disabled' : '', 'name' => '&laquo;', 'href' => Application\Model\Util::addQuery($url, array('page' => 1))));
     for ($i = max(1, min(ceil($size / $pageSize) - 6, $page - 3)); $i <= min($pageMax, max(1, $page - 3) + 6); $i++) {
         array_push($pages, array('class' => $page == $i ? 'active' : '', 'name' => $i, 'href' => Application\Model\Util::addQuery($url, array('page' => $i))));
     }
     array_push($pages, array('class' => $page == $pageMax ? 'disabled' : '', 'name' => '&raquo;', 'href' => Application\Model\Util::addQuery($url, array('page' => $pageMax))));
     //Return results
     return new ViewModel(array('nav' => 2, 'user' => $this->user, 'url' => $url, 'books' => $pageBookList, 'avParams' => $availParams, 'filters' => $filters, 'pages' => $pages, 'size' => $size));
 }
 public function indexAction()
 {
     //Initialize variables
     $sm = $this->getServiceLocator();
     $books = new Books($sm);
     $tokens = new Tokens($sm);
     $users = new Users($sm);
     $renderer = $this->serviceLocator->get('Zend\\View\\Renderer\\RendererInterface');
     //Load hash
     $hash = $this->params()->fromRoute('hash', 0);
     //Check hash validity
     if ($hash) {
         $token = $tokens->checkHash($hash);
         if ($token) {
             $this->logged = $token['enabled'];
             $this->user = $users->userDetails($token['user_id']);
         }
     }
     //Redirecting if not logged
     if (!$this->logged) {
         die("Invalid token");
     }
     //Setup path
     $page = $this->params()->fromRoute('page', 0);
     if (substr($this->params()->fromRoute('index', 0), 0, 6) == 'SEARCH') {
         $index = 'opds:key:' . substr($this->params()->fromRoute('index', 0), 7);
     } else {
         $index = base64_decode(urldecode($this->params()->fromRoute('index', 0)));
     }
     $path = explode(':', $index);
     $filter = array('status' => 'ok');
     //Identify type of page
     $type = 'LIST';
     if ($path[count($path) - 1] != 'LIST') {
         if (count($path) % 2 == 1) {
             $type = 'FILTERS';
         } else {
             $type = 'PARAMS';
         }
     }
     //Prepare XML
     $xmlStr = '<feed xmlns="http://www.w3.org/2005/Atom" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:opds="http://opds-spec.org/2010/catalog"></feed>';
     $xml = new SimpleXMLElement($xmlStr);
     $xml->addChild('title', array_key_exists($path[count($path) - 1], $this->titles) ? $this->titles[$path[count($path) - 1]] : $renderer->escapehtml($path[count($path) - 1]));
     $xml->addChild('id', $renderer->escapehtml($index));
     $xml->addChild('content')->addAttribute('type', 'text');
     $node = $xml->addChild('author');
     $node->addChild('name', 'bookcloud');
     $node->addChild('uri');
     $node->addChild('email', '*****@*****.**');
     //Add initial links (search, Main page, back)
     if (count($path) == 1) {
         $link = $xml->addChild('link');
         $link->addAttribute('rel', 'search');
         $link->addAttribute('title', 'Search Catalog');
         $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
         $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/SEARCH:{searchTerms}");
     } else {
         $link = $xml->addChild('link');
         $link->addAttribute('rel', 'start');
         $link->addAttribute('title', 'Main Catalog');
         $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
         $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/");
         $link = $xml->addChild('link');
         $link->addAttribute('rel', 'breadcrumb');
         $link->addAttribute('title', $renderer->escapehtml($path[count($path) - 2]));
         $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
         $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/" . urlencode(base64_encode(substr($index, 0, strrpos($index, ':')))));
     }
     //Show list of available filters
     if ($type == 'FILTERS') {
         //Setup filter
         for ($i = 1; $i < count($path); $i += 2) {
             $filter = Application\Model\Util::updateFilter($filter, array('a' . $path[$i] => $path[$i + 1]));
         }
         //List filters
         $filter_list = array(array('title' => 'Authors', 'name' => 'author', 'img' => ''), array('title' => 'Series', 'name' => 'serie', 'img' => ''), array('title' => 'Languages', 'name' => 'language', 'img' => ''), array('title' => 'Genres', 'name' => 'genre', 'img' => ''));
         //Create menu items
         foreach ($filter_list as $filter_item) {
             if (!array_key_exists($filter_item['name'], $filter)) {
                 $listParams = $books->listParams($filter, $filter_item['name'], true, true);
                 if (count($listParams) > 1) {
                     $node = $xml->addChild('entry');
                     $node->addChild('title', $filter_item['title']);
                     $node->addChild('id', $renderer->escapehtml($index . ':' . $filter_item['name']));
                     $node->addChild('content', 'Filter books by ' . $filter_item['name'])->addAttribute('type', 'text');
                     $link = $node->addChild('link');
                     $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/" . urlencode(base64_encode($index . ':' . $filter_item['name'])));
                     $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
                     $link = $node->addChild('link');
                     $link->addAttribute('href', $filter_item['img']);
                     $link->addAttribute('type', 'image/png');
                     $link->addAttribute('rel', 'http://opds-spec.org/thumbnail');
                 }
             }
         }
         //Show_all menu
         $node = $xml->addChild('entry');
         $node->addChild('title', 'Show books');
         $node->addChild('id', $renderer->escapehtml($index . ':LIST'));
         $node->addChild('content', 'Show books')->addAttribute('type', 'text');
         $link = $node->addChild('link');
         $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/" . urlencode(base64_encode($index . ':LIST')));
         $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
         $link = $node->addChild('link');
         $link->addAttribute('href', '');
         $link->addAttribute('type', 'image/png');
         $link->addAttribute('rel', 'http://opds-spec.org/thumbnail');
     }
     //Show list of available params
     if ($type == 'PARAMS') {
         //Setup filter
         for ($i = 1; $i < count($path) - 1; $i += 2) {
             $filter = Application\Model\Util::updateFilter($filter, array('a' . $path[$i] => $path[$i + 1]));
         }
         $param_name = $path[count($path) - 1];
         //List params
         $params = $books->listParams($filter, $param_name, false, true);
         //Create menu items
         foreach ($params as $param) {
             $node = $xml->addChild('entry');
             $node->addChild('title', $renderer->escapehtml($param[$param_name]));
             $node->addChild('id', $renderer->escapehtml($index . ':' . $param[$param_name]));
             $node->addChild('content', $param['count'] . ' books available');
             $link = $node->addChild('link');
             $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/" . urlencode(base64_encode($index . ':' . $param[$param_name])));
             $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
         }
     }
     //Show list of books
     if ($type == 'LIST') {
         //Setup filter
         for ($i = 1; $i < count($path) - 1; $i += 2) {
             $filter = Application\Model\Util::updateFilter($filter, array('a' . $path[$i] => $path[$i + 1]));
         }
         //List books
         $bookList = $books->listBooks($filter);
         $size = count($bookList);
         //Setup pages
         $pageSize = 10;
         $page = !$page ? 1 : $page;
         //Filter results for the page
         $pageMax = ceil($size / $pageSize);
         $page = $page > $pageMax ? $pageMax : $page;
         $pageBookList = array_slice($bookList->toArray(), ($page - 1) * $pageSize, $pageSize);
         //Add next and previous page link
         if ($page > 1) {
             $link = $xml->addChild('link');
             $link->addAttribute('rel', 'previous');
             $link->addAttribute('title', 'Previous Page');
             $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
             $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/" . urlencode(base64_encode($index)) . "/" . ($page - 1));
         }
         if ($page < $pageMax) {
             $link = $xml->addChild('link');
             $link->addAttribute('rel', 'next');
             $link->addAttribute('title', 'Next Page');
             $link->addAttribute('type', 'application/atom+xml;type=feed;profile=opds-catalog');
             $link->addAttribute('href', $renderer->url('catalog') . "/{$hash}/" . urlencode(base64_encode($index)) . "/" . ($page + 1));
         }
         //Create menu items
         foreach ($pageBookList as $book) {
             $node = $xml->addChild('entry');
             $node->addChild('title', $renderer->escapehtml($book['title']));
             $node->addChild('id', $renderer->escapehtml('FILE:' . $book['book_id']));
             $node->addChild('updated', $book['date']);
             $node->addChild('author', $renderer->escapehtml($book['author']));
             $node->addChild('summary', $renderer->escapehtml($book['sinopse']));
             $link = $node->addChild('link');
             $link->addAttribute('href', $renderer->url('files', array('action' => 'image', 'arg1' => 'thumb', 'arg2' => $book['book_id'])));
             $link->addAttribute('type', 'image/jpeg');
             $link->addAttribute('rel', 'http://opds-spec.org/thumbnail');
             $link = $node->addChild('link');
             $link->addAttribute('href', $renderer->url('files', array('action' => 'image', 'arg1' => 'reg', 'arg2' => $book['book_id'])));
             $link->addAttribute('type', 'image/jpeg');
             $link->addAttribute('rel', 'http://opds-spec.org/cover');
             $link = $node->addChild('link');
             $link->addAttribute('href', $renderer->url('files', array('action' => 'epub')) . "/{$hash}/" . $book['book_id']);
             $link->addAttribute('type', 'application/epub+zip');
             $link->addAttribute('rel', 'http://opds-spec.org/acquisition');
             $link->addAttribute('title', 'Download this ebook as EPUB');
         }
     }
     //Return XML
     header($_SERVER["SERVER_PROTOCOL"] . " 200 OK");
     header("Content-Type: application/atom+xml; profile=opds-catalog; kind=navigation");
     header("Content-Length:" . strlen($xml->asXML()));
     print $xml->asXML();
     die;
 }