Newer
Older

cedric@yterium.com
a validé
<?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.
*/

cedric@yterium.com
a validé

cedric@yterium.com
a validé
return;
}

cedric@yterium.com
a validé

cedric@yterium.com
a validé
/**
* Action editer_document
*
* @param int $arg
* @return array

cedric@yterium.com
a validé
*/

gilles.vincent@gmail.com
a validé
function action_editer_document_dist($arg = null) {

cedric@yterium.com
a validé

cedric@yterium.com
a validé
if (is_null($arg)) {
$securiser_action = charger_fonction('securiser_action', 'inc');
$arg = $securiser_action();
}

cedric@yterium.com
a validé
// Envoi depuis le formulaire de creation d'un document
if (!$id_document = intval($arg)) {
$id_document = document_inserer();

cedric@yterium.com
a validé

cedric@yterium.com
a validé
if (!$id_document) {

cedric@yterium.com
a validé
} // erreur

cedric@yterium.com
a validé
$err = document_modifier($id_document);
return [$id_document, $err];

cedric@yterium.com
a validé
}
/**
* Creer un nouveau document
*

cedric@yterium.com
a validé
* @param int $id_parent
* inutilise, pas de parent pour les documents
* @param array|null $set

cedric@yterium.com
a validé
*/

gilles.vincent@gmail.com
a validé
function document_inserer($id_parent = null, $set = null) {

cedric@yterium.com
a validé

cedric@yterium.com
a validé
'statut' => 'prop',
'date' => 'NOW()',

cedric@yterium.com
a validé

cedric@yterium.com
a validé
if ($set) {

cedric@yterium.com
a validé
$champs = array_merge($champs, $set);

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé

cedric@yterium.com
a validé
// Envoyer aux plugins

cedric@yterium.com
a validé
'table' => 'spip_documents',

cedric@yterium.com
a validé
'data' => $champs

cedric@yterium.com
a validé
);
$id_document = sql_insertq('spip_documents', $champs);
pipeline(
'post_insertion',
'table' => 'spip_documents',
'id_objet' => $id_document

cedric@yterium.com
a validé
return $id_document;
}
/**
* Enregistre une revision de document.

cedric@yterium.com
a validé
* $set est un contenu (par defaut on prend le contenu via _request())

cedric@yterium.com
a validé
*
* @param int $id_document

cedric@yterium.com
a validé
* @param array|null $set
* @return string|null

cedric@yterium.com
a validé
*/

cedric@yterium.com
a validé
function document_modifier($id_document, $set = null) {

cedric@yterium.com
a validé

cedric@yterium.com
a validé
include_spip('inc/modifier');

cedric@yterium.com
a validé

cedric@yterium.com
a validé
// champs normaux

cedric@yterium.com
a validé
$champs = collecter_requests(

cedric@yterium.com
a validé
objet_info('document', 'champs_editables'),

cedric@yterium.com
a validé
// black list
['parents', 'ajout_parents'],

cedric@yterium.com
a validé
// donnees eventuellement fournies
$set
);

cedric@yterium.com
a validé

cedric@yterium.com
a validé
// Si le document est publie, invalider les caches et demander sa reindexation
$t = sql_getfetsel('statut', 'spip_documents', 'id_document=' . intval($id_document));

cedric@yterium.com
a validé
if ($t == 'publie') {
$invalideur = "id='id_document/$id_document'";
$indexation = true;
}

cedric@yterium.com
a validé

cedric@yterium.com
a validé
// si le fichier est modifie, noter le nom de l'ancien pour faire le menage

cedric@yterium.com
a validé
if (isset($champs['fichier'])) {
$ancien_fichier = sql_getfetsel('fichier', 'spip_documents', 'id_document=' . intval($id_document));

cedric@yterium.com
a validé
}
if (
$err = objet_modifier_champs(
'document',
$id_document,
[

cedric@yterium.com
a validé
'data' => $set,

cedric@yterium.com
a validé
'invalideur' => $invalideur,
'indexation' => $indexation
],
$champs
)
) {
return $err;

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé
// nettoyer l'ancien fichier si necessaire
if (
isset($champs['fichier']) // un plugin a pu interdire la modif du fichier en virant le champ

marcimat@rezo.net
a validé
and $champs['fichier']
and $ancien_fichier // on avait bien note le nom du fichier avant la modif
and $ancien_fichier !== $champs['fichier'] // et il a ete modifie

cedric@yterium.com
a validé
and !tester_url_absolue($ancien_fichier)

marcimat@rezo.net
a validé
and @file_exists($f = get_spip_doc($ancien_fichier))

cedric@yterium.com
a validé
) {
spip_unlink($f);
}

cedric@yterium.com
a validé
// Changer le statut du document ?
// le statut n'est jamais fixe manuellement mais decoule de celui des objets lies
$champs = collecter_requests(['parents', 'ajouts_parents'], [], $set);

cedric@yterium.com
a validé
if (document_instituer($id_document, $champs)) {

cedric@yterium.com
a validé
//
// Post-modifications
//

cedric@yterium.com
a validé

cedric@yterium.com
a validé
// Invalider les caches
include_spip('inc/invalideur');
suivre_invalideur("id='document/$id_document'");

cedric@yterium.com
a validé
}
}

cedric@yterium.com
a validé
/**
* determiner le statut d'un document : prepa/publie
* si on trouve un element joint sans champ statut ou avec un statut='publie' alors le doc est publie aussi
*
* @param int $id_document
* @param array $champs
* @return bool

cedric@yterium.com
a validé
*/
function document_instituer($id_document, $champs = []) {

cedric@yterium.com
a validé
$statut = $champs['statut'] ?? null;
$date_publication = $champs['date_publication'] ?? null;

cedric@yterium.com
a validé
if (isset($champs['parents'])) {
medias_revision_document_parents($id_document, $champs['parents']);
}
if (isset($champs['ajout_parents'])) {
medias_revision_document_parents($id_document, $champs['ajout_parents'], true);
}
$row = sql_fetsel('statut,date_publication', 'spip_documents', 'id_document=' . intval($id_document));

cedric@yterium.com
a validé
$statut_ancien = $row['statut'];
$date_publication_ancienne = $row['date_publication'];

cedric@yterium.com
a validé

cedric@yterium.com
a validé
/* Autodetermination du statut si non fourni */

cedric@yterium.com
a validé
if (is_null($statut)) {
$determiner_statut_document = charger_fonction('determiner_statut_document', 'inc');
$champs = $determiner_statut_document($id_document, $statut_ancien, $date_publication_ancienne);
// rien a faire
if ($champs === false) {

cedric@yterium.com
a validé
return false;

cedric@yterium.com
a validé
}
}
else {
if ($statut !== $statut_ancien) {
$champs['statut'] = $statut;

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé
}
if (
!is_null($date_publication)
and empty($champs['date_publication'])
and $date_publication != $date_publication_ancienne
) {
$champs['date_publication'] = $date_publication;
}
// Envoyer aux plugins
$champs = pipeline(
'pre_edition',
[
'args' => [
'table' => 'spip_documents',
'id_objet' => $id_document,
'action' => 'instituer',
'statut_ancien' => $statut_ancien,
'date_ancienne' => $date_publication_ancienne,
'data' => $champs
);
if (!(is_countable($champs) ? count($champs) : 0)) {
return false;
}
sql_updateq('spip_documents', $champs, 'id_document=' . intval($id_document));
if (!empty($champs['statut'])) {
$publier_rubriques = sql_allfetsel(
'id_objet',
'spip_documents_liens',
"objet='rubrique' AND id_document=" . intval($id_document)
if (is_countable($publier_rubriques) ? count($publier_rubriques) : 0) {
include_spip('inc/rubriques');
foreach ($publier_rubriques as $r) {
calculer_rubriques_if($r['id_objet'], ['statut' => $champs['statut']], $statut_ancien, false);
}
}

cedric@yterium.com
a validé
}
// Invalider les caches
include_spip('inc/invalideur');
suivre_invalideur("id='document/$id_document'");
pipeline(
'post_edition',
[
'args' => [
'table' => 'spip_documents',
'id_objet' => $id_document,
'action' => 'instituer',
'statut_ancien' => $statut_ancien,
'date_ancienne' => $date_publication_ancienne,
'data' => $champs
);
return true;

cedric@yterium.com
a validé
}
/**
* Revision des parents d'un document
* chaque parent est liste au format objet|id_objet
*
* @param int $id_document
* @param array $parents
* @param bool $ajout

cedric@yterium.com
a validé
*/

cedric@yterium.com
a validé
function medias_revision_document_parents($id_document, $parents = null, $ajout = false) {

rastapopoulos@spip.org
a validé
include_spip('inc/autoriser');

cedric@yterium.com
a validé
if (!is_array($parents)) {

cedric@yterium.com
a validé
return;

cedric@yterium.com
a validé
}
$insertions = [];
$objets_parents = []; // array('article'=>array(12,23))

cedric@yterium.com
a validé

cedric@yterium.com
a validé
// au format objet|id_objet

cedric@yterium.com
a validé
foreach ($parents as $p) {
$p = explode('|', $p);
if (
preg_match('/^[a-z0-9_]+$/i', $objet = $p[0])

cedric@yterium.com
a validé
and (($p[1] = intval($p[1])) or in_array($objet, ['site', 'rubrique']))

cedric@yterium.com
a validé
) { // securite

cedric@yterium.com
a validé
$objets_parents[$p[0]][] = $p[1];

cedric@yterium.com
a validé
}
}

cedric@yterium.com
a validé

cedric@yterium.com
a validé
include_spip('action/editer_liens');
// les liens actuels
$liens = objet_trouver_liens(['document' => $id_document], '*');
$deja_parents = [];

cedric@yterium.com
a validé
// si ce n'est pas un ajout, il faut supprimer les liens actuels qui ne sont pas dans $objets_parents

cedric@yterium.com
a validé
if (!$ajout) {
foreach ($liens as $k => $lien) {

marcimat@rezo.net
a validé
if (!isset($objets_parents[$lien['objet']]) or !in_array($lien['id_objet'], $objets_parents[$lien['objet']])) {

cedric@yterium.com
a validé
if (autoriser('dissocierdocuments', $lien['objet'], $lien['id_objet'])) {
objet_dissocier(['document' => $id_document], [$lien['objet'] => $lien['id_objet']]);

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé
unset($liens[$k]);

cedric@yterium.com
a validé
} else {
$deja_parents[$lien['objet']][] = $lien['id_objet'];

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé
}

tcharlss@bravecassine.com
a validé
// trier les objets à traiter : ne pas prendre en compte ceux qui sont déjà associés ou qu'on n'a pas le droit d'associer

cedric@yterium.com
a validé
foreach ($objets_parents as $objet => $ids) {
foreach ($ids as $k => $id) {

tcharlss@bravecassine.com
a validé
isset($deja_parents[$objet])
and in_array($id, $deja_parents[$objet])
)
or !autoriser('associerdocuments', $objet, $id)
) {

cedric@yterium.com
a validé
unset($objets_parents[$objet][$k]);
}
}
}
objet_associer(['document' => $id_document], $objets_parents);