| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-15 23:14:11 +08:00
										 |  |  | namespace BookStack\Exports\Controllers; | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  | use BookStack\Entities\Queries\ChapterQueries; | 
					
						
							| 
									
										
										
										
											2024-10-15 23:14:11 +08:00
										 |  |  | use BookStack\Exports\ExportFormatter; | 
					
						
							| 
									
										
										
										
											2023-05-19 03:53:39 +08:00
										 |  |  | use BookStack\Http\ApiController; | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  | use Throwable; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ChapterExportApiController extends ApiController | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |     public function __construct( | 
					
						
							|  |  |  |         protected ExportFormatter $exportFormatter, | 
					
						
							|  |  |  |         protected ChapterQueries $queries, | 
					
						
							|  |  |  |     ) { | 
					
						
							| 
									
										
										
										
											2021-08-29 04:48:17 +08:00
										 |  |  |         $this->middleware('can:content-export'); | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Export a chapter as a PDF file. | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  |      * @throws Throwable | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function exportPdf(int $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $chapter = $this->queries->findVisibleByIdOrFail($id); | 
					
						
							| 
									
										
										
										
											2020-11-22 09:26:14 +08:00
										 |  |  |         $pdfContent = $this->exportFormatter->chapterToPdf($chapter); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-09 06:50:42 +08:00
										 |  |  |         return $this->download()->directly($pdfContent, $chapter->slug . '.pdf'); | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Export a chapter as a contained HTML file. | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  |      * @throws Throwable | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function exportHtml(int $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $chapter = $this->queries->findVisibleByIdOrFail($id); | 
					
						
							| 
									
										
										
										
											2020-11-22 09:26:14 +08:00
										 |  |  |         $htmlContent = $this->exportFormatter->chapterToContainedHtml($chapter); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-09 06:50:42 +08:00
										 |  |  |         return $this->download()->directly($htmlContent, $chapter->slug . '.html'); | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Export a chapter as a plain text file. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function exportPlainText(int $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $chapter = $this->queries->findVisibleByIdOrFail($id); | 
					
						
							| 
									
										
										
										
											2020-11-22 09:26:14 +08:00
										 |  |  |         $textContent = $this->exportFormatter->chapterToPlainText($chapter); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-09 06:50:42 +08:00
										 |  |  |         return $this->download()->directly($textContent, $chapter->slug . '.txt'); | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-06-23 04:32:55 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Export a chapter as a markdown file. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function exportMarkdown(int $id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-02-08 05:58:27 +08:00
										 |  |  |         $chapter = $this->queries->findVisibleByIdOrFail($id); | 
					
						
							| 
									
										
										
										
											2021-06-23 04:32:55 +08:00
										 |  |  |         $markdown = $this->exportFormatter->chapterToMarkdown($chapter); | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-09 06:50:42 +08:00
										 |  |  |         return $this->download()->directly($markdown, $chapter->slug . '.md'); | 
					
						
							| 
									
										
										
										
											2021-06-23 04:32:55 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-05-23 07:28:41 +08:00
										 |  |  | } |