Compress

Ceci est une ARCHIVE, peut-être périmée. Vérifiez bien les compatibilités !

Compress est une archive comprenant un squelette SPIP et deux classes de compression issues de PHPConcept.
Le but de ce squelette est de fournir une archive téléchargeable de TOUT un secteur. A l’appel de la page, on obtient un formulaire demandant le choix de compression et le secteur concerné. Une fois la compression effectuée, le fichier est proposé au téléchargement.

Le README

Installation :

Une fois l’archive décompressée, la structure des fichiers est la suivante :

-  / Racine du site SPIP
-  /compress.php Script php
-  /compress.html Squelette (c’est lui qui fera tout le boulot)
-  /compress Répertoire temporaire pour les pages HTML
-  /ressources Répertoire de stockage
-  /ressources/phpzlib Répertoire de la classe Zip
-  /ressources/phpzlib/pclzip.lib.php Classe de compression Zip
-  /ressources/phpzlib/pclerror.lib.php Classe de gestion d’erreurs
-  /ressources/phpzlib/pcltrace.lib.php Classe de traçage des opérations
-  /ressources/phpzlib/gnu-lgpl.txt License GNU-LGPL
-  /ressources/phptarlib Répertoire des fonctions tar
-  /ressources/phptarlib/pcltar.lib.php Script de fonctions de compression tar
-  /ressources/phptarlib/pclerror.lib.php Classe de gestion d’erreurs
-  /ressources/phptarlib/pcltrace.lib.php Classe de traçage des opérations

Copier les fichiers à la racine du site SPIP.

Configuration :

Par défaut, les pages aspirées sont enregistrées dans le répertoire compress.
Par défaut la classe phpzlib se trouve dans ressources/phpzlib, les fonctions phptarlib dans /ressources/phptarlib

Vous pouvez paramétrer les chemins et/ou nom du fichier archive.

Utilisation :

Au premier appel de la page, on obtient un formulaire demandant le type de compression (zip ou tar.gz) et le secteur concerné.
On peut l’appeler « en direct » sous la forme : compress.php ?format=xxx&id_rubrique=yy ou xxx peut être égal à zip ou tar et yy représente l’id_rubrique.

Au secours ?? : Jean-Baptiste


Crédits :
Merci à Vincent Blavet pour son autorisation d’utiliser ses classes de compression
License GNU/LGPL - Vincent Blavet - September 2002
PHPConcept

Merci aux développeurs de SPIP, pour ce formidable outils ;-))


Le but initial du projet était de pouvoir télécharger la doc spip facilement (http://www.uzine.net/spip/).

Devant le problème pour récupérer la liste des rubriques et articles dépendants de la fameuse rubrique 91, j’ai donc décidé de faire un petit outil à la disposition des Spipeurs, en espérant qu’il soit utilisé ;-))

La problématique :
Pourvoir récupérer 1 ou plusieurs pages tirées d’un site SPIP, les compresser et les proposer au téléchargement.

Fonctionnalités par défaut :

  1. Le script, via les boucles SPIP va récupérer tous les articles et rubriques dépendant d’un secteur à la façon d’un plan. Les pages sont enregistrées temporairement avant création de l’archive.
  2. Les fichiers « externes » aux pages sont enregistrés également. Par l’analyse des pages sur les critères href, src et background, on récupère : images, fichiers .css et fichiers .js
  3. Une fois l’analyse effectuée, on crée l’archive, on enregistre les pages HTML et les fichiers associés.

Contraintes :
Le script ne doit agir qu’en local, et ce pour plusieurs raisons :

  1. Le responsable du site doit avoir la main sur le déclenchement. (charge serveur)
  2. Il doit pouvoir identifier les éléments « extérieurs » à la page, images et css par exemple et les charger également.
  3. Le format des URL doit AU MINIMUM être du « type SPIP html ». In extenso, on ne pourra pas utiliser ce script en l’état avec les urls standards. Le symbole ? n’est pas valable dans un nom de fichier.
  4. J’ai rencontré quelques soucis pour enregistrer des images téléchargées à distance ;-))
  5. Enfin, les responsables de sites en général et les hébergeurs en particuliers n’aiment pas beaucoup les aspirateurs.

Futur :

  1. Vérifier les différentes façon de faire appel à un fichier externe dans une page HTML. Le but est de rendre le script encore plus universel ;-))
  2. Il devrait pouvoir être couplé à l’authentification SPIP.
  3. Se débarrasser de l’option « allow_call_time_pass_reference = On » imposée par la structure de la classe zip et visiblement tombée en désuétude pour PHP.
  4. Intégration des formats d’adresses de SPIP autre que HTML ?

Comme toute page SPIP, ce package est composé du célèbre couple de fichier .php/.html.
La compression est effectuée à partir :
-  d’une classe (phpzlib) pour la compression .zip
-  d’un ensemble de focntions (phptarlib) pour la compression tar
Ce fichiers sont issus de PHPConcept.
Tout ceci est basé sur la classe pclzip dans sa version 1.1.2 dont la license est du type GNU-LGPL

Discussion

3 discussions

  • 2

    Si j’ai bien compris, cet outil permet de compresser un secteur, en conservant la structure SPIP, soit les couples squelettes/PHP.
    J’ai une question : est-il possible de compresser un secteur (ou mieux tout un site) en STATIQUE. Exemple : transférer un SPIP sur un CDROM, sans obliger l’utilisateur à installer un serveur PHP, Mysql, restaurer la base, etc... Je pense que ce type d’outil serait bien utile, et quelqun l’a déjà construit (j’ai pas trouvé....). J’imagine aussi que ça doit être compliqué à monter (aspiration des couples PHP/HTML -> 1 page HTML, réécriture des liens, etc.)
    Merci de m’orienter...

    • Jean Baptiste

      Bon, reprenons ;-)

      Le but est exactement de pouvoir exporter un site SPIP sur un CD-ROM, donc en statique.
      Une autre utilisation pourrait être de proposer le contenu statique tout en gardant la facilité de production de contenu offerte par SPIP.

      L’utilisation de cette « contrib » permet justement de récupérer (comme un aspirateur de site) le site en entier au format HTML pur.

      Voilà.

    • comment cela marche t’il ?

    Répondre à ce message

  • Au départ j’ai eu une page blanche. J’ai mis inc-public.php3 au lieu de .php dans compress.php et là je bloque sur les erreurs :

    Warning : Failed opening ’header.php’ for inclusion (include_path=’. :/data/apache/php/mmp_lib’) in webgeneraction-compress.18f319 on line 20

    Warning : Failed opening ’footer.php’ for inclusion (include_path=’. :/data/apache/php/mmp_lib’) in webgeneraction-compress.18f319 on line 57

    Peut-être à cause des extensions php des autres fichiers ?

    Comment éviter ces blocages stp ?

    Répondre à ce message

  • un p’tit document joint serait utile, j’ai pas trouvé sur votre site phpconcept (mais j’ai ps cherché longtemps)

    Répondre à ce message

Ajouter un commentaire

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

Qui êtes-vous ?
[Se connecter]

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom