xref: /plugin/dw2pdf/DokuPDF.class.php (revision a06728a6ee649cdf2151ba63360e62e31f5fe7d2)
1<?php
2/**
3 * Wrapper around the mpdf library class
4 *
5 * This class overrides some functions to make mpdf make use of DokuWiki'
6 * standard tools instead of its own.
7 *
8 * @author Andreas Gohr <andi@splitbrain.org>
9 */
10
11if(!defined('_MPDF_TEMP_PATH')) define('_MPDF_TEMP_PATH', $conf['tmpdir']);
12if(!defined('_MPDF_TTFONTDATAPATH')) define('_MPDF_TTFONTDATAPATH',$conf['cachedir'].'/mpdf_ttf/');
13require_once(dirname(__FILE__)."/mpdf/mpdf.php");
14
15class DokuPDF extends mpdf {
16
17    function __construct(){
18        io_mkdir_p(_MPDF_TTFONTDATAPATH);
19
20        // we're always UTF-8
21        parent::__construct('UTF-8-s');
22        $this->SetAutoFont(AUTOFONT_ALL);
23        $this->ignore_invalid_utf8 = true;
24
25    }
26
27    /**
28     * Decode all paths, since DokuWiki uses XHTML compliant URLs
29     */
30    function GetFullPath(&$path,$basepath=''){
31        $path = htmlspecialchars_decode($path);
32        parent::GetFullPath($path, $basepath);
33    }
34
35    /**
36     * Override the mpdf _getImage function
37     *
38     * This function takes care of gathering the image data from HTTP or
39     * local files before passing the data back to mpdf's original function
40     * making sure that only cached file paths are passed to mpdf. It also
41     * takes care of checking image ACls.
42     */
43    function _getImage(&$file, $firsttime=true, $allowvector=true, $orig_srcpath=false){
44        list($ext,$mime) = mimetype($file);
45        if(substr($mime,0,6) == 'image/'){
46            // build regex to parse URL back to media info
47            $re = preg_quote(ml('xxx123yyy'),'/');
48            $re = str_replace('xxx123yyy','([^&\?]*)',$re);
49
50
51            if(preg_match("/$re/",$file,$m) ||
52               preg_match('/[&\?]media=([^&\?]*)/',$file,$m)){
53                $media = rawurldecode($m[1]);
54
55                if(preg_match('/[\?&]w=(\d+)/',$file, $m)) $w = $m[1];
56                if(preg_match('/[\?&]h=(\d+)/',$file, $m)) $h = $m[1];
57
58                if(preg_match('/^https?:\/\//',$media)){
59                    $local = media_get_from_URL($media,$ext,-1);
60                    if(!$local) $local = $media; // let mpdf try again
61                }else{
62                    $media = cleanID($media);
63                    //check permissions (namespace only)
64                    if(auth_quickaclcheck(getNS($media).':X') < AUTH_READ){
65                        $file = '';
66                    }
67                    $local  = mediaFN($media);
68                }
69
70                //handle image resizing/cropping
71                if($w){
72                    if($h){
73                        $local = media_crop_image($local,$ext,$w,$h);
74                    }else{
75                        $local = media_resize_image($local,$ext,$w,$h);
76                    }
77                }
78            }elseif(preg_match('/^https?:\/\//',$file)){ // fixed external URLs
79                $local = media_get_from_URL($file,$ext,$conf['cachetime']);
80            }
81
82            if($local){
83                $file = $local;
84                $orig_srcpath = $local;
85            }
86        }
87
88        return parent::_getImage($file, $firsttime, $allowvector, $orig_srcpath);
89    }
90
91}
92