#CACHE{0} $debug=0 // Mode debug => $debug=1 (ne fonctionne pas sous Internet Explorer)=> ??? si, ça fonctionne ! $debug=1; $conf_url_site = '[(#URL_RUBRIQUE|url_absolue|texte_script)]' ; $conf_nom_site = '[(#NOM_SITE_SPIP|pdf_first_clean|supprimer_tags|texte_script)]' ; // Recuperation et definition des differents elements $site='[(#NOM_SITE_SPIP|pdf_first_clean|supprimer_tags|texte_script)]'; $rubrique='[(#TITRE|supprimer_numero|pdf_first_clean|supprimer_tags|texte_script)][(#NOM_SITE_SPIP|pdf_first_clean|supprimer_tags|texte_script)]'; $DateParution='[(#DATE_REDAC|affdate|pdf_first_clean|texte_script)]'; $DateMiseEnLigne='[(#DATE|nom_jour|texte_script)] [(#DATE|affdate|pdf_first_clean|texte_script)]'; /*$auteur='[(#NOM|pdf_first_clean|texte_script)]';*/ $motsclef=/*'[(#TITRE|pdf_first_clean|supprimer_tags|texte_script)]'*/''; $yahoo='- [(#TITRE|supprimer_numero|pdf_first_clean|supprimer_tags|texte_script)] - '; $logo_site='[(#LOGO_SITE_SPIP|extraire_attribut{src}|texte_script)]'; // attention à l'ordre des filtres SPIP [$logo_fichier='(#LOGO_RUBRIQUE|extraire_attribut{src}|texte_script|supprimer_param_logo)';] // [$logo_lien="(#URL_ARTICLE)";] [$surtitre='(#SURTITRE|pdf_first_clean|supprimer_tags|texte_script)';] [$titre='(#TITRE|supprimer_numero|pdf_first_clean|supprimer_tags|texte_script)';] [$soustitre='(#SOUSTITRE|pdf_first_clean|supprimer_tags|texte_script)';] [$chapo='(#CHAPO|pdf_first_clean|texte_script)';] [$descriptif='(#DESCRIPTIF|pdf_first_clean|texte_script)';] [$texte= '(#TEXTE|pdf_first_clean|texte_script)';] [$ps='(#PS|pdf_first_clean|texte_script)';] [$notes='(#NOTES|pdf_first_clean|texte_script)';] $copyright = '[(#VAL{articlepdf:copyright}|_T|pdf_first_clean|texte_script)][(#NOM_SITE_SPIP|pdf_first_clean|supprimer_tags|texte_script)][(#VAL{articlepdf:tous_droits_reserves}|_T|pdf_first_clean|texte_script)]'; $id_rubrique = "#ID_RUBRIQUE"; $titre_rubrique = translitteration(corriger_caracteres('[(#TITRE|supprimer_numero|pdf_first_clean|supprimer_tags|texte_script)]')); // Reprise du code de urls/propres.php (pourquoi c'est pas une fonction de l'API de SPIP ?) // on va convertir tous les caracteres de ponctuation et espaces // a l'exception de l'underscore (_), car on veut le conserver dans l'url $titre_rubrique = str_replace('_', chr(7), $titre_rubrique); $titre_rubrique = @preg_replace(',[[:punct:][:space:]]+,u', ' ', $titre_rubrique); $titre_rubrique = str_replace(chr(7), '_', $titre_rubrique); // S'il reste trop de caracteres non latins, les gerer comme wikipedia // avec rawurlencode : if (preg_match_all(",[^a-zA-Z0-9 _]+,", $titre_rubrique, $r, PREG_SET_ORDER)) { foreach ($r as $regs) { $titre_rubrique = substr_replace($titre_rubrique, rawurlencode($regs[0]), strpos($titre_rubrique, $regs[0]), strlen($regs[0])); } } // S'il reste trop peu, on retombe sur rubrique12 if (strlen($titre_rubrique) == 0 ) { $titre_rubrique = "rubrique"; } // Sinon couper les mots et les relier par des tirets else { $mots = preg_split(",[^a-zA-Z0-9_%]+,", $titre_rubrique); $titre_rubrique = ''; foreach ($mots as $mot) { if (!strlen($mot)) continue; $titre_rubrique2 = $titre_rubrique.'-'.$mot; // Si on depasse _URLS_PROPRES_MAX caracteres, s'arreter // ne pas compter 3 caracteres pour %E9 mais un seul $long = preg_replace(',%.,', '', $titre_rubrique2); if (strlen($long) > _URLS_PROPRES_MAX) { break; } $titre_rubrique = $titre_rubrique2; } $titre_rubrique = substr($titre_rubrique, 1); // On enregistre en utf-8 dans la base $titre_rubrique = rawurldecode($titre_rubrique); if (strlen($titre_rubrique) == 0) $titre_rubrique = "rubrique"; } $files_pdf = $titre_rubrique."_".$id_rubrique.".pdf"; $file_out = $path_pdf . $files_pdf ; if (file_exists($file_out)) { clearstatcache; $damo = date(YmdHi , strtotime("#DATE_MODIF")) ; $dage = date(YmdHi , filemtime($file_out)) ; if ($damo > $dage) { unlink($file_out); } } header("Location: index.php"); exit; if ($debug == 1 && file_exists($file_out)) { unlink($file_out); } if (!file_exists($file_out)) { define('FPDF_FONTPATH',_DIR_FPDF_LIB.'font'); include_spip(_DIR_FPDF_LIB.'fpdf'); include_spip('pdf/lib_pdf_global'); include_spip('pdf/lib_pdf_spip'); //-------------------------------- // Debut génération du PDF //-------------------------------- $pdf->debug=$debug; $pdf=new PDF_SPIP(); $pdf->SetCompression(false); $pdf->SetDisplayMode('fullpage', 'single'); // haut, gauche, bas, droite $pdf->SetAllMargins(12,15,12,10); $pdf->SetTitle($titre); $pdf->SetCreator($site); $pdf->SetCopyright($copyright); $pdf->SetSubject($rubrique); $pdf->SetKeywords($motsclef); $pdf->Build($file_out); } // Vous voulez afficher un pdf header("Content-type: application/pdf"); if ($debug==1) { // Affiche le PDF directement dans l'onglet de Firefox // Ne fonctionne pas sous IE 6 SP2 : le pdf n'est pas reconnu (pris pour un fichier texte) header("location: ". url_de_base() . $file_out); } else { // Il sera nommé $files_pdf // ATTENTION : pour "filename", mettre un nom de fichier court (.) // sinon IE 6 SP2 ne reconnaîtra pas le type de fichier // Semble poser problème sous IE6 SP1 // Ah, Microsoft, je vous jure ! header('Content-Disposition: attachment; filename=' . $files_pdf); // Le source du PDF original.pdf readfile($file_out); } exit; ?>