/**
  * Parcours des données de la table explnum
  */
 function fetch_data()
 {
     global $dbh;
     $rqt_expl = "select explnum_mimetype, explnum_nomfichier, explnum_extfichier, explnum_data, explnum_url, concat(repertoire_path,explnum_path) as path, explnum_repertoire from explnum left join upload_repertoire on repertoire_id=explnum_repertoire where explnum_id='" . $this->id_explnum . "'";
     $result_expl = mysql_query($rqt_expl, $dbh);
     if ($result_expl) {
         while ($explnum = mysql_fetch_object($result_expl)) {
             if ($explnum->explnum_data) {
                 //le fichier est en base
                 $this->file_content = $explnum->explnum_data;
             } else {
                 //le fichier est en upload
                 $up = new upload_folder($explnum->explnum_repertoire);
                 $path = str_replace('//', '/', $explnum->path . $explnum->explnum_nomfichier);
                 if ($path) {
                     $path = $up->encoder_chaine($path);
                     if (file_exists($path)) {
                         $fp = fopen($path, "r");
                         if (filesize($path) && (filesize($path) < $this->return_bytes(ini_get('upload_max_filesize')) && (ini_get('memory_limit') * 1 == -1 || filesize($path) < $this->return_bytes(ini_get('memory_limit')) * 1 - memory_get_usage(true) * 1))) {
                             $this->file_content = fread($fp, filesize($path));
                         } else {
                             $this->file_content = "";
                         }
                         fclose($fp);
                     } else {
                         $this->file_content = "";
                     }
                 }
             }
             $this->file_url = $explnum->explnum_url;
             $this->mimetype = $explnum->explnum_mimetype;
             $this->explnum_nomfichier = $explnum->explnum_nomfichier;
             $this->ext = $explnum->explnum_extfichier;
         }
     }
 }
