====== TCPDF su Debian 10 Buster ======
Purtroppo il pacchetto **php-tcpdf** non è presente in **Debian 10 Buster**, esiste però come **[[https://packages.debian.org/buster-backports/all/php-tcpdf/download|backport]]** oppure si dovrebbe poter installare la versione da Debian Bullseye, scarcando il file da [[https://packages.debian.org/bullseye/php-tcpdf|Debian packages]].
mkdir -p /usr/local/download/php-tcpdf
cd /usr/local/download/php-tcpdf
wget http://ftp.de.debian.org/debian/pool/main/t/tcpdf/php-tcpdf_6.3.2+dfsg1-1_all.deb
dpkg -i php-tcpdf_6.3.2+dfsg1-1_all.deb
Una volta installato è sufficiente includere nel codice PHP:
require_once('/usr/share/php/tcpdf/tcpdf.php');
===== L'alternativa FPDF =====
In alternativa a **php-tcpdf** esiste il pacchetto **[[https://packages.debian.org/buster/php-fpdf|php-fpdf]]** (home page [[http://www.fpdf.org/|www.fpdf.org]]). Si tratta di una libreria con minori funzionalità, ma più snella. È inclusa nelle ultime versioni di Debian, compresa l'auttuale stabile **10 Buster** (che include **php-fpdf 1.8.1**), e la futura **Bullseye**.
===== L'estensione FPDI =====
**[[https://packagist.org/packages/setasign/fpdi|FPDI]]** sta per **Free PDF Document Importer**, si tratta di una **estensione** che funziona sia con [[http://www.fpdf.org|FPDF]] che con [[https://github.com/tecnickcom/TCPDF|TCPDF]]. Consente di inlcudere un file PDF esistente ed utilizzarlo come **template** per creare altri documenti.
Debian includeva **libfpdi-php 1.4.1** fino alla versione **8 Jessie**, nella attuale versione 10 Buster purtroppo non c'è. La libreria è comunque scaricabile da **GitHub**, ad esempio la release 2.2.0 è scaricabile scegliendo il **[[https://github.com/Setasign/FPDI/tree/v2.2.0|Tag v2.2.0]]**.
Per una installazione manuale si può scompattare l'archivio **FPDI-2.2.0.zip** in **/usr/local/share/php/** oppure anche nella directory stessa del progetto PHP. Quello che serve è la directory **src** contenuta nell'archivio ZIP, che può essere rinominata ad esempio in **fpdi220**. Per includerla si aggiunge al codice PHP:
// Set the namespace to use FPDI over FPDF.
use setasign\Fpdi\Fpdi;
// Set the namespace to use FPDI over TCPDF.
// use setasign\Fpdi\Tcpdf\Fpdi;
// Include the FPDI extension, to import pages from existing PDF documents.
require_once('/usr/local/share/php/fpdi220/autoload.php');
Come si vede nell'esempio viene utilizzata la keyword **use** per definire quale //variante// di FPDI si vuole utilizzare: quella basata su FPDF oppure quella basata su TCPDF (in effetti sono supportate anche altre varianti).
**ATTENZIONE**: La versione **FPDI 2.2.0** richiede **FPDF 1.8**. Con versioni più vecchie (ad esempio FPDF 1.7) si incappa nell'errore:
PHP Fatal error: Access level to setasign\Fpdi\FpdfTplTrait::_putimages()
must be public (as in class FPDF) in /niccolo/fpdi/FpdfTpl.php on line 19
===== Installazione consigliata =====
Ad oggi (febbraio 2020) questo è lo stack di librerie consigiate:
* **TCPDF** dal pacchetto Debian **php-tcpdf** (versione **6.2.12** in Debian 9, versione **6.3.5** dai backport per Debian 10).
* **FPDI** installata localmente da archivio **FPDI-2.2.0.tgz**.
Nel codice PHP si includono con qualcosa del tipo:
require_once('/usr/share/php/tcpdf/tcpdf.php');
use setasign\Fpdi\Tcpdf\Fpdi;
require_once('./vendor/fpdi/autoload.php');