get_parms(
"sbid"
, "piv" // pivot language
, "cid" // candidates
, "tid" // where to accept terms
, "typ" // "TS"=creer nouvo terme spec. ou "SY" creer simplement synonyme
, "debug"
);
$ret = array('refresh' => array());
$refresh = array();
$sbas_id = (int) $parm["sbid"];
try {
$databox = $app['phraseanet.appbox']->get_databox($sbas_id);
$connbas = $databox->get_connection();
$domct = $databox->get_dom_cterms();
if ( ! ($domct instanceof DOMDocument))
throw new Exception('Unable to load cterms');
$domth = $databox->get_dom_thesaurus();
if ( ! ($domth instanceof DOMDocument))
throw new Exception('Unable to load thesaurus');
$xpathth = new DOMXPath($domth);
if ($parm["tid"] == "T")
$q = "/thesaurus";
else
$q = "/thesaurus//te[@id='" . $parm["tid"] . "']";
if ($parm["debug"])
printf("qth: %s
\n", $q);
$parentnode = $xpathth->query($q)->item(0);
if ( ! $parentnode)
throw new Exception('Unable to find branch');
$xpathct = new DOMXPath($domct);
$ctchanged = $thchanged = false;
foreach ($parm["cid"] as $cid) {
$q = "//te[@id='" . $cid . "']";
if ($parm["debug"])
printf("qct: %s
\n", $q);
$ct = $xpathct->query($q)->item(0);
if ( ! $ct)
continue;
if ($parm["typ"] == "TS") {
// importer tt la branche candidate comme nouveau ts
$nid = $parentnode->getAttribute("nextid");
$parentnode->setAttribute("nextid", (int) $nid + 1);
$oldid = $ct->getAttribute("id");
$te = $domth->importNode($ct, true);
$chgids = array();
if (($pid = $parentnode->getAttribute("id")) == "") {
$pid = "T" . $nid;
} else {
$pid .= "." . $nid;
}
renum($te, $pid, $chgids);
$te = $parentnode->appendChild($te);
if ($parm["debug"])
printf("newid=%s
\n", $te->getAttribute("id"));
$soldid = str_replace(".", "d", $oldid) . "d";
$snewid = str_replace(".", "d", $pid) . "d";
$l = strlen($soldid) + 1;
$sql = "UPDATE thit SET value=CONCAT('$snewid', SUBSTRING(value FROM $l)) WHERE value LIKE :like";
if ($parm["debug"]) {
printf("soldid=%s ; snewid=%s
\nsql=%s
\n", $soldid, $snewid, $sql);
} else {
$stmt = $connbas->prepare($sql);
$stmt->execute(array(':like' => $soldid . '%'));
$stmt->closeCursor();
}
$refreshid = $parentnode->getAttribute('id');
$refresh['T' . $refreshid] = array('type' => 'T', 'sbid' => $sbas_id, 'id' => $refreshid);
$thchanged = true;
$refreshid = $ct->parentNode->getAttribute("id");
$refresh['C' . $refreshid] = array('type' => 'C', 'sbid' => $sbas_id, 'id' => $refreshid);
$ct->parentNode->removeChild($ct);
$ctchanged = true;
} elseif ($parm["typ"] == "SY") {
// importer tt le contenu de la branche sous la destination
for ($ct2 = $ct->firstChild; $ct2; $ct2 = $ct2->nextSibling) {
if ($ct2->nodeType != XML_ELEMENT_NODE || $ct2->nodeName != 'sy')
continue;
if ($parm['debug'])
printf("ct2:%s \n", var_export($ct2, true));
$nid = $parentnode->getAttribute("nextid");
$parentnode->setAttribute("nextid", (int) $nid + 1);
$oldid = $ct2->getAttribute("id");
$te = $domth->importNode($ct2, true);
$chgids = array();
if (($pid = $parentnode->getAttribute("id")) == "") {
// racine
$pid = "T" . $nid;
} else {
$pid .= "." . $nid;
}
renum($te, $pid, $chgids);
$te = $parentnode->appendChild($te);
if ($parm["debug"])
printf("newid=%s
\n", $te->getAttribute("id"));
$soldid = str_replace(".", "d", $oldid) . "d";
$snewid = str_replace(".", "d", $pid) . "d";
$l = strlen($soldid) + 1;
$sql = "UPDATE thit SET value=CONCAT('$snewid', SUBSTRING(value FROM $l)) WHERE value LIKE :like";
if ($parm["debug"]) {
printf("soldid=%s ; snewid=%s
\nsql=%s
\n", $soldid, $snewid, $sql);
} else {
$stmt = $connbas->prepare($sql);
$stmt->execute(array(':like' => $soldid . '%'));
$stmt->closeCursor();
}
$thchanged = true;
}
$refreshid = $parentnode->parentNode->getAttribute("id");
$refresh['T' . $refreshid] = array('type' => 'T', 'sbid' => $sbas_id, 'id' => $refreshid);
$refreshid = $ct->parentNode->getAttribute("id");
$refresh['C' . $refreshid] = array('type' => 'C', 'sbid' => $sbas_id, 'id' => $refreshid);
$ct->parentNode->removeChild($ct);
$ctchanged = true;
}
}
if ($ctchanged) {
$databox->saveCterms($domct);
}
if ($thchanged) {
$databox->saveThesaurus($domth);
}
} catch (Exception $e) {
}
foreach ($refresh as $r)
$ret['refresh'][] = $r;
if ($parm["debug"])
print("
" . p4string::jsonencode($ret) . ""); else { phrasea::headers(200, true, 'application/json', 'UTF-8', false); print(p4string::jsonencode($ret)); } function renum($node, $id, &$chgids, $depth = 0) { global $parm; if ($parm["debug"]) printf("renum('%s' -> '%s')