示例#2
0
     $res = pmb_mysql_query($rqt);
     if ($res) {
         $empr_carac = pmb_mysql_fetch_array($res);
         $log->add_log('empr', $empr_carac);
     }
     $log->add_log('num_session', session_id());
     $log->add_log('explnum', $infos_explnum);
     $infos_restriction_abo = array();
     foreach ($expl_num as $key => $value) {
         $infos_restriction_abo[$key] = $value;
     }
     $log->add_log('restriction_abo', $infos_restriction_abo);
     $log->save();
 }
 if ($ligne->explnum_path) {
     $up = new upload_folder($ligne->repertoire_id);
     $path = str_replace("//", "/", $ligne->path);
     $path = $up->encoder_chaine($path);
     $fo = fopen($path, 'rb');
     $ligne->explnum_data = fread($fo, filesize($path));
     $ligne->taille = filesize($path);
     fclose($fo);
 }
 $nomfichier = "";
 if ($ligne->explnum_nomfichier) {
     $nomfichier = $ligne->explnum_nomfichier;
 } elseif ($ligne->explnum_extfichier) {
     if ($ligne->explnum_nom) {
         $nomfichier = $ligne->explnum_nom;
         if (!preg_match("/\\." . $ligne->explnum_extfichier . "\$/", $nomfichier)) {
             $nomfichier .= "." . $ligne->explnum_extfichier;
示例#3
0
 function show_form_task($planificateur_id = "")
 {
     global $charset, $base_path, $msg;
     global $planificateur_form, $act, $type_task_id, $subaction;
     foreach ($this->types_taches as $type) {
         if ($type->id_type == $type_task_id) {
             $comment = $type->comment;
             $name = $type->name;
             $dir_upload_boolean = $type->dir_upload_boolean;
         }
     }
     // Inclusion de la classe spécifique
     if (is_file($base_path . '/admin/planificateur/' . $name . '/' . $name . '.class.php')) {
         require_once $base_path . '/admin/planificateur/' . $name . '/' . $name . '.class.php';
         eval("\$a_task=new " . $name . "();");
         //Récupération des données du formulaire
         if ($subaction == "change") {
             global $task_name, $task_desc, $form_users, $task_active, $id_rep, $path;
             global $task_perio_heure, $task_perio_min, $chkbx_task_quotidien, $chkbx_task_hebdo, $chkbx_task_mensuel;
             global $timeout, $radio_histo_day_number, $histo_day, $histo_number, $restart_on_failure, $alert_mail_on_failure, $mail_on_failure;
             $libelle_tache = stripslashes($task_name);
             $desc_tache = stripslashes($task_desc);
             $perio_heure = $task_perio_heure;
             $statut = $task_active;
             $rep_upload = $id_rep ? $id_rep : "";
             $chemin_upload = $path ? $path : "";
             $perio_heure = $task_perio_heure;
             $perio_minute = $task_perio_min;
             $perio_jour_mois = $chkbx_task_quotidien;
             $perio_jour = $chkbx_task_hebdo;
             $perio_mois = $chkbx_task_mensuel;
             $param["timeout"] = $timeout;
             $param["histo_day"] = $histo_day;
             $param["histo_number"] = $histo_number;
             $param["restart_on_failure"] = $restart_on_failure;
             $param["alert_mail_on_failure"] = $alert_mail_on_failure . ($mail_on_failure ? "," . $mail_on_failure : "");
         } else {
             //Récupération des données de la base
             $a_task->fetch_global_properties();
             $tab_properties = $a_task->get_property_task_bdd($planificateur_id);
             if (isset($tab_properties)) {
                 if (is_array($tab_properties)) {
                     foreach ($tab_properties as $atab_properties => $atab_propertiesv) {
                         //							global $$atab_properties;
                         ${$atab_properties} = $atab_propertiesv;
                     }
                 }
             }
         }
         //form spécifique
         $form_specific_task = $a_task->show_form($param);
     } else {
         $form_specific_task = "";
     }
     $planificateur_form = str_replace("!!script_js!!", "\n\t\t\t<script type='text/javascript' src='./javascript/select.js'></script>\n\t\t\t<script type='text/javascript' src='./javascript/upload.js'></script>", $planificateur_form);
     $planificateur_form = str_replace("!!submit_action!!", "return checkForm();", $planificateur_form);
     $planificateur_form = str_replace("!!libelle_type_task!!", $comment, $planificateur_form);
     $planificateur_form = str_replace("!!task_name!!", htmlentities($libelle_tache, ENT_QUOTES, $charset), $planificateur_form);
     $planificateur_form = str_replace("!!task_desc!!", htmlentities($desc_tache, ENT_QUOTES, $charset), $planificateur_form);
     $rqt_user = mysql_query("select esuser_id, esuser_username from es_esusers");
     $form_users = "<select name='form_users'>";
     while ($row = mysql_fetch_object($rqt_user)) {
         if ($row->esuser_id == $num_user) {
             $form_users .= "<option value='" . $row->esuser_id . "' selected>" . $row->esuser_username . "</option>";
         } else {
             $form_users .= "<option value='" . $row->esuser_id . "'>" . $row->esuser_username . "</option>";
         }
     }
     $form_users .= "</select>";
     if (mysql_num_rows($rqt_user) == 0) {
         $form_users .= "* " . $msg["planificateur_task_users_unknown"];
     }
     $planificateur_form = str_replace("!!task_users!!", $form_users, $planificateur_form);
     $planificateur_form = str_replace("!!task_statut!!", "<input type='checkbox' name='task_active' id='task_active' value='" . $statut . "' " . ($statut != "0" ? " checked " : "''") . " onchange='changeStatut();'/>", $planificateur_form);
     //ce type de tâche nécessite-t-il d'un répertoire d'upload pour les documents numériques?
     if ($dir_upload_boolean != "0") {
         $up = new upload_folder($rep_upload);
         if ($subaction == 'change') {
             $nom_chemin = $up->formate_path_to_nom($chemin_upload);
         } else {
             $nom_chemin = $up->formate_nom_to_path($up->repertoire_nom . $path_upload);
         }
         $planificateur_form = str_replace("!!div_upload!!", "<div class='row'>\n\t\t\t\t<div class='colonne3'><label for='timeout'/>" . $msg["print_numeric_ex_title"] . "</label></div>\n\t\t\t\t\t\t<div class='colonne_suite'>\n\t\t\t\t\t\t\t" . $msg["planificateur_upload"] . " : \n\t\t\t\t\t\t\t<input type='text' name='path' id='path' value='!!path!!' class='saisie-50emr' READONLY />\n\t\t\t\t\t\t\t<input type='button' id='upload_path' class='bouton' onclick='upload_openFrame(event)' value='...' name='upload_path' />\n\t\t\t\t\t\t\t<input id='id_rep' type='hidden' value='!!id_rep!!' name='id_rep' /> \n\t\t\t\t\t\t</div>\n\t\t\t\t</div>", $planificateur_form);
     } else {
         $planificateur_form = str_replace("!!div_upload!!", "", $planificateur_form);
     }
     $planificateur_form = str_replace('!!path!!', htmlentities($nom_chemin, ENT_QUOTES, $charset), $planificateur_form);
     $planificateur_form = str_replace('!!id_rep!!', htmlentities($rep_upload, ENT_QUOTES, $charset), $planificateur_form);
     $planificateur_form = str_replace("!!task_perio_heure!!", "<input type='text' id='task_perio_heure' name='task_perio_heure' value='" . $perio_heure . "' class='saisie-5em'/>", $planificateur_form);
     $planificateur_form = str_replace("!!task_perio_min!!", "<input type='text' id='task_perio_min' name='task_perio_min' value='" . $perio_minute . "' class='saisie-5em'/>", $planificateur_form);
     $planificateur_form = str_replace("!!help!!", "<a onclick='openPopUp(\"./admin/planificateur/help.php?action_help=configure_time\",\"help\",500,600,-2,-2,\"scrollbars=yes,menubar=0\"); w.focus(); return false;' href='#'>\n\t\t\t<img border='0' align='center' title='Aide...' alt='Aide...' src='" . $base_path . "/images/aide.gif' /></a>", $planificateur_form);
     $perio_quotidien .= "<input type='checkbox' id='chkbx_task_quotidien_0' name='chkbx_task_quotidien[]'  value='*' " . ($perio_jour_mois[0] == '*' ? "checked" : "''") . " onchange='changePerio(\"*\",\"chkbx_task_quotidien\",31);'> " . $msg["planificateur_task_all_days_of_month"] . "</input>";
     for ($i = 1; $i <= 31; $i++) {
         $cochee = false;
         for ($j = 0; $j < sizeof($perio_jour_mois); $j++) {
             if ($perio_jour_mois[$j] == $i) {
                 $cochee = true;
             }
         }
         $perio_quotidien .= "<input type='checkbox' id='chkbx_task_quotidien_" . $i . "' name='chkbx_task_quotidien[]'  value='" . $i . "' " . ($cochee == true ? "checked" : "''") . " onchange='changePerio({$i},\"chkbx_task_quotidien\",31);'/> " . $i . " ";
         if ($i == 15) {
             $perio_quotidien .= "<br />";
         }
     }
     $planificateur_form = str_replace("!!task_perio_quotidien!!", $perio_quotidien, $planificateur_form);
     $perio_hebdo .= "<input type='checkbox' id='chkbx_task_hebdo_0' name='chkbx_task_hebdo[]'  value='*' " . ($perio_jour[0] == '*' ? "checked" : "''") . " onchange='changePerio(\"*\",\"chkbx_task_hebdo\",7);'> " . $msg["planificateur_task_all_days"] . "</input>";
     for ($i = 1; $i <= 7; $i++) {
         $cochee = false;
         for ($j = 0; $j < sizeof($perio_jour); $j++) {
             if ($perio_jour[$j] == $i) {
                 $cochee = true;
             }
         }
         $perio_hebdo .= "<input type='checkbox' id='chkbx_task_hebdo_" . $i . "' name='chkbx_task_hebdo[]'  value='" . $i . "' " . ($cochee == true ? "checked" : "''") . " onchange='changePerio({$i},\"chkbx_task_hebdo\",7);'/> " . $msg["week_days_{$i}"];
         if ($i == 3) {
             $perio_hebdo .= "<br />";
         }
     }
     $planificateur_form = str_replace("!!task_perio_hebdo!!", $perio_hebdo, $planificateur_form);
     $perio_mensuel .= "<input type='checkbox' id='chkbx_task_mensuel_0' name='chkbx_task_mensuel[]'  value='*' " . ($perio_mois[0] == '*' ? " checked " : "''") . " onchange='changePerio(\"*\",\"chkbx_task_mensuel\",12);'> " . $msg["planificateur_task_all_months"] . "</input>";
     for ($i = 1; $i <= 12; $i++) {
         $cochee = false;
         for ($j = 0; $j < sizeof($perio_mois); $j++) {
             if ($perio_mois[$j] == $i) {
                 $cochee = true;
             }
         }
         $perio_mensuel .= "<input type='checkbox' id='chkbx_task_mensuel_" . $i . "' name='chkbx_task_mensuel[]'  value='" . $i . "' " . ($cochee == true ? "checked" : "''") . " onchange='changePerio({$i},\"chkbx_task_mensuel\",12);'> " . ucfirst($msg[$i + 1005]) . "</input>";
         if ($i == 6) {
             $perio_mensuel .= "<br />";
         }
     }
     $planificateur_form = str_replace("!!task_perio_mensuel!!", $perio_mensuel, $planificateur_form);
     $planificateur_form = str_replace("!!timeout!!", $param["timeout"], $planificateur_form);
     $planificateur_form = str_replace("!!histo_day_checked!!", $param["histo_day"] != "" ? " checked " : "", $planificateur_form);
     $planificateur_form = str_replace("!!histo_number_checked!!", $param["histo_number"] != "" ? " checked " : "", $planificateur_form);
     $planificateur_form = str_replace("!!histo_day!!", $param["histo_day"], $planificateur_form);
     $planificateur_form = str_replace("!!histo_day_visible!!", $param["histo_day"] == "" ? "disabled" : "", $planificateur_form);
     $planificateur_form = str_replace("!!histo_number!!", $param["histo_number"], $planificateur_form);
     $planificateur_form = str_replace("!!histo_number_visible!!", $param["histo_number"] == "" ? "disabled" : "", $planificateur_form);
     $planificateur_form = str_replace("!!restart_on_failure_checked!!", $param["restart_on_failure"] ? " checked " : "", $planificateur_form);
     $params_alert_mail = explode(",", $param["alert_mail_on_failure"]);
     $planificateur_form = str_replace("!!alert_mail_on_failure_checked!!", $params_alert_mail[0] ? " checked " : "", $planificateur_form);
     $planificateur_form = str_replace("!!mail_on_failure!!", $params_alert_mail[1], $planificateur_form);
     //Inclusion du formulaire spécifique au type de tâche
     $planificateur_form = str_replace("!!specific_form!!", $form_specific_task, $planificateur_form);
     if ($act == "task_duplicate") {
         $planificateur_id = 0;
     }
     if (!$planificateur_id) {
         $bt_save = $base_path . "/admin.php?categ=planificateur&sub=manager&act=task&type_task_id=" . $type_task_id;
         $bt_duplicate = "";
         $bt_suppr = "";
     } else {
         $bt_save = $base_path . "/admin.php?categ=planificateur&sub=manager&act=task&type_task_id=" . $type_task_id . "&planificateur_id=" . $planificateur_id;
         $bt_duplicate = "<input type='button' class='bouton' value='" . $msg["tache_duplicate_bouton"] . "' onclick='document.location=\"./admin.php?categ=planificateur&sub=manager&act=task_duplicate&type_task_id=" . $type_task_id . "&planificateur_id=" . $planificateur_id . "\"' />";
         $bt_suppr = "<input type='button' class='bouton' value='" . $msg["63"] . "' onClick='location.href=\"{$base_path}/admin.php?categ=planificateur&sub=manager&act=task_del&type_task_id={$type_task_id}&planificateur_id=" . $planificateur_id . "\"'/>";
     }
     $planificateur_form = str_replace("!!bt_save!!", $bt_save, $planificateur_form);
     $planificateur_form = str_replace("!!bt_duplicate!!", $bt_duplicate, $planificateur_form);
     $planificateur_form = str_replace("!!bt_supprimer!!", $bt_suppr, $planificateur_form);
     return $planificateur_form;
 }
示例#4
0
<?php

// +-------------------------------------------------+
// © 2002-2004 PMB Services / www.sigb.net pmb@sigb.net et contributeurs (voir www.sigb.net)
// +-------------------------------------------------+
// $Id: folders.inc.php,v 1.1 2009-07-03 09:35:36 kantin Exp $
if (stristr($_SERVER['REQUEST_URI'], ".inc.php")) {
    die("no access");
}
require_once $class_path . "/upload_folder.class.php";
$upload_folder = new upload_folder($id, $action);
$upload_folder->proceed();
示例#5
0
function explnum_add_from_url($f_notice_id, $f_bulletin_id, $f_nom, $f_url, $overwrite = true, $source_id = 0, $filename = '', $f_path = '', $f_statut)
{
    global $dbh, $base_path;
    if ($f_bulletin_id) {
        $f_notice_id = 0;
    } else {
        if (!$f_bulletin_id && $f_notice_id) {
            $f_bulletin_id = 0;
        }
    }
    if (!$overwrite) {
        $sql_find = "SELECT count(*) FROM explnum WHERE explnum_notice = " . $f_notice_id . " AND explnum_nom = '" . addslashes($f_nom) . "'";
        $res = pmb_mysql_query($sql_find, $dbh);
        $count = pmb_mysql_result($res, 0, 0);
        if ($count) {
            return;
        }
    }
    $sql_delete = "DELETE FROM explnum WHERE explnum_notice = " . $f_notice_id . " AND explnum_nom = '" . addslashes($f_nom) . "' ";
    pmb_mysql_query($sql_delete, $dbh);
    $original_filename = basename($f_url);
    $extension = substr($original_filename, strripos($original_filename, '.') * 1 + 1);
    $tmp_filename = explnum::static_rename($extension);
    if ($filename) {
        $new_filename = $filename;
    } else {
        $new_filename = $tmp_filename;
    }
    //copie en répertoire temporaire
    $r = false;
    if (file_exists($f_url) && filesize($f_url)) {
        //document en repertoire
        $r = copy($f_url, $base_path . '/temp/' . $tmp_filename);
    } else {
        //url
        $aCurl = new Curl();
        $content = $aCurl->get($f_url);
        $content = $content->body;
        $r = file_put_contents("{$base_path}/temp/" . $tmp_filename, $content);
    }
    if ($r) {
        //construction vignette
        $vignette = construire_vignette('', $tmp_filename);
        create_tableau_mimetype();
        $mimetype = trouve_mimetype("{$base_path}/temp/" . $tmp_filename, $extension);
        //si la source du connecteur est précisée, on regarde si on a pas un répertoire associé
        $rep_upload = 0;
        if ($source_id) {
            $check_rep = "select rep_upload from connectors_sources where source_id = " . $source_id;
            $res = pmb_mysql_query($check_rep);
            if (pmb_mysql_num_rows($res)) {
                $rep_upload = pmb_mysql_result($res, 0, 0);
            }
        }
        if ($rep_upload != 0) {
            $upload_folder = new upload_folder($rep_upload);
            $rep_path = $upload_folder->get_path($new_filename);
            if ($f_path && file_exists($rep_path . $f_path)) {
                $rep_path = $rep_path . $f_path . '/';
            }
            if (file_exists($upload_folder->encoder_chaine($rep_path . $new_filename))) {
                $suffix = 1;
                $ext = extension_fichier($new_filename);
                $file = str_replace("." . $ext, "", basename($new_filename));
                while (file_exists($upload_folder->encoder_chaine($rep_path . $file . "_" . $suffix . "." . $ext))) {
                    $suffix++;
                }
                $new_filename = $file . "_" . $suffix . "." . $ext;
            }
            rename("{$base_path}/temp/" . $tmp_filename, $upload_folder->encoder_chaine($rep_path . $new_filename));
            $path = $upload_folder->formate_path_to_save($upload_folder->formate_path_to_nom($rep_path));
            $insert_sql = "INSERT INTO explnum (explnum_notice, explnum_bulletin, explnum_nom, explnum_nomfichier, explnum_mimetype, explnum_extfichier, explnum_vignette, explnum_repertoire, explnum_path, explnum_docnum_statut) VALUES (";
            $insert_sql .= $f_notice_id . ",";
            $insert_sql .= $f_bulletin_id . ",";
            $insert_sql .= "'" . addslashes($f_nom) . "',";
            $insert_sql .= "'" . addslashes($new_filename) . "',";
            $insert_sql .= "'" . addslashes($mimetype) . "',";
            $insert_sql .= "'" . addslashes($extension) . "',";
            $insert_sql .= "'" . addslashes($vignette) . "',";
            $insert_sql .= "'" . addslashes($rep_upload) . "',";
            $insert_sql .= "'" . addslashes($path) . "',";
            $insert_sql .= $f_statut;
            $insert_sql .= ")";
        } else {
            $insert_sql = "INSERT INTO explnum (explnum_notice, explnum_bulletin, explnum_nom, explnum_nomfichier, explnum_mimetype, explnum_extfichier, explnum_data, explnum_vignette, explnum_docnum_statut) VALUES (";
            $insert_sql .= $f_notice_id . ",";
            $insert_sql .= $f_bulletin_id . ",";
            $insert_sql .= "'" . addslashes($f_nom) . "',";
            $insert_sql .= "'" . addslashes($new_filename) . "',";
            $insert_sql .= "'" . addslashes($mimetype) . "',";
            $insert_sql .= "'" . addslashes($extension) . "',";
            $insert_sql .= "'" . addslashes($content) . "',";
            $insert_sql .= "'" . addslashes($vignette) . "',";
            $insert_sql .= $f_statut;
            $insert_sql .= ")";
        }
        if (pmb_mysql_query($insert_sql, $dbh)) {
            $docnum_id = pmb_mysql_insert_id($dbh);
            if ($docnum_id) {
                $index = new indexation_docnum($docnum_id);
                $index->indexer();
            }
        }
        /*
        		$aCurl = new Curl();
        		$content = $aCurl->get($f_url);
        		$content = $content->body;
        		
        		$origine=str_replace(" ","",microtime());
        		$origine=str_replace("0.","",$origine);
        		$original_filename = basename($f_url);
        		if( $filename != "") $afilename = $filename;
        		else $afilename = $origine.$original_filename;
        		if (!$original_filename)
        			$original_filename = $afilename;
        			
        		file_put_contents("$base_path/temp/".$afilename, $content);
        */
        /*		
        		$vignette = construire_vignette('', $afilename);
        		create_tableau_mimetype();
        		$afilename_ext=extension_fichier($afilename);
        		$mimetype = trouve_mimetype("$base_path/temp/".$afilename, $afilename_ext);
        		$extension = strrchr($afilename, '.');
        		
        		//si la source du connecteur est précisée, on regarde si on a pas un répertoire associé
        		if ($source_id){
        			$check_rep = "select rep_upload from connectors_sources where source_id = ".$source_id;
        			$res = pmb_mysql_query($check_rep);
        			if(pmb_mysql_num_rows($res)){
        				$rep_upload = pmb_mysql_result($res,0,0);
        			}
        		}
        */
        /*
        			if($rep_upload != 0){
        			$upload_folder = new upload_folder($rep_upload);
        			$rep_path = $upload_folder->get_path($afilename);
        			if ($f_path && file_exists($rep_path.$f_path)) {
        				$rep_path=$rep_path.$f_path.'/';
        			}
        			
        			copy("$base_path/temp/".$afilename,$rep_path.$afilename);
        			$path =$upload_folder->formate_path_to_save($upload_folder->formate_path_to_nom($rep_path));
        			$insert_sql = "INSERT INTO explnum (explnum_notice, explnum_nom, explnum_nomfichier, explnum_mimetype, explnum_extfichier, explnum_vignette, explnum_repertoire, explnum_path) VALUES (";
        			$insert_sql .= $f_notice_id.",";
        			$insert_sql .= "'".addslashes($f_nom)."',";
        			$insert_sql .= "'".addslashes($afilename)."',";
        			$insert_sql .= "'".addslashes($mimetype)."',";
        			$insert_sql .= "'".addslashes($extension)."',";
        			$insert_sql .= "'".addslashes($vignette)."',";
        			$insert_sql .= "'".addslashes($rep_upload)."',";
        			$insert_sql .= "'".addslashes($path)."'";
        			$insert_sql .= ")";		
        		}else{
        			$insert_sql = "INSERT INTO explnum (explnum_notice, explnum_nom, explnum_nomfichier, explnum_mimetype, explnum_extfichier, explnum_data, explnum_vignette) VALUES (";
        			$insert_sql .= $f_notice_id.",";
        			$insert_sql .= "'".addslashes($f_nom)."',";
        			$insert_sql .= "'".addslashes($afilename)."',";
        			$insert_sql .= "'".addslashes($mimetype)."',";
        			$insert_sql .= "'".addslashes($extension)."',";
        			$insert_sql .= "'".addslashes($content)."',";
        			$insert_sql .= "'".addslashes($vignette)."'";
        			$insert_sql .= ")";
        		}
        		pmb_mysql_query($insert_sql, $dbh);
        		
        		unlink("$base_path/temp/".$afilename);	
        */
    }
}
示例#6
0
文件: pmb.class.php 项目: hogsim/PMB
 function openCurrentDoc()
 {
     global $dbh;
     //s'il est en cache, c'est vachement simple
     if ($this->isInCache($this->listeDocs[$this->current]->explnum_id)) {
         $document = $this->readInCache($this->listeDocs[$this->current]->explnum_id);
         //sinon on va devoir regarder un peu ou ca se passe...
     } elseif ($this->listeDocs[$this->current]->explnum_url != "") {
         //on est sur une URL
         $document = file_get_contents($this->listeDocs[$this->current]->explnum_url);
         //on met les documents issues d'une URL en cache, ca évite les problèmes de connexion plus tard...
         $this->setInCache($this->listeDocs[$this->current]->explnum_id, $document);
     } elseif ($this->listeDocs[$this->current]->explnum_repertoire != 0) {
         //le document est stocké dans un répertoire d'upload
         $rep = new upload_folder($this->listeDocs[$this->current]->explnum_repertoire);
         $filepath = $rep->encoder_chaine(str_replace("//", "/", $rep->repertoire_path . $this->listeDocs[$this->current]->explnum_path . "/" . $this->listeDocs[$this->current]->explnum_nomfichier));
         $document = file_get_contents($filepath);
     } else {
         $requete = "SELECT explnum_data FROM explnum WHERE explnum_id = " . $this->listeDocs[$this->current]->explnum_id;
         $res = pmb_mysql_query($requete, $dbh);
         if (pmb_mysql_num_rows($res)) {
             $document = pmb_mysql_result($res, 0, 0);
         }
     }
     //on renvoie le contenu du document
     return $document;
 }
示例#7
0
<?php

// +-------------------------------------------------+
// © 2002-2004 PMB Services / www.sigb.net pmb@sigb.net et contributeurs (voir www.sigb.net)
// +-------------------------------------------------+
// $Id: upload_frame.php,v 1.2 2010-01-06 09:30:59 kantin Exp $
if (stristr($_SERVER['REQUEST_URI'], ".inc.php")) {
    die("no access");
}
// définition du minimum nécéssaire
$base_path = "../..";
$base_auth = "CATALOGAGE_AUTH";
$base_title = "\$msg[7]";
$include_path = "{$base_path}/includes";
$class_path = "{$base_path}/classes";
require_once "{$base_path}/includes/init.inc.php";
require_once "{$class_path}/upload_folder.class.php";
require_once $include_path . '/templates/upload_folder.tpl.php';
print "<div id='att' style='z-Index:1000'></div>";
print $up_frame;
$up = new upload_folder();
print $up->make_tree();
示例#8
0
 /**
  * Construit les noeuds de l'arborescence
  */
 function getNodes($chemin = '', $id, &$tree)
 {
     if ($chemin && is_dir($chemin)) {
         if (($files = @scandir($chemin)) !== false) {
             for ($i = 0; $i < sizeof($files); $i++) {
                 if ($files[$i] != '.' && $files[$i] != '..') {
                     $id_noeud = $id . "_" . $i;
                     $id_parent = $id;
                     $dir_name = $files[$i];
                     $path = $chemin . $dir_name . "/";
                     if (is_dir($path)) {
                         $id_copy = explode("_", $id_parent);
                         $up = new upload_folder($id_copy[1]);
                         //$tree .= "tab_libelle[\"$id_noeud\"] = \"".$up->decoder_chaine(addslashes($up->formate_path_to_nom($path))). "\";";
                         $tree .= "tab_libelle[\"{$id_noeud}\"] = \"" . addslashes($up->formate_path_to_nom($chemin) . $up->decoder_chaine($dir_name) . "/") . "\";";
                         $tree .= "_dt_fiel_.add('{$id_noeud}','{$id_parent}','" . addslashes($up->decoder_chaine($dir_name)) . "','','javascript:copy_to_div(\\'" . $id_noeud . "\\',\\'" . $up->repertoire_id . "\\');');\n";
                         $this->getNodes($path, $id_noeud, $tree);
                     }
                 }
             }
         }
     }
     return $tree;
 }
    function get_doc_num($explnum, $upload_folder)
    {
        global $pmb_set_time_limit, $dbh;
        $report = array();
        if (SESSrights & ADMINISTRATION_AUTH) {
            @set_time_limit($pmb_set_time_limit);
            if (is_array($explnum) && $upload_folder) {
                $idLien = '';
                if ($explnum['explnum_bulletin']) {
                    $query = "SELECT 1 FROM bulletins WHERE bulletin_id=" . $explnum['explnum_bulletin'];
                    $result = pmb_mysql_query($query, $dbh);
                    if (pmb_mysql_num_rows($result)) {
                        $idLien = 'explnum_bulletin=' . $explnum['explnum_bulletin'];
                    }
                } elseif ($explnum['explnum_notice']) {
                    $query = "SELECT 1 FROM notices WHERE notice_id=" . $explnum['explnum_notice'];
                    $result = pmb_mysql_query($query, $dbh);
                    if (pmb_mysql_num_rows($result)) {
                        $idLien = 'explnum_notice=' . $explnum['explnum_notice'];
                    }
                }
                if ($idLien) {
                    if (file_exists($upload_folder . $explnum['explnum_nomfichier'])) {
                        if (!$explnum['explnum_nom']) {
                            $explnum['explnum_nom'] = $explnum['explnum_nomfichier'];
                        }
                        if (!$explnum['explnum_repertoire']) {
                            $explnum['explnum_repertoire'] = '1';
                        }
                        if (!$explnum['explnum_statut']) {
                            $explnum['explnum_statut'] = '0';
                        }
                        if (!$explnum['explnum_path']) {
                            $explnum['explnum_path'] = '/';
                        }
                        if (!$explnum['explnum_extfichier']) {
                            $match = array();
                            if (preg_match('/.+\\.(.+)$/', $explnum['explnum_nomfichier'], $match)) {
                                $explnum['explnum_extfichier'] = $match[1];
                            }
                        }
                        if (!$explnum['explnum_mimetype']) {
                            $explnum['explnum_mimetype'] = trouve_mimetype($upload_folder . $explnum['explnum_nomfichier'], $explnum['explnum_extfichier']);
                        }
                        if (!$explnum['explnum_vignette']) {
                            $explnum['explnum_vignette'] = reduire_image($upload_folder . $explnum['explnum_nomfichier']);
                        }
                        $query = 'INSERT INTO explnum SET ' . $idLien . ',
								explnum_nom="' . addslashes($explnum['explnum_nom']) . '",
								explnum_mimetype="' . addslashes($explnum['explnum_mimetype']) . '",
								explnum_extfichier="' . addslashes($explnum['explnum_extfichier']) . '",
								explnum_nomfichier="' . addslashes($explnum['explnum_nomfichier']) . '",
								explnum_vignette="' . addslashes($explnum['explnum_vignette']) . '",	
								explnum_path="' . addslashes($explnum['explnum_path']) . '",
								explnum_repertoire="' . addslashes($explnum['explnum_repertoire']) . '",
								explnum_statut="' . addslashes($explnum['explnum_statut']) . '"';
                        pmb_mysql_query($query, $dbh);
                        $explnum['explnum_id'] = pmb_mysql_insert_id($dbh);
                        if ($explnum['explnum_id']) {
                            //on récup le répertoire dans lequel envoyer le fichier
                            $upload_repertoire = new upload_folder($explnum['explnum_repertoire']);
                            if (!is_dir($upload_repertoire->decoder_chaine($upload_repertoire->repertoire_path))) {
                                $report['error'][] = $this->msg['get_doc_num_upload_repertoire_do_not_exist'];
                                //On efface l'entrée
                                $query = 'DELETE FROM explnum WHERE explnum_id=' . $explnum['explnum_id'];
                                pmb_mysql_query($query, $dbh);
                            }
                            if (!rename($upload_folder . $explnum['explnum_nomfichier'], $upload_repertoire->decoder_chaine($upload_repertoire->repertoire_path) . $explnum['explnum_nomfichier'])) {
                                $report['error'][] = $this->msg['get_doc_num_rename_error'];
                                //On efface l'entrée
                                $query = 'DELETE FROM explnum WHERE explnum_id=' . $explnum['explnum_id'];
                                pmb_mysql_query($query, $dbh);
                            } else {
                                //Réussi ici, on réindex et on incrémente le résultat
                                $obj_explnum = new explnum($explnum['explnum_id']);
                                $index = new indexation_docnum($explnum['explnum_id']);
                                $index->indexer();
                                $report['info'] = 1;
                            }
                        } else {
                            //erreur de déplacement ou de création
                            $report['error'][] = $this->msg['get_doc_num_cant_create_explnum'];
                        }
                    } else {
                        $report['error'][] = $this->msg['get_doc_num_file_not_found'];
                        //On efface l'entrée
                        $query = 'DELETE FROM explnum WHERE explnum_id=' . $explnum['explnum_id'];
                        pmb_mysql_query($query, $dbh);
                    }
                } else {
                    //doc num sans id notice ou bulletin
                    $report['error'][] = $this->msg['get_doc_num_missing_link'];
                }
            } else {
                //il manque un param
                $report['error'][] = $this->msg['get_doc_num_missing_param'];
            }
        }
        return $report;
    }
示例#10
0
 function get_file_content()
 {
     $resultat = mysql_query("SELECT explnum_id, explnum_notice, explnum_bulletin, explnum_nom, explnum_mimetype, explnum_url, explnum_data, length(explnum_data) as taille,explnum_path, concat(repertoire_path,explnum_path,explnum_nomfichier) as path, repertoire_id FROM explnum left join upload_repertoire on repertoire_id=explnum_repertoire WHERE explnum_id = '" . $this->explnum_id . "' ");
     $nb_res = mysql_num_rows($resultat);
     if (!$nb_res) {
         exit;
     }
     $ligne = mysql_fetch_object($resultat);
     if ($ligne->explnum_data || $ligne->explnum_path) {
         if ($ligne->explnum_path) {
             $up = new upload_folder($ligne->repertoire_id);
             $path = str_replace("//", "/", $ligne->path);
             $path = $up->encoder_chaine($path);
             if (file_exists($path) && filesize($path)) {
                 $fo = fopen($path, 'rb');
                 $data = fread($fo, filesize($path));
                 fclose($fo);
             } else {
                 $data = "";
             }
         } else {
             $data = $ligne->explnum_data;
         }
     }
     return $data;
 }
 function merge()
 {
     global $msg, $dbh, $gestion_acces_active, $gestion_acces_empr_notice;
     $cpt_doc_num = 0;
     if (is_array($this->docnum_ids) && count($this->docnum_ids)) {
         foreach ($this->docnum_ids as $explnum_id) {
             $resultat = pmb_mysql_query("SELECT explnum_id, explnum_notice, explnum_bulletin, explnum_nom, explnum_mimetype, explnum_url, explnum_data, length(explnum_data) as taille,explnum_path, concat(repertoire_path,explnum_path,explnum_nomfichier) as path, repertoire_id FROM explnum left join upload_repertoire on repertoire_id=explnum_repertoire WHERE explnum_id = '{$explnum_id}' ", $dbh);
             $nb_res = pmb_mysql_num_rows($resultat);
             $ligne = pmb_mysql_fetch_object($resultat);
             $id_for_rigths = $ligne->explnum_notice;
             if ($ligne->explnum_bulletin != 0) {
                 //si bulletin, les droits sont rattachés à la notice du bulletin, à défaut du pério...
                 $req = "select bulletin_notice,num_notice from bulletins where bulletin_id =" . $ligne->explnum_bulletin;
                 $res = pmb_mysql_query($req);
                 if (pmb_mysql_num_rows($res)) {
                     $row = pmb_mysql_fetch_object($result);
                     $id_for_rigths = $row->num_notice;
                     if (!$id_for_rigths) {
                         $id_for_rigths = $row->bulletin_notice;
                     }
                 }
                 $type = "";
             }
             //droits d'acces emprunteur/notice
             if ($gestion_acces_active == 1 && $gestion_acces_empr_notice == 1) {
                 $ac = new acces();
                 $dom_2 = $ac->setDomain(2);
                 $rights = $dom_2->getRights($_SESSION['id_empr_session'], $id_for_rigths);
             }
             //Accessibilité des documents numériques aux abonnés en opac
             $req_restriction_abo = "SELECT  explnum_visible_opac, explnum_visible_opac_abon FROM notice_statut, explnum, notices WHERE explnum_notice=notice_id AND statut=id_notice_statut  AND explnum_id='{$explnum_id}' ";
             $result = pmb_mysql_query($req_restriction_abo, $dbh);
             if (!pmb_mysql_num_rows($result)) {
                 $req_restriction_abo = "SELECT explnum_visible_opac, explnum_visible_opac_abon\n\t\t\t\t\t\tFROM notice_statut, explnum, bulletins, notices\n\t\t\t\t\t\tWHERE explnum_bulletin = bulletin_id\n\t\t\t\t\t\tAND num_notice = notice_id\n\t\t\t\t\t\tAND statut = id_notice_statut\n\t\t\t\t\t\tAND explnum_id='{$explnum_id}' ";
                 $result = pmb_mysql_query($req_restriction_abo, $dbh);
             }
             $expl_num = pmb_mysql_fetch_array($result);
             if ($rights & 16 || is_null($dom_2) && $expl_num["explnum_visible_opac"] && (!$expl_num["explnum_visible_opac_abon"] || $expl_num["explnum_visible_opac_abon"] && $_SESSION["user_code"])) {
                 if ($ligne->explnum_data || $ligne->explnum_path) {
                     if ($ligne->explnum_path) {
                         $up = new upload_folder($ligne->repertoire_id);
                         $path = str_replace("//", "/", $ligne->path);
                         $path = $up->encoder_chaine($path);
                         $fo = fopen($path, 'rb');
                         $ligne->explnum_data = fread($fo, filesize($path));
                         $ligne->taille = filesize($path);
                         fclose($fo);
                     }
                     // $ligne->explnum_data;
                     $filename = "./temp/doc_num_" . $explnum_id . session_id() . ".pdf";
                     $filename_list[] = $filename;
                     $fp = fopen($filename, "wb");
                     fwrite($fp, $ligne->explnum_data);
                     fclose($fp);
                     $cpt_doc_num++;
                 }
             }
         }
     }
     if ($cpt_doc_num > 1) {
         $filename_output = "./temp/doc_num_output" . session_id() . ".pdf";
         $cmd = "pdfunite " . implode(' ', $filename_list) . " " . $filename_output;
         exec($cmd);
         $contenu_merge = file_get_contents($filename_output);
         unlink($filename_output);
         foreach ($filename_list as $filename) {
             unlink($filename);
         }
         header('Content-type: application/pdf');
         print $contenu_merge;
     } elseif ($cpt_doc_num) {
         $contenu_merge = file_get_contents($filename_list[0]);
         header('Content-type: application/pdf');
         print $contenu_merge;
         unlink($filename_list[0]);
     }
 }