'prop',
'date' => 'NOW()',
);
// Envoyer aux plugins
$champs = pipeline('pre_insertion',
array(
'args' => array(
'table' => 'spip_documents',
),
'data' => $champs
)
);
$id_document = sql_insertq("spip_documents", $champs);
pipeline('post_insertion',
array(
'args' => array(
'table' => 'spip_documents',
'id_objet' => $id_document
),
'data' => $champs
)
);
return $id_document;
}
/**
* Enregistre une revision de document.
* $c est un contenu (par defaut on prend le contenu via _request())
*
* @param int $id_document
* @param array $c
*/
function document_set ($id_document, $c=false) {
// champs normaux
$champs = array();
foreach (array(
'titre', 'descriptif', 'date', 'taille', 'largeur','hauteur','mode','credits',
'fichier','distant','extension', 'id_vignette',
) as $champ)
if (($a = _request($champ,$c)) !== null)
$champs[$champ] = $a;
// Si le document est publie, invalider les caches et demander sa reindexation
$t = sql_getfetsel("statut", "spip_documents", 'id_document='.intval($id_document));
if ($t == 'publie') {
$invalideur = "id='id_document/$id_document'";
$indexation = true;
}
$ancien_fichier = "";
// si le fichier est modifie, noter le nom de l'ancien pour faire le menage
if (isset($champs['fichier'])){
$ancien_fichier = sql_getfetsel('fichier','spip_documents','id_document='.intval($id_document));
}
include_spip('inc/modifier');
modifier_contenu('document', $id_document,
array(
'invalideur' => $invalideur,
'indexation' => $indexation
),
$champs);
// nettoyer l'ancien fichier si necessaire
if ($champs['fichier'] // un plugin a pu interdire la modif du fichier en virant le champ
AND $ancien_fichier // on avait bien note le nom du fichier avant la modif
AND $ancien_fichier!==$champs['fichier'] // et il a ete modifie
AND @file_exists($f = get_spip_doc($ancien_fichier)))
spip_unlink($f);
// Changer le statut du document ?
// le statut n'est jamais fixe manuellement mais decoule de celui des objets lies
if(instituer_document($id_document,array('parents'=>_request('parents',$c),'ajout_parents'=>_request('ajout_parents',$c)))) {
//
// Post-modifications
//
// Invalider les caches
include_spip('inc/invalideur');
suivre_invalideur("id='id_document/$id_document'");
}
}
/**
* 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
*/
function instituer_document($id_document,$champs=array()){
$statut=isset($champs['statut'])?$champs['statut']:null;
$date_publication = isset($champs['date_publication'])?$champs['date_publication']:null;
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=$id_document");
$statut_ancien = $row['statut'];
$date_publication_ancienne = $row['date_publication'];
if (is_null($statut)){
$statut = 'prepa';
$trouver_table = charger_fonction('trouver_table','base');
$res = sql_select('id_objet,objet','spip_documents_liens',"objet!='document' AND id_document=".intval($id_document));
// dans 10 ans, ca nous fera un bug a corriger vers 2018
// penser a ouvrir un ticket d'ici la :p
$date_publication=time()+10*365*24*3600;
while($row = sql_fetch($res)){
$table = table_objet_sql($row['objet']);
$desc = $trouver_table($table);
// si pas de champ statut, c'est un objet publie, donc c'est bon
// si c'est une rubrique, c'est bon aussi, car un document publie une rubrique
if (!isset($desc['field']['statut'])
OR $row['objet']=='rubrique'){
$statut = 'publie';
$date_publication=0;
continue;
}
$id_table = id_table_objet($row['objet']);
$row2 = sql_fetsel('statut'.($table=='spip_articles'?",date":""),$table,$id_table.'='.intval($row['id_objet']));
if ($row2['statut']=='publie'){
$statut = 'publie';
// si ce n'est pas un article, c'est donc deja publie, on met la date a 0
if (!$row2['date']){
$date_publication=0;
continue;
}
else {
$date_publication = min($date_publication,strtotime($row2['date']));
}
}
}
$date_publication = date('Y-m-d H:i:s',$date_publication);
if ($statut=='publie' AND $statut_ancien=='publie' AND $date_publication==$date_publication_ancienne)
return false;
if ($statut!='publie' AND $statut_ancien!='publie' AND $statut_ancien!='0')
return false;
}
if ($statut!==$statut_ancien
OR $date_publication!=$date_publication_ancienne){
sql_updateq('spip_documents',array('statut'=>$statut,'date_publication'=>$date_publication),'id_document='.intval($id_document));
return true;
}
return false;
}
/**
* Revision des parents d'un document
* chaque parent est liste au format objet|id_objet
*
* @param unknown_type $id_document
* @param unknown_type $parents
*/
function medias_revision_document_parents($id_document, $parents=null, $ajout=false){
if (!is_array($parents))
return;
$insertions = array();
$cond = array();
// au format objet|id_objet
foreach($parents as $p){
$p = explode('|',$p);
if (preg_match('/^[a-z0-9_]+$/i', $objet=$p[0])){ // securite
$insertions[] = array('id_document'=>$id_document,'objet'=>$p[0],'id_objet'=>$p[1]);
$cond[] = "(id_objet=".intval($p[1])." AND objet=".sql_quote($p[0]).")";
}
}
if (!$ajout){
// suppression des parents obsoletes
$cond_notin = "id_document=".intval($id_document).(count($cond)?" AND NOT(".implode(") AND NOT(",$cond).")":"");
#$cond_in = "id_document=".intval($id_document).(count($cond)?" AND (".implode(" OR (",$cond).")":"");
sql_delete("spip_documents_liens", $cond_notin);
}
foreach($insertions as $ins){
if (!sql_countsel('spip_documents_liens','id_document='.intval($ins['id_document'])." AND id_objet=".intval($ins['id_objet'])." AND objet=".sql_quote($ins['objet'])))
sql_insertq('spip_documents_liens',$ins);
}
}
?>