Пакет CodeIgniter
CodeIgniter · LGPL-3.0Пакет CodeIgniter обеспечивает интеграцию TCPDF-Next с CodeIgniter 4 — регистрация сервиса, класс Library для контроллеров, асинхронная генерация через очередь и хелперы HTTP-ответов с заголовками безопасности OWASP.
Установка
bash
composer require yeeefang/tcpdf-next-codeigniterТребования: CodeIgniter ^4.0, PHP ^8.5
Конфигурация
Опубликуйте файл конфигурации:
bash
php spark tcpdf-next:publishphp
// app/Config/TcpdfNext.php
namespace Config;
use CodeIgniter\Config\BaseConfig;
class TcpdfNext extends BaseConfig
{
public string $fontsDirectory = WRITEPATH . 'fonts';
public string $defaultPageSize = 'A4';
public string $defaultOrientation = 'portrait';
public bool $autoPageBreak = true;
public float $marginBottom = 25.0;
}Использование через Service
Используйте сервис в контроллерах:
php
namespace App\Controllers;
use Yeeefang\TcpdfNext\CodeIgniter\Services\TcpdfNextService;
class InvoiceController extends BaseController
{
public function download(int $id)
{
$invoice = model('InvoiceModel')->find($id);
$pdf = service('tcpdfnext')->create()
->setTitle("Invoice #{$invoice->number}")
->addPage()
->setFont('Helvetica', '', 12)
->cell(0, 10, "Invoice #{$invoice->number}");
return service('tcpdfnext')->response($pdf, "invoice-{$invoice->number}.pdf");
}
}Использование через Library
Альтернативно используйте класс Library:
php
namespace App\Controllers;
use Yeeefang\TcpdfNext\CodeIgniter\Libraries\PdfLibrary;
class ReportController extends BaseController
{
public function generate()
{
$pdfLib = new PdfLibrary();
$pdf = $pdfLib->create()
->setTitle('Monthly Report')
->addPage()
->setFont('Helvetica', 'B', 16)
->cell(0, 10, 'Monthly Report', newLine: true);
return $pdfLib->inline($pdf, 'report.pdf');
}
}HTTP-ответы
Хелперы ответов включают рекомендованные OWASP заголовки безопасности:
php
// Inline display (browser preview)
return service('tcpdfnext')->inline($pdf, 'report.pdf');
// Force download
return service('tcpdfnext')->download($pdf, 'report.pdf');Интеграция с очередью
Отправьте генерацию PDF в планировщик задач CodeIgniter:
php
use Yeeefang\TcpdfNext\CodeIgniter\Queue\GeneratePdfJob;
$job = new GeneratePdfJob([
'template' => 'invoice',
'data' => ['invoice_id' => $invoice->id],
'output_path' => WRITEPATH . "pdfs/invoice-{$invoice->id}.pdf",
]);
service('queue')->push($job);Содержимое пакета
| Класс | Описание |
|---|---|
TcpdfNextService | Регистрация сервиса и фабрика |
PdfLibrary | Класс Library для использования в контроллерах |
PdfResponse | HTTP-ответ с заголовками безопасности |
GeneratePdfJob | Задание очереди для фоновой генерации |
