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 = databox::get_instance($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')