File size: 3,769 Bytes
07c3cdd
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
<?php

$filter = new InputFilter();
$_REQUEST = $filter->xssFilterHard($_REQUEST);

$action = isset( $_REQUEST['action'] ) ? $_REQUEST['action'] :'';

// Function call from ajax_function for calling to lookForNameOutput.
if ($action == '') {
    $action = isset( $_REQUEST['function'] ) ? $_REQUEST['function'] : '';
}

switch ($action) {
    case 'setTemplateFile':
        $_FILES = $filter->xssFilterHard($_FILES);
        //print_r($_FILES);
        $_SESSION['outpudocs_tmpFile'] = PATH_DATA . $_FILES['templateFile']['name'];
        //    file_put_contents($_FILES['templateFile']['name'], file_get_contents($_FILES['templateFile']['tmp_name']));
        copy( $_FILES['templateFile']['tmp_name'], $_SESSION['outpudocs_tmpFile'] );
        $result = new stdClass();

        $result->success = true;
        $result->msg = 'success - saved ' . $_SESSION['outpudocs_tmpFile'];
        echo G::json_encode( $result );
        break;

    case 'getTemplateFile':
        $_SESSION['outpudocs_tmpFile'] = $filter->xssFilterHard($_SESSION['outpudocs_tmpFile']);
        $aExtensions = array ("exe","com","dll","ocx","fon","ttf","doc","xls","mdb","rtf","bin","jpeg","jpg","jif","jfif","gif","tif","tiff","png","bmp","pdf","aac","mp3","mp3pro","vorbis","realaudio","vqf","wma","aiff","flac","wav","midi","mka","ogg","jpeg","ilbm","tar","zip","rar","arj","gzip","bzip2","afio","kgb","gz","asf","avi","mov","iff","ogg","ogm","mkv","3gp"
        );
        $sFileName = strtolower( $_SESSION['outpudocs_tmpFile'] );
        $strRev = strrev( $sFileName );
        $searchPos = strpos( $strRev, '.' );
        $pos = (strlen( $sFileName ) - 1) - $searchPos;
        $sExtension = substr( $sFileName, $pos + 1, strlen( $sFileName ) );
        if (! in_array( $sExtension, $aExtensions )) {
            $content = file_get_contents( $_SESSION['outpudocs_tmpFile'] );
            $content = $filter->xssFilterHard($content);
            echo $content;
        }
        break;

    case 'loadTemplateContent':
        $_POST = $filter->xssFilterHard($_POST);
        require_once 'classes/model/OutputDocument.php';
        $ooutputDocument = new OutputDocument();
        if (isset( $_POST['OUT_DOC_UID'] )) {
            $aFields = $ooutputDocument->load( $_POST['OUT_DOC_UID'] );

            echo $aFields['OUT_DOC_TEMPLATE'];
        }
        break;

    case 'lookForNameOutput':
        $_POST = $filter->xssFilterHard($_POST);

        $snameInput = urldecode($_POST['NAMEOUTPUT']);
        $sPRO_UID = urldecode($_POST['proUid']);
        $oOutputDocument = new \ProcessMaker\BusinessModel\OutputDocument();
        echo !$oOutputDocument->existsTitle($sPRO_UID, $snameInput);
        break;

    case 'loadOutputEditor':
        global $G_PUBLISH;
        $G_PUBLISH = new Publisher();
        $fcontent  = '';
        $proUid    = '';
        $filename  = '';
        $title  = '';

        require_once 'classes/model/OutputDocument.php';
        $oOutputDocument = new OutputDocument();
        if (isset( $_REQUEST['OUT_DOC_UID'] )) {
            $aFields = $oOutputDocument->load( $_REQUEST['OUT_DOC_UID'] );
            $fcontent = $aFields['OUT_DOC_TEMPLATE'];
            $proUid   = $aFields['PRO_UID'];
            $filename = $aFields['OUT_DOC_FILENAME'];
            $title    = $aFields['OUT_DOC_TITLE'];
        }

        $aData = Array ( 'PRO_UID' => $proUid,'OUT_DOC_TEMPLATE' => $fcontent, 'FILENAME' => $filename, 'OUT_DOC_UID'=> $_REQUEST['OUT_DOC_UID'], 'OUT_DOC_TITLE'=> $title);

        $G_PUBLISH->AddContent( 'xmlform', 'xmlform', 'outputdocs/outputdocs_Edit', '', $aData );
        
        G::RenderPage( 'publish', 'raw' );
        
        break;
}