Example #1
0
 /**
  * Inserts or updates record in the underlying database
  *
  * @param string $nodeName Identifier of server which data comes from (used for harvesting)
  * @param string $viewGroup Name of the group for viewing (used for CENIA filters)
  * @param boolean $stopOnError If set true, insert no record if error occurs. Otherwise attempts to insert at least valid elements. 
  * @return array Associative array with update results (both successful and failed records)
  */
 function update($nodeName = '', $editGroup = '', $viewGroup = '', $public = 0, $stopOnError = true, $overwrite = 'all')
 {
     $importer = new MetadataImport($this->params['DEBUG']);
     $md = $importer->xml2array($this->xml, PHPPRG_DIR . "/../xsl/update2micka.xsl");
     $c = new MdImport();
     $c->setDataType($public);
     // nastavení veřejného záznamu
     if ($editGroup) {
         $c->group_e = $editGroup;
     }
     if ($viewGroup) {
         $c->group_v = $viewGroup;
     }
     $c->stop_error = $stopOnError;
     // pokud dojde k chybě při importu pokračuje
     $c->server_name = $nodeName;
     // jméno serveru ze kterého se importuje
     $c->setReportValidType('array', true);
     // formát validace
     $result = $c->dataToMd($md, $overwrite);
     if ($this->params['DEBUG'] == 1) {
         var_dump($result);
     }
     return $result;
 }
