diff options
Diffstat (limited to 'inc/poche')
-rwxr-xr-x | inc/poche/Poche.class.php | 4 | ||||
-rwxr-xr-x | inc/poche/Routing.class.php | 13 | ||||
-rw-r--r-- | inc/poche/Template.class.php | 6 | ||||
-rwxr-xr-x | inc/poche/Tools.class.php | 2 | ||||
-rw-r--r-- | inc/poche/WallabagEBooks.class.php | 246 | ||||
-rw-r--r-- | inc/poche/WallabagEpub.class.php | 135 | ||||
-rwxr-xr-x | inc/poche/config.inc.default.php | 10 | ||||
-rwxr-xr-x | inc/poche/global.inc.php | 9 |
8 files changed, 281 insertions, 144 deletions
diff --git a/inc/poche/Poche.class.php b/inc/poche/Poche.class.php index ecb2a51f..27d6f4a6 100755 --- a/inc/poche/Poche.class.php +++ b/inc/poche/Poche.class.php | |||
@@ -314,6 +314,8 @@ class Poche | |||
314 | 314 | ||
315 | switch ($view) | 315 | switch ($view) |
316 | { | 316 | { |
317 | case 'about': | ||
318 | break; | ||
317 | case 'config': | 319 | case 'config': |
318 | $dev_infos = $this->_getPocheVersion('dev'); | 320 | $dev_infos = $this->_getPocheVersion('dev'); |
319 | $dev = trim($dev_infos[0]); | 321 | $dev = trim($dev_infos[0]); |
@@ -810,4 +812,4 @@ class Poche | |||
810 | } | 812 | } |
811 | 813 | ||
812 | 814 | ||
813 | } | 815 | } \ No newline at end of file |
diff --git a/inc/poche/Routing.class.php b/inc/poche/Routing.class.php index 6ae93d21..5acd08ba 100755 --- a/inc/poche/Routing.class.php +++ b/inc/poche/Routing.class.php | |||
@@ -120,7 +120,16 @@ class Routing | |||
120 | $this->wallabag->deleteUser($_POST['password4deletinguser']); | 120 | $this->wallabag->deleteUser($_POST['password4deletinguser']); |
121 | } elseif (isset($_GET['epub'])) { | 121 | } elseif (isset($_GET['epub'])) { |
122 | $epub = new WallabagEpub($this->wallabag, $_GET['method'], $_GET['value']); | 122 | $epub = new WallabagEpub($this->wallabag, $_GET['method'], $_GET['value']); |
123 | $epub->run(); | 123 | $epub->prepareData(); |
124 | $epub->produceEpub(); | ||
125 | } elseif (isset($_GET['mobi'])) { | ||
126 | $mobi = new WallabagMobi($this->wallabag, $_GET['method'], $_GET['value']); | ||
127 | $mobi->prepareData(); | ||
128 | $mobi->produceMobi(); | ||
129 | } elseif (isset($_GET['pdf'])) { | ||
130 | $pdf = new WallabagPDF($this->wallabag, $_GET['method'], $_GET['value']); | ||
131 | $pdf->prepareData(); | ||
132 | $pdf->producePDF(); | ||
124 | } elseif (isset($_GET['import'])) { | 133 | } elseif (isset($_GET['import'])) { |
125 | $import = $this->wallabag->import(); | 134 | $import = $this->wallabag->import(); |
126 | $tplVars = array_merge($this->vars, $import); | 135 | $tplVars = array_merge($this->vars, $import); |
@@ -148,4 +157,4 @@ class Routing | |||
148 | { | 157 | { |
149 | echo $this->wallabag->tpl->render($file, $vars); | 158 | echo $this->wallabag->tpl->render($file, $vars); |
150 | } | 159 | } |
151 | } \ No newline at end of file | 160 | } |
diff --git a/inc/poche/Template.class.php b/inc/poche/Template.class.php index b686f2ec..4d0bfdbb 100644 --- a/inc/poche/Template.class.php +++ b/inc/poche/Template.class.php | |||
@@ -24,7 +24,7 @@ class Template extends Twig_Environment | |||
24 | 24 | ||
25 | $themeDirectory = (is_null($pocheUser) ? DEFAULT_THEME : $pocheUser->getConfigValue('theme')); | 25 | $themeDirectory = (is_null($pocheUser) ? DEFAULT_THEME : $pocheUser->getConfigValue('theme')); |
26 | 26 | ||
27 | if ($themeDirectory === false) { | 27 | if ($themeDirectory === false || !is_dir(THEME . '/' . $themeDirectory)) { |
28 | $themeDirectory = DEFAULT_THEME; | 28 | $themeDirectory = DEFAULT_THEME; |
29 | } | 29 | } |
30 | 30 | ||
@@ -181,7 +181,7 @@ class Template extends Twig_Environment | |||
181 | while (($theme = readdir($handle)) !== false) { | 181 | while (($theme = readdir($handle)) !== false) { |
182 | # Themes are stored in a directory, so all directory names are themes | 182 | # Themes are stored in a directory, so all directory names are themes |
183 | # @todo move theme installation data to database | 183 | # @todo move theme installation data to database |
184 | if (!is_dir(THEME . '/' . $theme) || in_array($theme, array('.', '..'))) { | 184 | if (!is_dir(THEME . '/' . $theme) || in_array($theme, array('.', '..', '_global'))) { |
185 | continue; | 185 | continue; |
186 | } | 186 | } |
187 | 187 | ||
@@ -232,4 +232,4 @@ class Template extends Twig_Environment | |||
232 | Tools::emptyCache(); | 232 | Tools::emptyCache(); |
233 | Tools::redirect('?view=config'); | 233 | Tools::redirect('?view=config'); |
234 | } | 234 | } |
235 | } \ No newline at end of file | 235 | } |
diff --git a/inc/poche/Tools.class.php b/inc/poche/Tools.class.php index beb4f30c..f803e3b5 100755 --- a/inc/poche/Tools.class.php +++ b/inc/poche/Tools.class.php | |||
@@ -117,7 +117,7 @@ final class Tools | |||
117 | { | 117 | { |
118 | $views = array( | 118 | $views = array( |
119 | 'install', 'import', 'export', 'config', 'tags', | 119 | 'install', 'import', 'export', 'config', 'tags', |
120 | 'edit-tags', 'view', 'login', 'error' | 120 | 'edit-tags', 'view', 'login', 'error', 'about' |
121 | ); | 121 | ); |
122 | 122 | ||
123 | return (in_array($view, $views) ? $view . '.twig' : 'home.twig'); | 123 | return (in_array($view, $views) ? $view . '.twig' : 'home.twig'); |
diff --git a/inc/poche/WallabagEBooks.class.php b/inc/poche/WallabagEBooks.class.php new file mode 100644 index 00000000..bc40990b --- /dev/null +++ b/inc/poche/WallabagEBooks.class.php | |||
@@ -0,0 +1,246 @@ | |||
1 | <?php | ||
2 | /** | ||
3 | * wallabag, self hostable application allowing you to not miss any content anymore | ||
4 | * | ||
5 | * @category wallabag | ||
6 | * @author Nicolas LÅ“uillet <nicolas@loeuillet.org> | ||
7 | * @copyright 2013 | ||
8 | * @license http://opensource.org/licenses/MIT see COPYING file | ||
9 | */ | ||
10 | |||
11 | class WallabagEBooks | ||
12 | { | ||
13 | protected $wallabag; | ||
14 | protected $method; | ||
15 | protected $value; | ||
16 | protected $entries; | ||
17 | protected $bookTitle; | ||
18 | protected $bookFileName; | ||
19 | protected $author = 'wallabag'; | ||
20 | |||
21 | public function __construct(Poche $wallabag, $method, $value) | ||
22 | { | ||
23 | $this->wallabag = $wallabag; | ||
24 | $this->method = $method; | ||
25 | $this->value = $value; | ||
26 | } | ||
27 | |||
28 | public function prepareData() | ||
29 | { | ||
30 | switch ($this->method) { | ||
31 | case 'id': | ||
32 | $entryID = filter_var($this->value, FILTER_SANITIZE_NUMBER_INT); | ||
33 | $entry = $this->wallabag->store->retrieveOneById($entryID, $this->wallabag->user->getId()); | ||
34 | $this->entries = array($entry); | ||
35 | $this->bookTitle = $entry['title']; | ||
36 | $this->bookFileName = substr($this->bookTitle, 0, 200); | ||
37 | $this->author = preg_replace('#^w{3}.#', '', Tools::getdomain($entry["url"])); # if only one article, set author to domain name (we strip the eventual www part) | ||
38 | Tools::logm('Producing ebook from article ' . $this->bookTitle); | ||
39 | break; | ||
40 | case 'all': | ||
41 | $this->entries = $this->wallabag->store->retrieveAll($this->wallabag->user->getId()); | ||
42 | $this->bookTitle = sprintf(_('All my articles on %s'), date(_('d.m.y'))); #translatable because each country has it's own date format system | ||
43 | $this->bookFileName = _('Allarticles') . date(_('dmY')); | ||
44 | Tools::logm('Producing ebook from all articles'); | ||
45 | break; | ||
46 | case 'tag': | ||
47 | $tag = filter_var($this->value, FILTER_SANITIZE_STRING); | ||
48 | $tags_id = $this->wallabag->store->retrieveAllTags($this->wallabag->user->getId(), $tag); | ||
49 | $tag_id = $tags_id[0]["id"]; // we take the first result, which is supposed to match perfectly. There must be a workaround. | ||
50 | $this->entries = $this->wallabag->store->retrieveEntriesByTag($tag_id, $this->wallabag->user->getId()); | ||
51 | $this->bookTitle = sprintf(_('Articles tagged %s'), $tag); | ||
52 | $this->bookFileName = substr(sprintf(_('Tag %s'), $tag), 0, 200); | ||
53 | Tools::logm('Producing ebook from tag ' . $tag); | ||
54 | break; | ||
55 | case 'category': | ||
56 | $category = filter_var($this->value, FILTER_SANITIZE_STRING); | ||
57 | $this->entries = $this->wallabag->store->getEntriesByView($category, $this->wallabag->user->getId()); | ||
58 | $this->bookTitle = sprintf(_('Articles in category %s'), $category); | ||
59 | $this->bookFileName = substr(sprintf(_('Category %s'), $category), 0, 200); | ||
60 | Tools::logm('Producing ebook from category ' . $category); | ||
61 | break; | ||
62 | case 'search': | ||
63 | $search = filter_var($this->value, FILTER_SANITIZE_STRING); | ||
64 | Tools::logm($search); | ||
65 | $this->entries = $this->wallabag->store->search($search, $this->wallabag->user->getId()); | ||
66 | $this->bookTitle = sprintf(_('Articles for search %s'), $search); | ||
67 | $this->bookFileName = substr(sprintf(_('Search %s'), $search), 0, 200); | ||
68 | Tools::logm('Producing ebook from search ' . $search); | ||
69 | break; | ||
70 | case 'default': | ||
71 | die(_('Uh, there is a problem while generating eBook.')); | ||
72 | } | ||
73 | } | ||
74 | } | ||
75 | |||
76 | class WallabagEpub extends WallabagEBooks | ||
77 | { | ||
78 | /** | ||
79 | * handle ePub | ||
80 | */ | ||
81 | public function produceEpub() | ||
82 | { | ||
83 | Tools::logm('Starting to produce ePub 3 file'); | ||
84 | $content_start = | ||
85 | "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" | ||
86 | . "<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:epub=\"http://www.idpf.org/2007/ops\">\n" | ||
87 | . "<head>" | ||
88 | . "<meta http-equiv=\"Default-Style\" content=\"text/html; charset=utf-8\" />\n" | ||
89 | . "<title>" . _("wallabag articles book") . "</title>\n" | ||
90 | . "</head>\n" | ||
91 | . "<body>\n"; | ||
92 | |||
93 | $bookEnd = "</body>\n</html>\n"; | ||
94 | |||
95 | $log = new Logger("wallabag", TRUE); | ||
96 | $fileDir = CACHE; | ||
97 | |||
98 | $book = new EPub(EPub::BOOK_VERSION_EPUB3, DEBUG_POCHE); | ||
99 | $log->logLine("new EPub()"); | ||
100 | $log->logLine("EPub class version: " . EPub::VERSION); | ||
101 | $log->logLine("EPub Req. Zip version: " . EPub::REQ_ZIP_VERSION); | ||
102 | $log->logLine("Zip version: " . Zip::VERSION); | ||
103 | $log->logLine("getCurrentServerURL: " . $book->getCurrentServerURL()); | ||
104 | $log->logLine("getCurrentPageURL..: " . $book->getCurrentPageURL()); | ||
105 | |||
106 | Tools::logm('Filling metadata for ePub...'); | ||
107 | |||
108 | $book->setTitle($this->bookTitle); | ||
109 | $book->setIdentifier("http://$_SERVER[HTTP_HOST]", EPub::IDENTIFIER_URI); // Could also be the ISBN number, prefered for published books, or a UUID. | ||
110 | //$book->setLanguage("en"); // Not needed, but included for the example, Language is mandatory, but EPub defaults to "en". Use RFC3066 Language codes, such as "en", "da", "fr" etc. | ||
111 | $book->setDescription(_("Some articles saved on my wallabag")); | ||
112 | $book->setAuthor($this->author,$this->author); | ||
113 | $book->setPublisher("wallabag", "wallabag"); // I hope this is a non existant address :) | ||
114 | $book->setDate(time()); // Strictly not needed as the book date defaults to time(). | ||
115 | //$book->setRights("Copyright and licence information specific for the book."); // As this is generated, this _could_ contain the name or licence information of the user who purchased the book, if needed. If this is used that way, the identifier must also be made unique for the book. | ||
116 | $book->setSourceURL("http://$_SERVER[HTTP_HOST]"); | ||
117 | |||
118 | $book->addDublinCoreMetadata(DublinCore::CONTRIBUTOR, "PHP"); | ||
119 | $book->addDublinCoreMetadata(DublinCore::CONTRIBUTOR, "wallabag"); | ||
120 | |||
121 | $cssData = "body {\n margin-left: .5em;\n margin-right: .5em;\n text-align: justify;\n}\n\np {\n font-family: serif;\n font-size: 10pt;\n text-align: justify;\n text-indent: 1em;\n margin-top: 0px;\n margin-bottom: 1ex;\n}\n\nh1, h2 {\n font-family: sans-serif;\n font-style: italic;\n text-align: center;\n background-color: #6b879c;\n color: white;\n width: 100%;\n}\n\nh1 {\n margin-bottom: 2px;\n}\n\nh2 {\n margin-top: -2px;\n margin-bottom: 2px;\n}\n"; | ||
122 | |||
123 | $log->logLine("Add Cover"); | ||
124 | |||
125 | $fullTitle = "<h1> " . $this->bookTitle . "</h1>\n"; | ||
126 | |||
127 | $book->setCoverImage("Cover.png", file_get_contents("themes/_global/img/appicon/apple-touch-icon-152.png"), "image/png", $fullTitle); | ||
128 | |||
129 | $cover = $content_start . '<div style="text-align:center;"><p>' . _('Produced by wallabag with PHPePub') . '</p><p>'. _('Please open <a href="https://github.com/wallabag/wallabag/issues" >an issue</a> if you have trouble with the display of this E-Book on your device.') . '</p></div>' . $bookEnd; | ||
130 | |||
131 | //$book->addChapter("Table of Contents", "TOC.xhtml", NULL, false, EPub::EXTERNAL_REF_IGNORE); | ||
132 | $book->addChapter("Notices", "Cover2.html", $cover); | ||
133 | |||
134 | $book->buildTOC(); | ||
135 | |||
136 | Tools::logm('Adding actual content...'); | ||
137 | |||
138 | foreach ($this->entries as $entry) { //set tags as subjects | ||
139 | $tags = $this->wallabag->store->retrieveTagsByEntry($entry['id']); | ||
140 | foreach ($tags as $tag) { | ||
141 | $book->setSubject($tag['value']); | ||
142 | } | ||
143 | |||
144 | $log->logLine("Set up parameters"); | ||
145 | |||
146 | $chapter = $content_start . $entry['content'] . $bookEnd; | ||
147 | $book->addChapter($entry['title'], htmlspecialchars($entry['title']) . ".html", $chapter, true, EPub::EXTERNAL_REF_ADD); | ||
148 | $log->logLine("Added chapter " . $entry['title']); | ||
149 | } | ||
150 | |||
151 | if (DEBUG_POCHE) { | ||
152 | $book->addChapter("Log", "Log.html", $content_start . $log->getLog() . "\n</pre>" . $bookEnd); // log generation | ||
153 | Tools::logm('Production log available in produced file'); | ||
154 | } | ||
155 | $book->finalize(); | ||
156 | $zipData = $book->sendBook($this->bookFileName); | ||
157 | Tools::logm('Ebook produced'); | ||
158 | } | ||
159 | } | ||
160 | |||
161 | class WallabagMobi extends WallabagEBooks | ||
162 | { | ||
163 | /** | ||
164 | * MOBI Class | ||
165 | * @author Sander Kromwijk | ||
166 | */ | ||
167 | |||
168 | public function produceMobi() | ||
169 | { | ||
170 | |||
171 | Tools::logm('Starting to produce Mobi file'); | ||
172 | $mobi = new MOBI(); | ||
173 | $content = new MOBIFile(); | ||
174 | |||
175 | $messages = new Messages(); // for later | ||
176 | |||
177 | Tools::logm('Filling metadata for Mobi...'); | ||
178 | |||
179 | $content->set("title", $this->bookTitle); | ||
180 | $content->set("author", $this->author); | ||
181 | $content->set("subject", $this->bookTitle); | ||
182 | |||
183 | # introduction | ||
184 | $content->appendParagraph('<div style="text-align:center;" ><p>' . _('Produced by wallabag with PHPMobi') . '</p><p>'. _('Please open <a href="https://github.com/wallabag/wallabag/issues" >an issue</a> if you have trouble with the display of this E-Book on your device.') . '</p></div>'); | ||
185 | $content->appendImage(imagecreatefrompng("themes/_global/img/appicon/apple-touch-icon-152.png")); | ||
186 | $content->appendPageBreak(); | ||
187 | |||
188 | Tools::logm('Adding actual content...'); | ||
189 | |||
190 | foreach ($this->entries as $item) { | ||
191 | $content->appendChapterTitle($item['title']); | ||
192 | $content->appendParagraph($item['content']); | ||
193 | $content->appendPageBreak(); | ||
194 | } | ||
195 | $mobi->setContentProvider($content); | ||
196 | |||
197 | // we offer file to download | ||
198 | $mobi->download($this->bookFileName.'.mobi'); | ||
199 | Tools::logm('Mobi file produced'); | ||
200 | } | ||
201 | } | ||
202 | |||
203 | class WallabagPDF extends WallabagEbooks | ||
204 | { | ||
205 | public function producePDF() | ||
206 | { | ||
207 | |||
208 | Tools::logm('Starting to produce PDF file'); | ||
209 | |||
210 | $pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false); | ||
211 | |||
212 | Tools::logm('Filling metadata for PDF...'); | ||
213 | $pdf->SetCreator(PDF_CREATOR); | ||
214 | $pdf->SetAuthor(''); | ||
215 | $pdf->SetTitle($this->bookTitle); | ||
216 | $pdf->SetSubject('TCPDF Tutorial'); | ||
217 | $pdf->SetKeywords('TCPDF, PDF, example, test, guide'); | ||
218 | |||
219 | Tools::logm('Adding introduction...'); | ||
220 | $pdf->AddPage(); | ||
221 | $intro = '<h1>' . $this->bookTitle . '</h1><div style="text-align:center;" > | ||
222 | <p>' . _('Produced by wallabag with tcpdf') . '</p> | ||
223 | <p>'. _('Please open <a href="https://github.com/wallabag/wallabag/issues" >an issue</a> if you have trouble with the display of this E-Book on your device.') . '</p> | ||
224 | <img src="themes/_global/img/appicon/apple-touch-icon-152.png" /></div>'; | ||
225 | |||
226 | |||
227 | $pdf->writeHTMLCell(0, 0, '', '', $intro, 0, 1, 0, true, '', true); | ||
228 | |||
229 | $i = 1; | ||
230 | Tools::logm('Adding actual content...'); | ||
231 | foreach ($this->entries as $item) { | ||
232 | $pdf->AddPage(); | ||
233 | $html = '<h1>' . $item['title'] . '</h1>'; | ||
234 | $html .= $item['content']; | ||
235 | $pdf->writeHTMLCell(0, 0, '', '', $html, 0, 1, 0, true, '', true); | ||
236 | $i = $i+1; | ||
237 | } | ||
238 | |||
239 | // set image scale factor | ||
240 | $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO); | ||
241 | |||
242 | |||
243 | $pdf->Output($this->bookFileName . '.pdf', 'FD'); | ||
244 | |||
245 | } | ||
246 | } | ||
diff --git a/inc/poche/WallabagEpub.class.php b/inc/poche/WallabagEpub.class.php deleted file mode 100644 index 9c4d3566..00000000 --- a/inc/poche/WallabagEpub.class.php +++ /dev/null | |||
@@ -1,135 +0,0 @@ | |||
1 | <?php | ||
2 | /** | ||
3 | * wallabag, self hostable application allowing you to not miss any content anymore | ||
4 | * | ||
5 | * @category wallabag | ||
6 | * @author Nicolas LÅ“uillet <nicolas@loeuillet.org> | ||
7 | * @copyright 2013 | ||
8 | * @license http://opensource.org/licenses/MIT see COPYING file | ||
9 | */ | ||
10 | |||
11 | class WallabagEpub | ||
12 | { | ||
13 | protected $wallabag; | ||
14 | protected $method; | ||
15 | protected $value; | ||
16 | |||
17 | public function __construct(Poche $wallabag, $method, $value) | ||
18 | { | ||
19 | $this->wallabag = $wallabag; | ||
20 | $this->method = $method; | ||
21 | $this->value = $value; | ||
22 | } | ||
23 | |||
24 | /** | ||
25 | * handle ePub | ||
26 | */ | ||
27 | public function run() | ||
28 | { | ||
29 | switch ($this->method) { | ||
30 | case 'id': | ||
31 | $entryID = filter_var($this->value, FILTER_SANITIZE_NUMBER_INT); | ||
32 | $entry = $this->wallabag->store->retrieveOneById($entryID, $this->wallabag->user->getId()); | ||
33 | $entries = array($entry); | ||
34 | $bookTitle = $entry['title']; | ||
35 | $bookFileName = substr($bookTitle, 0, 200); | ||
36 | break; | ||
37 | case 'all': | ||
38 | $entries = $this->wallabag->store->retrieveAll($this->wallabag->user->getId()); | ||
39 | $bookTitle = sprintf(_('All my articles on '), date(_('d.m.y'))); #translatable because each country has it's own date format system | ||
40 | $bookFileName = _('Allarticles') . date(_('dmY')); | ||
41 | break; | ||
42 | case 'tag': | ||
43 | $tag = filter_var($this->value, FILTER_SANITIZE_STRING); | ||
44 | $tags_id = $this->wallabag->store->retrieveAllTags($this->wallabag->user->getId(), $tag); | ||
45 | $tag_id = $tags_id[0]["id"]; // we take the first result, which is supposed to match perfectly. There must be a workaround. | ||
46 | $entries = $this->wallabag->store->retrieveEntriesByTag($tag_id, $this->wallabag->user->getId()); | ||
47 | $bookTitle = sprintf(_('Articles tagged %s'), $tag); | ||
48 | $bookFileName = substr(sprintf(_('Tag %s'), $tag), 0, 200); | ||
49 | break; | ||
50 | case 'category': | ||
51 | $category = filter_var($this->value, FILTER_SANITIZE_STRING); | ||
52 | $entries = $this->wallabag->store->getEntriesByView($category, $this->wallabag->user->getId()); | ||
53 | $bookTitle = sprintf(_('All articles in category %s'), $category); | ||
54 | $bookFileName = substr(sprintf(_('Category %s'), $category), 0, 200); | ||
55 | break; | ||
56 | case 'search': | ||
57 | $search = filter_var($this->value, FILTER_SANITIZE_STRING); | ||
58 | $entries = $this->store->search($search, $this->wallabag->user->getId()); | ||
59 | $bookTitle = sprintf(_('All articles for search %s'), $search); | ||
60 | $bookFileName = substr(sprintf(_('Search %s'), $search), 0, 200); | ||
61 | break; | ||
62 | case 'default': | ||
63 | die(_('Uh, there is a problem while generating epub.')); | ||
64 | } | ||
65 | |||
66 | $content_start = | ||
67 | "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" | ||
68 | . "<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:epub=\"http://www.idpf.org/2007/ops\">\n" | ||
69 | . "<head>" | ||
70 | . "<meta http-equiv=\"Default-Style\" content=\"text/html; charset=utf-8\" />\n" | ||
71 | . "<title>wallabag articles book</title>\n" | ||
72 | . "</head>\n" | ||
73 | . "<body>\n"; | ||
74 | |||
75 | $bookEnd = "</body>\n</html>\n"; | ||
76 | |||
77 | $log = new Logger("wallabag", TRUE); | ||
78 | $fileDir = CACHE; | ||
79 | |||
80 | $book = new EPub(EPub::BOOK_VERSION_EPUB3, DEBUG_POCHE); | ||
81 | $log->logLine("new EPub()"); | ||
82 | $log->logLine("EPub class version: " . EPub::VERSION); | ||
83 | $log->logLine("EPub Req. Zip version: " . EPub::REQ_ZIP_VERSION); | ||
84 | $log->logLine("Zip version: " . Zip::VERSION); | ||
85 | $log->logLine("getCurrentServerURL: " . $book->getCurrentServerURL()); | ||
86 | $log->logLine("getCurrentPageURL..: " . $book->getCurrentPageURL()); | ||
87 | |||
88 | $book->setTitle($bookTitle); | ||
89 | $book->setIdentifier("http://$_SERVER[HTTP_HOST]", EPub::IDENTIFIER_URI); // Could also be the ISBN number, prefered for published books, or a UUID. | ||
90 | //$book->setLanguage("en"); // Not needed, but included for the example, Language is mandatory, but EPub defaults to "en". Use RFC3066 Language codes, such as "en", "da", "fr" etc. | ||
91 | $book->setDescription(_("Some articles saved on my wallabag")); | ||
92 | $book->setAuthor("wallabag", "wallabag"); | ||
93 | $book->setPublisher("wallabag", "wallabag"); // I hope this is a non existant address :) | ||
94 | $book->setDate(time()); // Strictly not needed as the book date defaults to time(). | ||
95 | //$book->setRights("Copyright and licence information specific for the book."); // As this is generated, this _could_ contain the name or licence information of the user who purchased the book, if needed. If this is used that way, the identifier must also be made unique for the book. | ||
96 | $book->setSourceURL("http://$_SERVER[HTTP_HOST]"); | ||
97 | |||
98 | $book->addDublinCoreMetadata(DublinCore::CONTRIBUTOR, "PHP"); | ||
99 | $book->addDublinCoreMetadata(DublinCore::CONTRIBUTOR, "wallabag"); | ||
100 | |||
101 | $cssData = "body {\n margin-left: .5em;\n margin-right: .5em;\n text-align: justify;\n}\n\np {\n font-family: serif;\n font-size: 10pt;\n text-align: justify;\n text-indent: 1em;\n margin-top: 0px;\n margin-bottom: 1ex;\n}\n\nh1, h2 {\n font-family: sans-serif;\n font-style: italic;\n text-align: center;\n background-color: #6b879c;\n color: white;\n width: 100%;\n}\n\nh1 {\n margin-bottom: 2px;\n}\n\nh2 {\n margin-top: -2px;\n margin-bottom: 2px;\n}\n"; | ||
102 | |||
103 | $log->logLine("Add Cover"); | ||
104 | |||
105 | $fullTitle = "<h1> " . $bookTitle . "</h1>\n"; | ||
106 | |||
107 | $book->setCoverImage("Cover.png", file_get_contents("themes/baggy/img/apple-touch-icon-152.png"), "image/png", $fullTitle); | ||
108 | |||
109 | $cover = $content_start . '<div style="text-align:center;"><p>' . _('Produced by wallabag with PHPePub') . '</p><p>'. _('Please open <a href="https://github.com/wallabag/wallabag/issues" >an issue</a> if you have trouble with the display of this E-Book on your device.') . '</p></div>' . $bookEnd; | ||
110 | |||
111 | //$book->addChapter("Table of Contents", "TOC.xhtml", NULL, false, EPub::EXTERNAL_REF_IGNORE); | ||
112 | $book->addChapter("Notices", "Cover2.html", $cover); | ||
113 | |||
114 | $book->buildTOC(); | ||
115 | |||
116 | foreach ($entries as $entry) { //set tags as subjects | ||
117 | $tags = $this->wallabag->store->retrieveTagsByEntry($entry['id']); | ||
118 | foreach ($tags as $tag) { | ||
119 | $book->setSubject($tag['value']); | ||
120 | } | ||
121 | |||
122 | $log->logLine("Set up parameters"); | ||
123 | |||
124 | $chapter = $content_start . $entry['content'] . $bookEnd; | ||
125 | $book->addChapter($entry['title'], htmlspecialchars($entry['title']) . ".html", $chapter, true, EPub::EXTERNAL_REF_ADD); | ||
126 | $log->logLine("Added chapter " . $entry['title']); | ||
127 | } | ||
128 | |||
129 | if (DEBUG_POCHE) { | ||
130 | $book->addChapter("Log", "Log.html", $content_start . $log->getLog() . "\n</pre>" . $bookEnd); // log generation | ||
131 | } | ||
132 | $book->finalize(); | ||
133 | $zipData = $book->sendBook($bookFileName); | ||
134 | } | ||
135 | } \ No newline at end of file | ||
diff --git a/inc/poche/config.inc.default.php b/inc/poche/config.inc.default.php index f666f468..a159e713 100755 --- a/inc/poche/config.inc.default.php +++ b/inc/poche/config.inc.default.php | |||
@@ -44,11 +44,20 @@ | |||
44 | @define ('SHARE_MAIL', TRUE); | 44 | @define ('SHARE_MAIL', TRUE); |
45 | @define ('SHARE_SHAARLI', FALSE); | 45 | @define ('SHARE_SHAARLI', FALSE); |
46 | @define ('SHAARLI_URL', 'http://myshaarliurl.com'); | 46 | @define ('SHAARLI_URL', 'http://myshaarliurl.com'); |
47 | @define ('SHARE_DIASPORA', FALSE); | ||
48 | @define ('DIASPORA_URL', 'http://diasporapod.com'); # Don't add a / at the end | ||
47 | @define ('FLATTR', TRUE); | 49 | @define ('FLATTR', TRUE); |
48 | @define ('FLATTR_API', 'https://api.flattr.com/rest/v2/things/lookup/?url='); | 50 | @define ('FLATTR_API', 'https://api.flattr.com/rest/v2/things/lookup/?url='); |
49 | @define ('NOT_FLATTRABLE', '0'); | 51 | @define ('NOT_FLATTRABLE', '0'); |
50 | @define ('FLATTRABLE', '1'); | 52 | @define ('FLATTRABLE', '1'); |
51 | @define ('FLATTRED', '2'); | 53 | @define ('FLATTRED', '2'); |
54 | @define ('CARROT', FALSE); | ||
55 | |||
56 | // ebook | ||
57 | @define ('EPUB', TRUE); | ||
58 | @define ('MOBI', FALSE); | ||
59 | @define ('PDF', FALSE); | ||
60 | |||
52 | // display or not print link in article view | 61 | // display or not print link in article view |
53 | @define ('SHOW_PRINTLINK', '1'); | 62 | @define ('SHOW_PRINTLINK', '1'); |
54 | // display or not percent of read in article view. Affects only default theme. | 63 | // display or not percent of read in article view. Affects only default theme. |
@@ -67,4 +76,3 @@ | |||
67 | @define ('IMPORT_LIMIT', 5); | 76 | @define ('IMPORT_LIMIT', 5); |
68 | //delay between downloads (in sec) | 77 | //delay between downloads (in sec) |
69 | @define ('IMPORT_DELAY', 5); | 78 | @define ('IMPORT_DELAY', 5); |
70 | |||
diff --git a/inc/poche/global.inc.php b/inc/poche/global.inc.php index b8c487e3..728528f8 100755 --- a/inc/poche/global.inc.php +++ b/inc/poche/global.inc.php | |||
@@ -22,7 +22,7 @@ require_once ROOT . '/vendor/autoload.php'; | |||
22 | require_once INCLUDES . '/poche/Template.class.php'; | 22 | require_once INCLUDES . '/poche/Template.class.php'; |
23 | require_once INCLUDES . '/poche/Language.class.php'; | 23 | require_once INCLUDES . '/poche/Language.class.php'; |
24 | require_once INCLUDES . '/poche/Routing.class.php'; | 24 | require_once INCLUDES . '/poche/Routing.class.php'; |
25 | require_once INCLUDES . '/poche/WallabagEpub.class.php'; | 25 | require_once INCLUDES . '/poche/WallabagEBooks.class.php'; |
26 | require_once INCLUDES . '/poche/Poche.class.php'; | 26 | require_once INCLUDES . '/poche/Poche.class.php'; |
27 | 27 | ||
28 | require_once INCLUDES . '/poche/Database.class.php'; | 28 | require_once INCLUDES . '/poche/Database.class.php'; |
@@ -41,6 +41,13 @@ require_once INCLUDES . '/3rdparty/libraries/PHPePub/Logger.php'; | |||
41 | require_once INCLUDES . '/3rdparty/libraries/PHPePub/EPub.php'; | 41 | require_once INCLUDES . '/3rdparty/libraries/PHPePub/EPub.php'; |
42 | require_once INCLUDES . '/3rdparty/libraries/PHPePub/EPubChapterSplitter.php'; | 42 | require_once INCLUDES . '/3rdparty/libraries/PHPePub/EPubChapterSplitter.php'; |
43 | 43 | ||
44 | # mobi library | ||
45 | require_once INCLUDES . '/3rdparty/libraries/MOBIClass/MOBI.php'; | ||
46 | |||
47 | # pdf library | ||
48 | #require_once INCLUDES . '/3rdparty/libraries/mpdf/mpdf.php'; | ||
49 | require_once INCLUDES . '/3rdparty/libraries/tcpdf/tcpdf.php'; | ||
50 | |||
44 | # system configuration; database credentials et caetera | 51 | # system configuration; database credentials et caetera |
45 | require_once INCLUDES . '/poche/config.inc.php'; | 52 | require_once INCLUDES . '/poche/config.inc.php'; |
46 | require_once INCLUDES . '/poche/config.inc.default.php'; | 53 | require_once INCLUDES . '/poche/config.inc.default.php'; |