Fix : correction de tous les appels à count() sur une variable non définie pour compatibilité PHP 8. Passage en SPIP 4.2. TODO : passer les scss de Bootstrap 4.0 (LESS) à SCSSPHP

This commit is contained in:
cy_altern 2024-03-23 11:52:16 +01:00
parent 4431d1da0d
commit 3e7879fc8c
8 changed files with 97 additions and 12 deletions

View file

@ -164,6 +164,7 @@ function formulaires_editer_auteur_verifier_dist(
$oblis[] = 'new_login';
}
// mais il reste obligatoire si on a rien trouve
$erreurs = [];
$erreurs = formulaires_editer_objet_verifier('auteur', $id_auteur, $oblis);
if (isset($erreurs['new_login'])) {
$erreurs['login'] = $erreurs['new_login'];

View file

@ -176,8 +176,7 @@ function formulaires_editer_groupe_traiter_dist($id_article=0, $redirect=''){
);
$ids_auteurs = sql_allfetsel('id_auteur', 'spip_auteurs_liens', $where);
$ids_auteurs = array_column($ids_auteurs, 'id_auteur');
$Tauteurs = _request('Tauteurs');
$Tauteurs = _request('Tauteurs') ?? [];
if (count($Tauteurs)) {
$associer = array_diff($Tauteurs, $ids_auteurs);
$dissocier = array_diff($ids_auteurs, $Tauteurs);
@ -204,7 +203,7 @@ function formulaires_editer_groupe_traiter_dist($id_article=0, $redirect=''){
$ids_mots = sql_allfetsel('M.id_mot AS id_mot', $from, $where);
$ids_mots = array_column($ids_mots, 'id_mot');
$coches = _request('id_groupe_'.$id_groupe);
$coches = _request('id_groupe_'.$id_groupe) ?? [];
if (count($coches)) {
$associer = array_diff($coches, $ids_mots);
$dissocier = array_diff($ids_mots, $coches);

View file

@ -161,6 +161,7 @@ function formulaires_editer_membre_verifier_dist(
$oblis[] = 'new_login';
}
// mais il reste obligatoire si on a rien trouve
$erreurs = [];
$erreurs = formulaires_editer_objet_verifier('auteur', $id_auteur, $oblis);
if (isset($erreurs['new_login'])) {
$erreurs['login'] = $erreurs['new_login'];

View file

@ -60,7 +60,7 @@ function formulaires_editer_post_charger_dist($id_article=0, $redirect=''){
'L.objet="article"',
'L.id_gis=G.id_gis'
);
$res = sql_fetsel('G.lat, G.lon', $from, $where);
$res = sql_fetsel('G.lat, G.lon', $from, $where) ?? [];
if (count($res)) {
$valeurs['lat'] = $res['lat'];
$valeurs['lon'] = $res['lon'];
@ -155,7 +155,7 @@ function formulaires_editer_post_traiter_dist($id_article = 0, $redirect = ''){
);
$ids_auteurs = sql_allfetsel('id_auteur', 'spip_auteurs_liens', $where);
$ids_auteurs = array_column($ids_auteurs, 'id_auteur');
$Tauteurs = _request('Tauteurs');
$Tauteurs = _request('Tauteurs') ?? [];
if (count($Tauteurs)) {
$associer = array_diff($Tauteurs, $ids_auteurs);
$dissocier = array_diff($ids_auteurs, $Tauteurs);
@ -188,8 +188,7 @@ function formulaires_editer_post_traiter_dist($id_article = 0, $redirect = ''){
}
}
$coches = _request('id_emplacements');
$coches = _request('id_emplacements') ?? [];
if (count($coches)){
$associer = array_diff($coches, $T_ids_mots);
$dissocier = array_diff($T_ids_mots, $coches);
@ -265,7 +264,8 @@ function formulaires_editer_post_traiter_dist($id_article = 0, $redirect = ''){
$retour = array();
$retour['message_ok'] = "L'article est bien enregistré.";
if ($new==0){
$redirect .= '&id_article=' . $id_article;
//$redirect .= '&id_article=' . $id_article;
$redirect = parametre_url($redirect, 'id_article', $id_article);
}
$retour['redirect'] = $redirect;

View file

@ -107,8 +107,7 @@ function formulaires_editer_sujet_traiter_dist($id_article = 0, $id_rubrique, $r
);
$ids_auteurs = sql_allfetsel('id_auteur', 'spip_auteurs_liens', $where);
$ids_auteurs = array_column($ids_auteurs, 'id_auteur');
$Tauteurs = _request('Tauteurs');
if (count($Tauteurs)) {
$Tauteurs = _request('Tauteurs') ?? [];
$associer = array_diff($Tauteurs, $ids_auteurs);
$dissocier = array_diff($ids_auteurs, $Tauteurs);

View file

@ -40,7 +40,7 @@ function formulaires_inscription_charger_dist($mode = '', $id = 0, $redirect =''
// Si inscriptions pas autorisees, retourner une chaine d'avertissement
function formulaires_inscription_verifier_dist($mode = '', $id = 0, $redirect ='') {
$erreurs = array();
$erreurs = [];
include_spip('inc/config');
set_request("_upgrade_auteur"); // securite

View file

@ -3,7 +3,7 @@
categorie="squelette"
version="1.0.0"
etat="stable"
compatibilite="[3.1.7;3.3.*]"
compatibilite="[4.0.0;4.2.*]"
logo="img/balint_64.png"
documentation=""
schema="1.0.7"

85
urls/propres.php Normal file
View file

@ -0,0 +1,85 @@
<?php
/**
* Gestion des URLs propres : surcharge (voir @notes pour le pourquoi et le comment)
*/
if (!defined("_ECRIRE_INC_VERSION")) {
return;
}
/**
* Retrouve le fond et les paramètres d'une URL propre
* ou produit l'URL propre d'un objet, en fonction des paramètres passés.
*
* @note
* À défaut de pipeline dont on pourrait se servir, on est obligé de surcharger
* la fonction urls_propres_dist pour gérer correctement les URLS des pages.
* Néammoins, une fois le cas des pages évacué, c'est toujours la fonction dist qui est utilisée.
*
* La fonction dist est prévue pour gérer les URLs des objets.
* Pour un objet donné, elle va chercher l'URL la plus récente dans `spip_urls`.
* Or toutes les URLs des pages seraient identifiées comme se rapportant au même objet, avec type='' et id_objet=0,
* et du coup seraient redirigées vers la même URL : celle la plus récente.
*
* On ne serait pas obligé de surcharger on utilisant type=`page` et id_objet=N pour les URLs des pages,
* mais le contexte retourné serait erroné : `id_page = N` au lieu de `page = X`
*
* Valeurs des paramètres quand il s'agit d'une page :
* $i = URL personnalisée
* $entite = ''
*
* @param integer | string
* URL si on veut retourner son fond et ses paramètres
* Numéro d'un objet si on veut retourner son URL propre
* @param string $entite
* Fond si on veut retourner le fond et les paramètres d'une URL
* Type d'un objet si on veut retourner son URL propre
* @param array | string $args
* @param string $ancre
* @return array
* Fond et paramètres d'une URL propre : [contexte],[type],[url_redirect],[fond]
* ou URL décodée de l'objet donné
*/
function urls_propres_decoder_url($i, $entite, $args = '', $ancre = '') {
include_spip('base/abstract_sql');
// 1) Gestion des pages (voir @note)
if (is_string($i) // c'est une URL et pas un id
and strlen($i)
and strpos($i, '/') === false // ce n'est pas une URL arborescente
and !$entite // ce n'est pas l'URL d'un objet
and $url = strtok($i, '?') // retirer les query strings
and $ligne = sql_fetsel('page, url', 'spip_urls', array('url = ' . sql_quote($url), 'page != \'\''))
) {
$fond = $page = $ligne['page'];
// récupérer le contexte
if (is_array($args)){
$contexte = $args;
} else {
$contexte = array();
}
$contexte['page'] = $page;
$retour = array(
$contexte,
$entite,
'',
$fond,
);
// 2) S'il ne s'agit pas d'une page, appel de la fonction dist
} else {
include_spip(_DIR_PLUGIN_URLS.'urls/propres');
$retour = urls_propres_decoder_url_dist($i, $entite, $args, $ancre);
}
return $retour;
}
/**
* include de tout le fichier urls/propres.php du plugin-dist url_etendues
* pour avoir toutes les fonctions que n'a pas la surcharge du plugin urls_pages
*
**/
include_spip('plugins-dist/urls_etendues/urls/propres');