Example #2
0
function mainInsert($post, $defaultValue = array())
{
    //my_print_r($post);
    $rs = array();
    $md = array();
    $rs['akce'] = 'error';
    $rs['ok'] = FALSE;
    $rs['report'] = '';
    $rs['data'] = '';
    $md_record = new MdRecord();
    //$md_record->deleteTmpRecords();
    if (count($post) == 0) {
        setMickaLog('INSERT ERROR, POST is empty!', 'ERROR', 'micka_main_lib.main_insert');
        $rs['report'] = 'Error, not complete data!';
        //return $rs;
        Debugger::log('[micka_main_lib.mainInsert] ' . 'POST is empty!', 'ERROR');
        require PHPINC_DIR . '/templates/404_record.php';
    }
    $defaultEditGroup = array_key_exists('edit_group', $defaultValue) === TRUE ? $defaultValue['edit_group'] : MICKA_USER;
    $defaultViewGroup = array_key_exists('view_group', $defaultValue) === TRUE ? $defaultValue['view_group'] : MICKA_USER;
    //	0:ISO 19115 | 10:ISO 19119 | 1:DC | 2:FC | 99:import
    $md['md_standard'] = isset($post['standard']) && $post['standard'] != '' ? htmlspecialchars($post['standard']) : 0;
    // skupina pro prohlížení
    $md['view_group'] = isset($post['group_v']) && $post['group_v'] != '' ? htmlspecialchars($post['group_v']) : $defaultEditGroup;
    // skupina s právem editace
    $md['edit_group'] = isset($post['group_e']) && $post['group_e'] != '' ? htmlspecialchars($post['group_e']) : $defaultViewGroup;
    // hlavní jazyk záznamu
    $lang_main = isset($post['lang_main']) && $post['lang_main'] != '' ? htmlspecialchars($post['lang_main']) : MICKA_LANG;
    // seznam dalších jazyků
    $md['lang'] = isset($post['languages']) ? htmlspecialchars(implode($post['languages'], "|")) : '';
    if ($md['lang'] == '' && $lang_main != '') {
        $md['lang'] = $lang_main;
    }
    // template s default hodnotami
    $template = '';
    if ($md['md_standard'] < 99) {
        if ($md['md_standard'] == 0) {
            $template = PHPCFG_DIR . '/templateMd.xml';
        } elseif ($md['md_standard'] == 10) {
            $template = PHPCFG_DIR . '/templateMs.xml';
        } elseif ($md['md_standard'] == 1) {
            $template = PHPCFG_DIR . '/templateDc.xml';
        } elseif ($md['md_standard'] == 2) {
            $template = PHPCFG_DIR . '/templateFc.xml';
        }
        if ($template != '' && file_exists($template)) {
            $md['file_type'] = 'ISO19139';
            $md['update_type'] = 'skip';
            $md['md_standard'] = 99;
        }
    }
    // IMPORT
    if ($md['md_standard'] == 99) {
        $md['file_type'] = isset($post['fileType']) && $post['fileType'] != '' ? htmlspecialchars($post['fileType']) : 'ISO19139';
        $md['md_rec'] = isset($post['md_rec']) && $post['md_rec'] != '' ? htmlspecialchars($post['md_rec']) : '';
        $md['fc'] = isset($post['fc']) && $post['fc'] != '' ? htmlspecialchars($post['fc']) : '';
        $md['service_type'] = isset($post['serviceType']) && $post['serviceType'] != '' ? htmlspecialchars($post['serviceType']) : 'WMS';
        $md['url'] = isset($post['url']) && $post['url'] != '' ? htmlspecialchars($post['url']) : '';
        $md['url'] = $md['url'] != '' ? str_replace('&amp;', '&', $md['url']) : '';
        $md['update_type'] = isset($post['updateType']) && $post['updateType'] != '' ? htmlspecialchars($post['updateType']) : 'skip';
    }
    if ($md['md_standard'] < 99) {
        // Vytvoření nového záznamu v tmp
        $recno = $md_record->setNewRecord($md, $lang_main);
        if ($recno > 0) {
            $rs['akce'] = 'edit';
            $rs['ok'] = TRUE;
            $rs['data'] = $recno;
            setEditId2Session('recno', 'new');
            setEditId2Session('recnoTmp', $recno);
            $redirectUrl = substr(htmlspecialchars($_SERVER['PHP_SELF']), 0, strrpos($_SERVER['PHP_SELF'], '/')) . '?ak=edit&recno=new';
            setUrlEdit2Session($redirectUrl);
        }
        //return $rs;
        return $redirectUrl;
    }
    if ($md['md_standard'] == 99) {
        // Import ze souboru nebo url
        require PHPPRG_DIR . '/micka_lib_php5.php';
        require PHPPRG_DIR . '/micka_lib_insert.php';
        require PHPPRG_DIR . '/MdImport.php';
        //$prevod = DomainCodes2List();
        $report = array();
        $importer = new MetadataImport();
        if (isset($_FILES['soubor']['tmp_name']) && $_FILES['soubor']['tmp_name'] != '' || $template != '') {
            if ($_FILES['soubor']['tmp_name'] != '') {
                if (!file_exists(PHPINC_DIR . '/temp/upload/')) {
                    mkdir(PHPINC_DIR . '/temp/upload/', 0777);
                }
                $tmpFileName = PHPINC_DIR . '/temp/upload/' . md5(uniqid(rand(), true)) . '.xml';
                if (is_uploaded_file($_FILES['soubor']['tmp_name'])) {
                    move_uploaded_file($_FILES['soubor']['tmp_name'], $tmpFileName);
                } else {
                    $tmpFileName = '';
                }
            } else {
                $tmpFileName = $template;
            }
            if ($tmpFileName != '') {
                //$prevod = DomainCodes2List();
                $xmlstring = file_get_contents($tmpFileName);
                $importer = new MetadataImport();
                $importer->setTableMode('tmp');
                $report = $importer->import($xmlstring, $md['file_type'], MICKA_USER, $md['edit_group'], $md['view_group'], $md['mds'] = 0, $md['lang'], $lang_main, $params = false, $md['update_type'], $md['md_rec']);
            } else {
                $rs['report'] = "File error!";
                return $rs;
            }
        } elseif ($md['url'] != '') {
            setMickaLog($md['url'], 'INFO', 'micka_main_lib.main_insert.url');
            $importer->setTableMode('tmp');
            $report = $importer->importService($md['url'], $md['service_type'], MICKA_USER, $md['edit_group'], $md['view_group'], $md['mds'] = 10, $md['lang'], $lang_main, $public = 0, $md['update_type']);
        } else {
            // není zadán soubor ani url
            $rs['report'] = "Unknown import type!";
            return $rs;
        }
    }
    // zpracování reportu po importu
    if ($report[0]['ok'] == 1) {
        if (substr($report[0]['report'], 0, 11) == 'UUID exists') {
            $rs['report'] = "UUID exists, stop import!";
            $rs['akce'] = 'error';
            $rs['data'] = $report[0];
            return $rs;
        } else {
            $rs['ok'] = TRUE;
            $rs['report'] = $report[0]['report'];
            $md_record->setTableMode('tmp');
            $record = $md_record->getMd('uuid', $report[0]['uuid']);
            if (is_array($record) && count($record) > 1) {
                $rs['akce'] = IMPORT_VALID ? 'import' : 'edit';
                if ($rs['akce'] == 'edit') {
                    $rs['data'] = $record['md']['RECNO'];
                } else {
                    $rs['data']['md'] = $record['md'];
                }
            }
        }
    } else {
        $rs['report'] = $report[0]['report'];
        $rs['data'] = $report[0];
        return $rs;
    }
    if ($rs['akce'] == 'edit') {
        $redirectUrl = substr(htmlspecialchars($_SERVER['PHP_SELF']), 0, strrpos($_SERVER['PHP_SELF'], '/')) . '?ak=edit&recno=new';
        setUrlEdit2Session($redirectUrl);
    } else {
        // TODO: zatím jen editace
        $redirectUrl = substr(htmlspecialchars($_SERVER['PHP_SELF']), 0, strrpos($_SERVER['PHP_SELF'], '/')) . '?ak=edit&recno=new';
        setUrlEdit2Session($redirectUrl);
    }
    return $redirectUrl;
}