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/genie/plugins-dist/svp/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/hednacluml/genie/plugins-dist/svp/svp_administrations.php
<?php

/**
 * Fichier gérant l'installation et désinstallation du plugin
 *
 * @plugin SVP pour SPIP
 * @license GPL
 * @package SPIP\SVP\Installation
 **/

include_spip('base/create');

/**
 * Installation et mises à jour du plugin
 *
 * Crée les tables SQL du plugin (spip_depots, spip_plugins, spip_depots_plugins, spip_paquets)
 *
 * @param string $nom_meta_base_version
 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
 * @param string $version_cible
 *     Version du schéma de données dans ce plugin (déclaré dans paquet.xml)
 * @return void
 **/
function svp_upgrade($nom_meta_base_version, $version_cible) {

	$maj = [];

	$install = ['maj_tables', ['spip_depots', 'spip_plugins', 'spip_depots_plugins', 'spip_paquets']];
	$maj['create'][] = $install;
	$maj['0.2'][] = ['maj_tables', 'spip_paquets'];
	$maj['0.3'][] = ['maj_tables', 'spip_paquets']; // prefixe et attente
	$maj['0.3'][] = ['svp_synchroniser_prefixe'];
	include_spip('inc/svp_depoter_local');
	// on force le recalcul des infos des paquets locaux.
	$maj['0.3.1'][] = ['svp_actualiser_paquets_locaux', true];

	// autant mettre tout a jour pour avoir une base propre apres renommage extensions=> plugins_dist
	$maj['0.4.0'][] = ['svp_vider_tables', $nom_meta_base_version];
	$maj['0.4.0'][] = $install;
	// on force le recalcul des infos des paquets locaux.
	#$maj['0.4.1'][] = ['svp_actualiser_paquets_locaux', true];
	// on force le recalcul des infos des paquets locaux.
	$maj['0.5.0'][] = ['maj_tables', 'spip_paquets'];
	#$maj['0.5.1'][] = ['svp_actualiser_paquets_locaux', true];
	// suppression des colonnes tags et categorie car c'est le plugin SVP Typologie différent qui s'en occupe totalement.
	$maj['0.6.0'] = [
		['maj_tables',['spip_plugins']],
		['sql_alter','TABLE spip_plugins DROP COLUMN categorie'],
		['sql_alter','TABLE spip_plugins DROP COLUMN tags'],
	];

	$maj['0.6.1'] = [
		['sql_alter', "TABLE spip_plugins CHANGE prefixe prefixe VARCHAR(48) DEFAULT '' NOT NULL"],
		['sql_alter', "TABLE spip_paquets CHANGE prefixe prefixe VARCHAR(48) DEFAULT '' NOT NULL"],
	];

	$maj['0.6.2'][] = ['svp_actualiser_paquets_locaux', true]; //forcer les date "nulles"

	include_spip('base/upgrade');
	maj_plugin($nom_meta_base_version, $version_cible, $maj);
}

/**
 * Désinstallation du plugin
 *
 * Supprime les tables SQL du plugin (spip_depots, spip_plugins, spip_depots_plugins, spip_paquets)
 *
 * @param string $nom_meta_base_version
 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
 * @return void
 **/
function svp_vider_tables($nom_meta_base_version) {
	sql_drop_table('spip_depots');
	sql_drop_table('spip_plugins');
	sql_drop_table('spip_depots_plugins');
	sql_drop_table('spip_paquets');
	effacer_meta($nom_meta_base_version);

	spip_log('DESINSTALLATION BDD', 'svp_actions.' . _LOG_INFO);
}


/**
 * Ajoute le préfixe des plugins dans chaque ligne de paquets
 *
 * Cette mise à jour permet de dupliquer le préfixe des plugins
 * dans la ligne des paquets (cette colonne était absente avant)
 * pour plus de simplicité ensuite dans les requêtes SQL.
 */
function svp_synchroniser_prefixe() {
	$paquets = sql_allfetsel(
		['pa.id_paquet', 'pl.prefixe'],
		['spip_paquets AS pa', 'spip_plugins AS pl'],
		'pl.id_plugin=pa.id_plugin'
	);

	if ($paquets) {
		// On insere, en encapsulant pour sqlite...
		if (sql_preferer_transaction()) {
			sql_demarrer_transaction();
		}

		foreach ($paquets as $paquet) {
			sql_updateq(
				'spip_paquets',
				['prefixe' => $paquet['prefixe']],
				'id_paquet=' . intval($paquet['id_paquet'])
			);
		}

		if (sql_preferer_transaction()) {
			sql_terminer_transaction();
		}
	}
}

SAMX