« WATERBEAR:Imagettes » : différence entre les versions
Aucun résumé des modifications |
Aucun résumé des modifications |
||
Ligne 33 : | Ligne 33 : | ||
Le principe consiste à effectuer plusieurs tâches: | Le principe consiste à effectuer plusieurs tâches: | ||
- récupérer la liste des codes ISBN de la base de données, de les mettre en une colonne | - récupérer la liste des codes ISBN de la base de données, de les mettre en une colonne et d'éliminer les doubles | ||
- convertir ces codes en un code ISBN de 10 caractères. Sur le site d'Amazon, le nom des images est constitué de ce code. | - convertir ces codes en un code ISBN de 10 caractères. Sur le site d'Amazon, le nom des images est constitué de ce code. | ||
- tester si les images (petites et moyennes) ont déjà été récupérées | - tester si les images (petites et moyennes) ont déjà été récupérées | ||
Ligne 40 : | Ligne 40 : | ||
Pour exécuter de façon régulière ces scripts, il faut ajouter quelques lignes dans le fichier Linux "/etc/crontab" géré par le service crond.service. Dans l'exemple, la recherche complète est effectuée chaque dimanche, la recherche rapide, chaque heure. | |||
---- | |||
# Waterbear : récupération d'imagettes | |||
15 22 * * 0 root /manager/waterbear/isbn.bat > /manager/waterbear/isbn.cron.log | |||
5 * * * * root /manager/waterbear/isbnred.bat > /manager/waterbear/isbnred.cron.log | |||
---- | |||
Note: Dans ces scripts, il faut adapter le mot de passe du user "root" de MySql. | |||
=Plugin get_ISBN10.php= | |||
Pour les documents dont les imagettes n'ont pas été récupérées, le script PHP existant émettra un Warning et l'affichage sera imparfait. Pour cette raison il faudra la remplacer par une petite image vide la la même couleur que le fond de l'écran. | |||
On placera ces deux images spéciales, nommées videS.jpg et videM.jpg, dans le répertoire "/web/waterbear/IMG/isbn10". Ensuite il faut adapter le plugin "/web/waterbear/include/plugins/catalogue/marcxml/get_ISBN10.php". On teste la présence de l'imagette; dans le cas contraire, on remplace le code ISBN 10 par le mot "vide". Par la même occasion, on introduit deux nouveaux paramètres "avant" et "après" afin de reconstituer le nom du fichier image dont on veut tester la présence. Ce script PHP est compris dans le fichier ZIP ainsi que les deux images vides. | |||
Version du 20 août 2020 à 14:25
But
Dans les écrans de recherche de documents, une image de la page de couverture est affichée par document. A l'origine, ces images sont recherchées à chaque passage sur cette page sur le site d'Amazon. Pour diminuer les interrogations sur un site externe, on peut vouloir les récupérer sur son propre serveur.
Procédure de récupération
La première étape consiste à récupérer ces images et à récupérer les nouvelles qui manqueraient encore suite par exemple à l'ajout d'un nouveau document. Nous avons choisi de la faire via un script sous Linux et à l'exécuter à intervalles réguliers.
Le nécessaire pour effectuer ce qui suit se trouve dans le fichier ZIP ci-dessous.
Télécharger le fichier ZIP des modifications concernant ces imagettes
La première étape consiste à créer l'arborescence nécessaire sous Linux.
- Dans l'arborescence des fichiers du site WEB de Waterbear, il faut créer un répertoire qui regroupera les images. Nous garderons la base utilisée lors de l'installation.
mkdir /web/waterbear/IMG/isbn10
- Nous allons placer les scripts Linus, écrits en Bash, dans un répertoire spécifique hors des fichiers du site WEB. En dessous de ce répertoire, on en place d'autres nécessaires au bon fonctionnement des scripts. Nous avons pour habitude de créer un répertoire de base qui accueille ces scripts de gestion: "/manager".
mkdir /manager mkdir /manager/waterbear mkdir /manager/waterbear/new mkdir /manager/waterbear/image10 mkdir /manager/waterbear/autre10 mkdir /manager/waterbear/inconnu
Fonction de ces répertoires:
- new : recueille les images récupérées; elles seront déplacées dans l'arborescence du site WEB "/web/waterbear/IMG/isbn10" - image10 : images déjà récupérées - inconnu : images non trouvées - autre10 : images récupérées mais non valides
Il y a deux scripts.
- isbn.bat : essaye de récupérer toutes les images non encore récupérées. Il est à exécuter rarement (une fois par semaine ou par mois par exemple). - isbnred.bat : essaye de récupérer les images non encore récupérées sans chercher à le faire pour des images dont la recherche est restée infructueuse par le passé.
Le principe consiste à effectuer plusieurs tâches:
- récupérer la liste des codes ISBN de la base de données, de les mettre en une colonne et d'éliminer les doubles - convertir ces codes en un code ISBN de 10 caractères. Sur le site d'Amazon, le nom des images est constitué de ce code. - tester si les images (petites et moyennes) ont déjà été récupérées - récupérer les images manquantes. - les déplacer dans l'arborescence du site WEB
Pour exécuter de façon régulière ces scripts, il faut ajouter quelques lignes dans le fichier Linux "/etc/crontab" géré par le service crond.service. Dans l'exemple, la recherche complète est effectuée chaque dimanche, la recherche rapide, chaque heure.
# Waterbear : récupération d'imagettes 15 22 * * 0 root /manager/waterbear/isbn.bat > /manager/waterbear/isbn.cron.log 5 * * * * root /manager/waterbear/isbnred.bat > /manager/waterbear/isbnred.cron.log
Note: Dans ces scripts, il faut adapter le mot de passe du user "root" de MySql.
Plugin get_ISBN10.php
Pour les documents dont les imagettes n'ont pas été récupérées, le script PHP existant émettra un Warning et l'affichage sera imparfait. Pour cette raison il faudra la remplacer par une petite image vide la la même couleur que le fond de l'écran. On placera ces deux images spéciales, nommées videS.jpg et videM.jpg, dans le répertoire "/web/waterbear/IMG/isbn10". Ensuite il faut adapter le plugin "/web/waterbear/include/plugins/catalogue/marcxml/get_ISBN10.php". On teste la présence de l'imagette; dans le cas contraire, on remplace le code ISBN 10 par le mot "vide". Par la même occasion, on introduit deux nouveaux paramètres "avant" et "après" afin de reconstituer le nom du fichier image dont on veut tester la présence. Ce script PHP est compris dans le fichier ZIP ainsi que les deux images vides.