1
0
mirror of https://github.com/24eme/signaturepdf.git synced 2023-08-25 09:33:08 +02:00
Free web software for signing PDFs and also organize pages, edit medata and compress pdf https://pdf.24eme.fr
Go to file
2022-04-14 09:09:48 +02:00
.github/workflows ci: dockerize and push with gh-actions 2022-01-28 17:23:51 +01:00
config feat(docker): update dockerfile to enable pdf storage for multi-signature 2022-04-11 09:34:18 +02:00
public FirstPage with white background 2022-04-14 09:09:48 +02:00
templates FirstPage with white background 2022-04-14 09:09:48 +02:00
tests L'ajout de texte avec accent est possible maintenant 2022-01-04 09:37:53 +01:00
vendor/fatfree Fatfree core lib only 2022-03-26 23:40:57 +01:00
.editorconfig Définition des normes d'édition 2021-10-12 01:02:40 +02:00
.gitignore Storage path of the pdf in config and disabled in the interface if not defined 2022-04-01 17:34:35 +02:00
app.php The rotation of pdf pages are taken into account on the server side with pdftk 2022-04-08 01:06:35 +02:00
Dockerfile feat(docker): update dockerfile to enable pdf storage for multi-signature 2022-04-11 09:34:18 +02:00
entrypoint.sh feat(docker): update dockerfile to enable pdf storage for multi-signature 2022-04-11 09:34:18 +02:00
LICENSE License AGPLV3 2021-05-04 00:58:47 +02:00
Makefile Testes fonctionnels de la signature d'un pdf avec jest et puppeteer 2021-10-24 01:38:57 +02:00
README.md feat(docker): update dockerfile to enable pdf storage for multi-signature 2022-04-11 09:34:18 +02:00

Signature de PDF

Logiciel web libre permettant de signer un PDF.

Instances

Liste des instances permettant d'utiliser ce logiciel :

License

Logiciel libre sous license AGPL V3

Installation

Dépendances :

  • php >= 5.6
  • rsvg-convert
  • pdftk
  • imagemagick
  • potrace

Sur debian :

sudo aptitude install php librsvg2-bin pdftk imagemagick potrace

Récupération des sources :

git clone https://github.com/24eme/signaturepdf.git

Pour le lancer :

php -S localhost:8000 -t public

Configuration de PHP

upload_max_filesize = 24M # Taille maximum du fichier PDF à signer
post_max_size = 24M # Taille maximum du fichier PDF à signer
max_file_uploads = 201 # Nombre de pages maximum du PDF, ici 200 pages + le PDF d'origine

Déployer avec apache

DocumentRoot /path/to/signaturepdf/public

<Directory /path/to/signaturepdf/public>
    Require all granted
    FallbackResource /index.php
    php_value max_file_uploads 201
    php_value upload_max_filesize 24M
    php_value post_max_size 24M
</Directory>

Activation et configuration du mode partage de signature à plusieurs

Ce mode permet de proposer la signature d'un pdf à plusieurs personnes mais il nécessite que les PDF soient stockés sur le serveur, il convient donc de définir un dossier qui contiendra ces PDF.

Il n'est pas obligatoire d'activer ce mode pour que l'application fonctionne c'est une option.

Créer le fichier config/config.ini

cp config/config.ini{.example,}

Dans ce fichier config/config.ini, il suffit ce configurer la variable PDF_STORAGE_PATH avec le chemin vers lequel les fichiers pdf uploadés pourront être stockés :

PDF_STORAGE_PATH=/path/to/folder

Créer ce dossier :

mkdir /path/to/folder

Le serveur web devra avoir les droits en écriture sur ce dossier.

Par exemple pour apache :

chown www-data /path/to/folder/to/store/pdf

Déployer avec docker

Construction de l'image

docker build -t signaturepdf .

Lancement d'un conteneur

docker run -d --name=signaturepdf -p 8080:80 signaturepdf

localhost:8080

Configuration

Les variables suivantes permettent de configurer le déployement :

Variable description exemple defaut
SERVERNAME url de déploiement pdf.24eme.fr localhost
UPLOAD_MAX_FILESIZE Taille maximum du fichier PDF à signer 48M 24M
POST_MAX_SIZE Taille maximum du fichier PDF à signer 48M 24M
MAX_FILE_UPLOADS Nombre de pages maximum du PDF, ici 200 pages + le PDF d'origine 401 201
PDF_STORAGE_PATH chemin vers lequel les fichiers pdf uploadés pourront être stockés /data
docker run -d --name=signaturepdf -p 8080:80 -e SERVERNAME=pdf.example.org -e UPLOAD_MAX_FILESIZE=48M -e POST_MAX_SIZE=48M -e MAX_FILE_UPLOADS=401 -e PDF_STORAGE_PATH=/data signaturepdf

Tests

Pour exécuter les tests fonctionnels :

make test

Les tests sont réalisés avec puppeteer et jest.

Pour lancer les tests et voir le navigateur (en mode debug) :

DEBUG=1 make test

Librairies utilisées

Pour les tests :