Completed
Push — master ( 81a660...8ce9c8 )
by cam
01:32
created
ecrire/base/abstract_sql.php 1 patch
Indentation   +693 added lines, -693 removed lines patch added patch discarded remove patch
@@ -25,7 +25,7 @@  discard block
 block discarded – undo
25 25
  */
26 26
 
27 27
 if (!defined('_ECRIRE_INC_VERSION')) {
28
-	return;
28
+    return;
29 29
 }
30 30
 
31 31
 /** Version de l'API SQL */
@@ -45,39 +45,39 @@  discard block
 block discarded – undo
45 45
  *     contexte de l'erreur
46 46
  **/
47 47
 function sql_error_backtrace($compil_info = false) {
48
-	$trace = debug_backtrace();
49
-	$caller = array_shift($trace);
50
-	while (count($trace) and (empty($trace[0]['file']) or $trace[0]['file'] === $caller['file'] or $trace[0]['file'] === __FILE__)) {
51
-		array_shift($trace);
52
-	}
53
-
54
-	if ($compil_info) {
55
-		$contexte_compil = [
56
-			$trace[0]['file'],// sourcefile
57
-			'', //nom
58
-			(isset($trace[1]) ? $trace[1]['function'] . "(){\n" : '')
59
-			. $trace[0]['function'] . '();'
60
-			. (isset($trace[1]) ? "\n}" : ''), //id_boucle
61
-			$trace[0]['line'], // ligne
62
-			$GLOBALS['spip_lang'], // lang
63
-		];
64
-
65
-		return $contexte_compil;
66
-	}
67
-
68
-	$message = count($trace) ? $trace[0]['file'] . ' L' . $trace[0]['line'] : '';
69
-	$f = [];
70
-	while (count($trace) and $t = array_shift($trace)) {
71
-		if (in_array($t['function'], ['include_once', 'include_spip', 'find_in_path'])) {
72
-			break;
73
-		}
74
-		$f[] = $t['function'];
75
-	}
76
-	if (count($f)) {
77
-		$message .= ' [' . implode('(),', $f) . '()]';
78
-	}
79
-
80
-	return $message;
48
+    $trace = debug_backtrace();
49
+    $caller = array_shift($trace);
50
+    while (count($trace) and (empty($trace[0]['file']) or $trace[0]['file'] === $caller['file'] or $trace[0]['file'] === __FILE__)) {
51
+        array_shift($trace);
52
+    }
53
+
54
+    if ($compil_info) {
55
+        $contexte_compil = [
56
+            $trace[0]['file'],// sourcefile
57
+            '', //nom
58
+            (isset($trace[1]) ? $trace[1]['function'] . "(){\n" : '')
59
+            . $trace[0]['function'] . '();'
60
+            . (isset($trace[1]) ? "\n}" : ''), //id_boucle
61
+            $trace[0]['line'], // ligne
62
+            $GLOBALS['spip_lang'], // lang
63
+        ];
64
+
65
+        return $contexte_compil;
66
+    }
67
+
68
+    $message = count($trace) ? $trace[0]['file'] . ' L' . $trace[0]['line'] : '';
69
+    $f = [];
70
+    while (count($trace) and $t = array_shift($trace)) {
71
+        if (in_array($t['function'], ['include_once', 'include_spip', 'find_in_path'])) {
72
+            break;
73
+        }
74
+        $f[] = $t['function'];
75
+    }
76
+    if (count($f)) {
77
+        $message .= ' [' . implode('(),', $f) . '()]';
78
+    }
79
+
80
+    return $message;
81 81
 }
82 82
 
83 83
 
@@ -102,16 +102,16 @@  discard block
 block discarded – undo
102 102
  *
103 103
  **/
104 104
 function sql_serveur($ins_sql = '', $serveur = '', $continue = false) {
105
-	static $sql_serveur = [];
106
-	if (!isset($sql_serveur[$serveur][$ins_sql])) {
107
-		$f = spip_connect_sql(\SQL_ABSTRACT_VERSION, $ins_sql, $serveur, $continue);
108
-		if (!is_string($f) or !$f) {
109
-			return $f;
110
-		}
111
-		$sql_serveur[$serveur][$ins_sql] = $f;
112
-	}
113
-
114
-	return $sql_serveur[$serveur][$ins_sql];
105
+    static $sql_serveur = [];
106
+    if (!isset($sql_serveur[$serveur][$ins_sql])) {
107
+        $f = spip_connect_sql(\SQL_ABSTRACT_VERSION, $ins_sql, $serveur, $continue);
108
+        if (!is_string($f) or !$f) {
109
+            return $f;
110
+        }
111
+        $sql_serveur[$serveur][$ins_sql] = $f;
112
+    }
113
+
114
+    return $sql_serveur[$serveur][$ins_sql];
115 115
 }
116 116
 
117 117
 /**
@@ -133,23 +133,23 @@  discard block
 block discarded – undo
133 133
  *     Retourne le nom du charset si effectivement trouvé, sinon false.
134 134
  **/
135 135
 function sql_get_charset($charset, $serveur = '', $option = true) {
136
-	// le nom http du charset differe parfois du nom SQL utf-8 ==> utf8 etc.
137
-	$desc = sql_serveur('', $serveur, true);
138
-	$desc = $desc[\SQL_ABSTRACT_VERSION];
139
-	$c = $desc['charsets'][$charset];
140
-	if ($c) {
141
-		if (function_exists($f = @$desc['get_charset'])) {
142
-			if ($f($c, $serveur, $option !== false)) {
143
-				return $c;
144
-			}
145
-		}
146
-	}
147
-	spip_log(
148
-		"SPIP ne connait pas les Charsets disponibles sur le serveur $serveur. Le serveur choisira seul.",
149
-		_LOG_AVERTISSEMENT
150
-	);
151
-
152
-	return false;
136
+    // le nom http du charset differe parfois du nom SQL utf-8 ==> utf8 etc.
137
+    $desc = sql_serveur('', $serveur, true);
138
+    $desc = $desc[\SQL_ABSTRACT_VERSION];
139
+    $c = $desc['charsets'][$charset];
140
+    if ($c) {
141
+        if (function_exists($f = @$desc['get_charset'])) {
142
+            if ($f($c, $serveur, $option !== false)) {
143
+                return $c;
144
+            }
145
+        }
146
+    }
147
+    spip_log(
148
+        "SPIP ne connait pas les Charsets disponibles sur le serveur $serveur. Le serveur choisira seul.",
149
+        _LOG_AVERTISSEMENT
150
+    );
151
+
152
+    return false;
153 153
 }
154 154
 
155 155
 
@@ -175,12 +175,12 @@  discard block
 block discarded – undo
175 175
  *    Retourne true si elle reussie.
176 176
  **/
177 177
 function sql_set_charset($charset, $serveur = '', $option = true) {
178
-	$f = sql_serveur('set_charset', $serveur, $option === 'continue' or $option === false);
179
-	if (!is_string($f) or !$f) {
180
-		return false;
181
-	}
178
+    $f = sql_serveur('set_charset', $serveur, $option === 'continue' or $option === false);
179
+    if (!is_string($f) or !$f) {
180
+        return false;
181
+    }
182 182
 
183
-	return $f($charset, $serveur, $option !== false);
183
+    return $f($charset, $serveur, $option !== false);
184 184
 }
185 185
 
186 186
 
@@ -231,59 +231,59 @@  discard block
 block discarded – undo
231 231
  *
232 232
  **/
233 233
 function sql_select(
234
-	$select = [],
235
-	$from = [],
236
-	$where = [],
237
-	$groupby = [],
238
-	$orderby = [],
239
-	$limit = '',
240
-	$having = [],
241
-	$serveur = '',
242
-	$option = true
234
+    $select = [],
235
+    $from = [],
236
+    $where = [],
237
+    $groupby = [],
238
+    $orderby = [],
239
+    $limit = '',
240
+    $having = [],
241
+    $serveur = '',
242
+    $option = true
243 243
 ) {
244
-	$f = sql_serveur('select', $serveur, $option === 'continue' or $option === false);
245
-	if (!is_string($f) or !$f) {
246
-		return false;
247
-	}
248
-
249
-	$debug = (defined('_VAR_MODE') and _VAR_MODE == 'debug');
250
-	if (($option !== false) and !$debug) {
251
-		$res = $f(
252
-			$select,
253
-			$from,
254
-			$where,
255
-			$groupby,
256
-			$orderby,
257
-			$limit,
258
-			$having,
259
-			$serveur,
260
-			is_array($option) ? true : $option
261
-		);
262
-	} else {
263
-		$query = $f($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, false);
264
-		if (!$option) {
265
-			return $query;
266
-		}
267
-		// le debug, c'est pour ce qui a ete produit par le compilateur
268
-		if (isset($GLOBALS['debug']['aucasou'])) {
269
-			[$table, $id, ] = $GLOBALS['debug']['aucasou'];
270
-			$nom = $GLOBALS['debug_objets']['courant'] . $id;
271
-			$GLOBALS['debug_objets']['requete'][$nom] = $query;
272
-		}
273
-		$res = $f($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, true);
274
-	}
275
-
276
-	// en cas d'erreur
277
-	if (!is_string($res)) {
278
-		return $res;
279
-	}
280
-	// denoncer l'erreur SQL dans sa version brute
281
-	spip_sql_erreur($serveur);
282
-	// idem dans sa version squelette (prefixe des tables non substitue)
283
-	$contexte_compil = sql_error_backtrace(true);
284
-	erreur_squelette([sql_errno($serveur), sql_error($serveur), $res], $contexte_compil);
285
-
286
-	return false;
244
+    $f = sql_serveur('select', $serveur, $option === 'continue' or $option === false);
245
+    if (!is_string($f) or !$f) {
246
+        return false;
247
+    }
248
+
249
+    $debug = (defined('_VAR_MODE') and _VAR_MODE == 'debug');
250
+    if (($option !== false) and !$debug) {
251
+        $res = $f(
252
+            $select,
253
+            $from,
254
+            $where,
255
+            $groupby,
256
+            $orderby,
257
+            $limit,
258
+            $having,
259
+            $serveur,
260
+            is_array($option) ? true : $option
261
+        );
262
+    } else {
263
+        $query = $f($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, false);
264
+        if (!$option) {
265
+            return $query;
266
+        }
267
+        // le debug, c'est pour ce qui a ete produit par le compilateur
268
+        if (isset($GLOBALS['debug']['aucasou'])) {
269
+            [$table, $id, ] = $GLOBALS['debug']['aucasou'];
270
+            $nom = $GLOBALS['debug_objets']['courant'] . $id;
271
+            $GLOBALS['debug_objets']['requete'][$nom] = $query;
272
+        }
273
+        $res = $f($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, true);
274
+    }
275
+
276
+    // en cas d'erreur
277
+    if (!is_string($res)) {
278
+        return $res;
279
+    }
280
+    // denoncer l'erreur SQL dans sa version brute
281
+    spip_sql_erreur($serveur);
282
+    // idem dans sa version squelette (prefixe des tables non substitue)
283
+    $contexte_compil = sql_error_backtrace(true);
284
+    erreur_squelette([sql_errno($serveur), sql_error($serveur), $res], $contexte_compil);
285
+
286
+    return false;
287 287
 }
288 288
 
289 289
 
@@ -320,16 +320,16 @@  discard block
 block discarded – undo
320 320
  *
321 321
  **/
322 322
 function sql_get_select(
323
-	$select = [],
324
-	$from = [],
325
-	$where = [],
326
-	$groupby = [],
327
-	$orderby = [],
328
-	$limit = '',
329
-	$having = [],
330
-	$serveur = ''
323
+    $select = [],
324
+    $from = [],
325
+    $where = [],
326
+    $groupby = [],
327
+    $orderby = [],
328
+    $limit = '',
329
+    $having = [],
330
+    $serveur = ''
331 331
 ) {
332
-	return sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, false);
332
+    return sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, false);
333 333
 }
334 334
 
335 335
 
@@ -373,23 +373,23 @@  discard block
 block discarded – undo
373 373
  *
374 374
  **/
375 375
 function sql_countsel(
376
-	$from = [],
377
-	$where = [],
378
-	$groupby = [],
379
-	$having = [],
380
-	$serveur = '',
381
-	$option = true
376
+    $from = [],
377
+    $where = [],
378
+    $groupby = [],
379
+    $having = [],
380
+    $serveur = '',
381
+    $option = true
382 382
 ) {
383
-	$f = sql_serveur('countsel', $serveur, $option === 'continue' or $option === false);
384
-	if (!is_string($f) or !$f) {
385
-		return false;
386
-	}
387
-	$r = $f($from, $where, $groupby, $having, $serveur, $option !== false);
388
-	if ($r === false) {
389
-		spip_sql_erreur($serveur);
390
-	}
391
-
392
-	return $r;
383
+    $f = sql_serveur('countsel', $serveur, $option === 'continue' or $option === false);
384
+    if (!is_string($f) or !$f) {
385
+        return false;
386
+    }
387
+    $r = $f($from, $where, $groupby, $having, $serveur, $option !== false);
388
+    if ($r === false) {
389
+        spip_sql_erreur($serveur);
390
+    }
391
+
392
+    return $r;
393 393
 }
394 394
 
395 395
 /**
@@ -421,16 +421,16 @@  discard block
 block discarded – undo
421 421
  *     Ce retour n'est pas pertinent pour savoir si l'opération est correctement réalisée.
422 422
  **/
423 423
 function sql_alter($q, $serveur = '', $option = true) {
424
-	$f = sql_serveur('alter', $serveur, $option === 'continue' or $option === false);
425
-	if (!is_string($f) or !$f) {
426
-		return false;
427
-	}
428
-	$r = $f($q, $serveur, $option !== false);
429
-	if ($r === false) {
430
-		spip_sql_erreur($serveur);
431
-	}
432
-
433
-	return $r;
424
+    $f = sql_serveur('alter', $serveur, $option === 'continue' or $option === false);
425
+    if (!is_string($f) or !$f) {
426
+        return false;
427
+    }
428
+    $r = $f($q, $serveur, $option !== false);
429
+    if ($r === false) {
430
+        spip_sql_erreur($serveur);
431
+    }
432
+
433
+    return $r;
434 434
 }
435 435
 
436 436
 /**
@@ -453,12 +453,12 @@  discard block
 block discarded – undo
453 453
  *    presentant une ligne de resultat d'une selection
454 454
  */
455 455
 function sql_fetch($res, $serveur = '', $option = true) {
456
-	$f = sql_serveur('fetch', $serveur, $option === 'continue' or $option === false);
457
-	if (!is_string($f) or !$f) {
458
-		return false;
459
-	}
456
+    $f = sql_serveur('fetch', $serveur, $option === 'continue' or $option === false);
457
+    if (!is_string($f) or !$f) {
458
+        return false;
459
+    }
460 460
 
461
-	return $f($res, null, $serveur, $option !== false);
461
+    return $f($res, null, $serveur, $option !== false);
462 462
 }
463 463
 
464 464
 
@@ -485,20 +485,20 @@  discard block
 block discarded – undo
485 485
  *    presentant une ligne de resultat d'une selection
486 486
  */
487 487
 function sql_fetch_all($res, $serveur = '', $option = true) {
488
-	$rows = [];
489
-	if (!$res) {
490
-		return $rows;
491
-	}
492
-	$f = sql_serveur('fetch', $serveur, $option === 'continue' or $option === false);
493
-	if (!is_string($f) or !$f) {
494
-		return [];
495
-	}
496
-	while ($r = $f($res, null, $serveur, $option !== false)) {
497
-		$rows[] = $r;
498
-	}
499
-	sql_free($res, $serveur);
500
-
501
-	return $rows;
488
+    $rows = [];
489
+    if (!$res) {
490
+        return $rows;
491
+    }
492
+    $f = sql_serveur('fetch', $serveur, $option === 'continue' or $option === false);
493
+    if (!is_string($f) or !$f) {
494
+        return [];
495
+    }
496
+    while ($r = $f($res, null, $serveur, $option !== false)) {
497
+        $rows[] = $r;
498
+    }
499
+    sql_free($res, $serveur);
500
+
501
+    return $rows;
502 502
 }
503 503
 
504 504
 /**
@@ -526,16 +526,16 @@  discard block
 block discarded – undo
526 526
  *    Operation effectuée (true), sinon false.
527 527
  **/
528 528
 function sql_seek($res, $row_number, $serveur = '', $option = true) {
529
-	$f = sql_serveur('seek', $serveur, $option === 'continue' or $option === false);
530
-	if (!is_string($f) or !$f) {
531
-		return false;
532
-	}
533
-	$r = $f($res, $row_number, $serveur, $option !== false);
534
-	if ($r === false) {
535
-		spip_sql_erreur($serveur);
536
-	}
537
-
538
-	return $r;
529
+    $f = sql_serveur('seek', $serveur, $option === 'continue' or $option === false);
530
+    if (!is_string($f) or !$f) {
531
+        return false;
532
+    }
533
+    $r = $f($res, $row_number, $serveur, $option !== false);
534
+    if ($r === false) {
535
+        spip_sql_erreur($serveur);
536
+    }
537
+
538
+    return $r;
539 539
 }
540 540
 
541 541
 
@@ -560,16 +560,16 @@  discard block
 block discarded – undo
560 560
  *    False en cas d'erreur.
561 561
  **/
562 562
 function sql_listdbs($serveur = '', $option = true) {
563
-	$f = sql_serveur('listdbs', $serveur, $option === 'continue' or $option === false);
564
-	if (!is_string($f) or !$f) {
565
-		return false;
566
-	}
567
-	$r = $f($serveur);
568
-	if ($r === false) {
569
-		spip_sql_erreur($serveur);
570
-	}
571
-
572
-	return $r;
563
+    $f = sql_serveur('listdbs', $serveur, $option === 'continue' or $option === false);
564
+    if (!is_string($f) or !$f) {
565
+        return false;
566
+    }
567
+    $r = $f($serveur);
568
+    if ($r === false) {
569
+        spip_sql_erreur($serveur);
570
+    }
571
+
572
+    return $r;
573 573
 }
574 574
 
575 575
 
@@ -592,16 +592,16 @@  discard block
 block discarded – undo
592 592
  *     - False en cas d'erreur.
593 593
  **/
594 594
 function sql_selectdb($nom, $serveur = '', $option = true) {
595
-	$f = sql_serveur('selectdb', $serveur, $option === 'continue' or $option === false);
596
-	if (!is_string($f) or !$f) {
597
-		return false;
598
-	}
599
-	$r = $f($nom, $serveur, $option !== false);
600
-	if ($r === false) {
601
-		spip_sql_erreur($serveur);
602
-	}
603
-
604
-	return $r;
595
+    $f = sql_serveur('selectdb', $serveur, $option === 'continue' or $option === false);
596
+    if (!is_string($f) or !$f) {
597
+        return false;
598
+    }
599
+    $r = $f($nom, $serveur, $option !== false);
600
+    if ($r === false) {
601
+        spip_sql_erreur($serveur);
602
+    }
603
+
604
+    return $r;
605 605
 }
606 606
 
607 607
 /**
@@ -626,16 +626,16 @@  discard block
 block discarded – undo
626 626
  *     - false en cas d'erreur.
627 627
  **/
628 628
 function sql_count($res, $serveur = '', $option = true) {
629
-	$f = sql_serveur('count', $serveur, $option === 'continue' or $option === false);
630
-	if (!is_string($f) or !$f) {
631
-		return false;
632
-	}
633
-	$r = $f($res, $serveur, $option !== false);
634
-	if ($r === false) {
635
-		spip_sql_erreur($serveur);
636
-	}
637
-
638
-	return $r;
629
+    $f = sql_serveur('count', $serveur, $option === 'continue' or $option === false);
630
+    if (!is_string($f) or !$f) {
631
+        return false;
632
+    }
633
+    $r = $f($res, $serveur, $option !== false);
634
+    if ($r === false) {
635
+        spip_sql_erreur($serveur);
636
+    }
637
+
638
+    return $r;
639 639
 }
640 640
 
641 641
 /**
@@ -657,12 +657,12 @@  discard block
 block discarded – undo
657 657
  *     True si réussi
658 658
  */
659 659
 function sql_free($res, $serveur = '', $option = true) {
660
-	$f = sql_serveur('free', $serveur, $option === 'continue' or $option === false);
661
-	if (!is_string($f) or !$f) {
662
-		return false;
663
-	}
660
+    $f = sql_serveur('free', $serveur, $option === 'continue' or $option === false);
661
+    if (!is_string($f) or !$f) {
662
+        return false;
663
+    }
664 664
 
665
-	return $f($res);
665
+    return $f($res);
666 666
 }
667 667
 
668 668
 
@@ -700,17 +700,17 @@  discard block
 block discarded – undo
700 700
  *     - False en cas d'erreur.
701 701
  **/
702 702
 function sql_insert($table, $noms, $valeurs, $desc = [], $serveur = '', $option = true) {
703
-	$f = sql_serveur('insert', $serveur, $option === 'continue' or $option === false);
704
-	if (!is_string($f) or !$f) {
705
-		return false;
706
-	}
707
-	$r = $f($table, $noms, $valeurs, $desc, $serveur, $option !== false);
708
-	if ($r === false or $r === null) {
709
-		spip_sql_erreur($serveur);
710
-		$r = false;
711
-	}
712
-
713
-	return $r;
703
+    $f = sql_serveur('insert', $serveur, $option === 'continue' or $option === false);
704
+    if (!is_string($f) or !$f) {
705
+        return false;
706
+    }
707
+    $r = $f($table, $noms, $valeurs, $desc, $serveur, $option !== false);
708
+    if ($r === false or $r === null) {
709
+        spip_sql_erreur($serveur);
710
+        $r = false;
711
+    }
712
+
713
+    return $r;
714 714
 }
715 715
 
716 716
 /**
@@ -751,17 +751,17 @@  discard block
 block discarded – undo
751 751
  *     - False en cas d'erreur.
752 752
  **/
753 753
 function sql_insertq($table, $couples = [], $desc = [], $serveur = '', $option = true) {
754
-	$f = sql_serveur('insertq', $serveur, $option === 'continue' or $option === false);
755
-	if (!is_string($f) or !$f) {
756
-		return false;
757
-	}
758
-	$r = $f($table, $couples, $desc, $serveur, $option !== false);
759
-	if ($r === false or $r === null) {
760
-		spip_sql_erreur($serveur);
761
-		$r = false;
762
-	}
763
-
764
-	return $r;
754
+    $f = sql_serveur('insertq', $serveur, $option === 'continue' or $option === false);
755
+    if (!is_string($f) or !$f) {
756
+        return false;
757
+    }
758
+    $r = $f($table, $couples, $desc, $serveur, $option !== false);
759
+    if ($r === false or $r === null) {
760
+        spip_sql_erreur($serveur);
761
+        $r = false;
762
+    }
763
+
764
+    return $r;
765 765
 }
766 766
 
767 767
 /**
@@ -796,17 +796,17 @@  discard block
 block discarded – undo
796 796
  *     - false en cas d'erreur.
797 797
  **/
798 798
 function sql_insertq_multi($table, $couples = [], $desc = [], $serveur = '', $option = true) {
799
-	$f = sql_serveur('insertq_multi', $serveur, $option === 'continue' or $option === false);
800
-	if (!is_string($f) or !$f) {
801
-		return false;
802
-	}
803
-	$r = $f($table, $couples, $desc, $serveur, $option !== false);
804
-	if ($r === false or $r === null) {
805
-		spip_sql_erreur($serveur);
806
-		$r = false;
807
-	}
808
-
809
-	return $r;
799
+    $f = sql_serveur('insertq_multi', $serveur, $option === 'continue' or $option === false);
800
+    if (!is_string($f) or !$f) {
801
+        return false;
802
+    }
803
+    $r = $f($table, $couples, $desc, $serveur, $option !== false);
804
+    if ($r === false or $r === null) {
805
+        spip_sql_erreur($serveur);
806
+        $r = false;
807
+    }
808
+
809
+    return $r;
810 810
 }
811 811
 
812 812
 /**
@@ -846,16 +846,16 @@  discard block
 block discarded – undo
846 846
  *     - array Tableau décrivant la requête et son temps d'exécution si var_profile est actif
847 847
  */
848 848
 function sql_update($table, $exp, $where = '', $desc = [], $serveur = '', $option = true) {
849
-	$f = sql_serveur('update', $serveur, $option === 'continue' or $option === false);
850
-	if (!is_string($f) or !$f) {
851
-		return false;
852
-	}
853
-	$r = $f($table, $exp, $where, $desc, $serveur, $option !== false);
854
-	if ($r === false) {
855
-		spip_sql_erreur($serveur);
856
-	}
857
-
858
-	return $r;
849
+    $f = sql_serveur('update', $serveur, $option === 'continue' or $option === false);
850
+    if (!is_string($f) or !$f) {
851
+        return false;
852
+    }
853
+    $r = $f($table, $exp, $where, $desc, $serveur, $option !== false);
854
+    if ($r === false) {
855
+        spip_sql_erreur($serveur);
856
+    }
857
+
858
+    return $r;
859 859
 }
860 860
 
861 861
 
@@ -901,16 +901,16 @@  discard block
 block discarded – undo
901 901
  *     - false en cas d'erreur.
902 902
  **/
903 903
 function sql_updateq($table, $exp, $where = '', $desc = [], $serveur = '', $option = true) {
904
-	$f = sql_serveur('updateq', $serveur, $option === 'continue' or $option === false);
905
-	if (!is_string($f) or !$f) {
906
-		return false;
907
-	}
908
-	$r = $f($table, $exp, $where, $desc, $serveur, $option !== false);
909
-	if ($r === false) {
910
-		spip_sql_erreur($serveur);
911
-	}
912
-
913
-	return $r;
904
+    $f = sql_serveur('updateq', $serveur, $option === 'continue' or $option === false);
905
+    if (!is_string($f) or !$f) {
906
+        return false;
907
+    }
908
+    $r = $f($table, $exp, $where, $desc, $serveur, $option !== false);
909
+    if ($r === false) {
910
+        spip_sql_erreur($serveur);
911
+    }
912
+
913
+    return $r;
914 914
 }
915 915
 
916 916
 /**
@@ -941,16 +941,16 @@  discard block
 block discarded – undo
941 941
  *     - false en cas d'erreur.
942 942
  **/
943 943
 function sql_delete($table, $where = '', $serveur = '', $option = true) {
944
-	$f = sql_serveur('delete', $serveur, $option === 'continue' or $option === false);
945
-	if (!is_string($f) or !$f) {
946
-		return false;
947
-	}
948
-	$r = $f($table, $where, $serveur, $option !== false);
949
-	if ($r === false) {
950
-		spip_sql_erreur($serveur);
951
-	}
952
-
953
-	return $r;
944
+    $f = sql_serveur('delete', $serveur, $option === 'continue' or $option === false);
945
+    if (!is_string($f) or !$f) {
946
+        return false;
947
+    }
948
+    $r = $f($table, $where, $serveur, $option !== false);
949
+    if ($r === false) {
950
+        spip_sql_erreur($serveur);
951
+    }
952
+
953
+    return $r;
954 954
 }
955 955
 
956 956
 /**
@@ -986,16 +986,16 @@  discard block
 block discarded – undo
986 986
  *     - false en cas d'erreur.
987 987
  **/
988 988
 function sql_replace($table, $couples, $desc = [], $serveur = '', $option = true) {
989
-	$f = sql_serveur('replace', $serveur, $option === 'continue' or $option === false);
990
-	if (!is_string($f) or !$f) {
991
-		return false;
992
-	}
993
-	$r = $f($table, $couples, $desc, $serveur, $option !== false);
994
-	if ($r === false) {
995
-		spip_sql_erreur($serveur);
996
-	}
997
-
998
-	return $r;
989
+    $f = sql_serveur('replace', $serveur, $option === 'continue' or $option === false);
990
+    if (!is_string($f) or !$f) {
991
+        return false;
992
+    }
993
+    $r = $f($table, $couples, $desc, $serveur, $option !== false);
994
+    if ($r === false) {
995
+        spip_sql_erreur($serveur);
996
+    }
997
+
998
+    return $r;
999 999
 }
1000 1000
 
1001 1001
 
@@ -1033,16 +1033,16 @@  discard block
 block discarded – undo
1033 1033
  *     - false en cas d'erreur.
1034 1034
  **/
1035 1035
 function sql_replace_multi($table, $tab_couples, $desc = [], $serveur = '', $option = true) {
1036
-	$f = sql_serveur('replace_multi', $serveur, $option === 'continue' or $option === false);
1037
-	if (!is_string($f) or !$f) {
1038
-		return false;
1039
-	}
1040
-	$r = $f($table, $tab_couples, $desc, $serveur, $option !== false);
1041
-	if ($r === false) {
1042
-		spip_sql_erreur($serveur);
1043
-	}
1044
-
1045
-	return $r;
1036
+    $f = sql_serveur('replace_multi', $serveur, $option === 'continue' or $option === false);
1037
+    if (!is_string($f) or !$f) {
1038
+        return false;
1039
+    }
1040
+    $r = $f($table, $tab_couples, $desc, $serveur, $option !== false);
1041
+    if ($r === false) {
1042
+        spip_sql_erreur($serveur);
1043
+    }
1044
+
1045
+    return $r;
1046 1046
 }
1047 1047
 
1048 1048
 /**
@@ -1070,16 +1070,16 @@  discard block
 block discarded – undo
1070 1070
  *     - false en cas d'erreur.
1071 1071
  **/
1072 1072
 function sql_drop_table($table, $exist = '', $serveur = '', $option = true) {
1073
-	$f = sql_serveur('drop_table', $serveur, $option === 'continue' or $option === false);
1074
-	if (!is_string($f) or !$f) {
1075
-		return false;
1076
-	}
1077
-	$r = $f($table, $exist, $serveur, $option !== false);
1078
-	if ($r === false) {
1079
-		spip_sql_erreur($serveur);
1080
-	}
1081
-
1082
-	return $r;
1073
+    $f = sql_serveur('drop_table', $serveur, $option === 'continue' or $option === false);
1074
+    if (!is_string($f) or !$f) {
1075
+        return false;
1076
+    }
1077
+    $r = $f($table, $exist, $serveur, $option !== false);
1078
+    if ($r === false) {
1079
+        spip_sql_erreur($serveur);
1080
+    }
1081
+
1082
+    return $r;
1083 1083
 }
1084 1084
 
1085 1085
 /**
@@ -1103,16 +1103,16 @@  discard block
 block discarded – undo
1103 1103
  *     - true si la requête a réussie, false sinon
1104 1104
  */
1105 1105
 function sql_drop_view($table, $exist = '', $serveur = '', $option = true) {
1106
-	$f = sql_serveur('drop_view', $serveur, $option === 'continue' or $option === false);
1107
-	if (!is_string($f) or !$f) {
1108
-		return false;
1109
-	}
1110
-	$r = $f($table, $exist, $serveur, $option !== false);
1111
-	if ($r === false) {
1112
-		spip_sql_erreur($serveur);
1113
-	}
1114
-
1115
-	return $r;
1106
+    $f = sql_serveur('drop_view', $serveur, $option === 'continue' or $option === false);
1107
+    if (!is_string($f) or !$f) {
1108
+        return false;
1109
+    }
1110
+    $r = $f($table, $exist, $serveur, $option !== false);
1111
+    if ($r === false) {
1112
+        spip_sql_erreur($serveur);
1113
+    }
1114
+
1115
+    return $r;
1116 1116
 }
1117 1117
 
1118 1118
 /**
@@ -1136,18 +1136,18 @@  discard block
 block discarded – undo
1136 1136
  *     Ressource à utiliser avec sql_fetch()
1137 1137
  **/
1138 1138
 function sql_showbase($spip = null, $serveur = '', $option = true) {
1139
-	$f = sql_serveur('showbase', $serveur, $option === 'continue' or $option === false);
1140
-	if (!is_string($f) or !$f) {
1141
-		return false;
1142
-	}
1143
-
1144
-	// la globale n'est remplie qu'apres l'appel de sql_serveur.
1145
-	if ($spip == null) {
1146
-		$connexion = $GLOBALS['connexions'][$serveur ? strtolower($serveur) : 0];
1147
-		$spip = $connexion['prefixe'] . '\_%';
1148
-	}
1149
-
1150
-	return $f($spip, $serveur, $option !== false);
1139
+    $f = sql_serveur('showbase', $serveur, $option === 'continue' or $option === false);
1140
+    if (!is_string($f) or !$f) {
1141
+        return false;
1142
+    }
1143
+
1144
+    // la globale n'est remplie qu'apres l'appel de sql_serveur.
1145
+    if ($spip == null) {
1146
+        $connexion = $GLOBALS['connexions'][$serveur ? strtolower($serveur) : 0];
1147
+        $spip = $connexion['prefixe'] . '\_%';
1148
+    }
1149
+
1150
+    return $f($spip, $serveur, $option !== false);
1151 1151
 }
1152 1152
 
1153 1153
 /**
@@ -1170,15 +1170,15 @@  discard block
 block discarded – undo
1170 1170
  *     Liste des tables SQL
1171 1171
  **/
1172 1172
 function sql_alltable($spip = null, $serveur = '', $option = true) {
1173
-	$q = sql_showbase($spip, $serveur, $option);
1174
-	$r = [];
1175
-	if ($q) {
1176
-		while ($t = sql_fetch($q, $serveur)) {
1177
-			$r[] = array_shift($t);
1178
-		}
1179
-	}
1180
-
1181
-	return $r;
1173
+    $q = sql_showbase($spip, $serveur, $option);
1174
+    $r = [];
1175
+    if ($q) {
1176
+        while ($t = sql_fetch($q, $serveur)) {
1177
+            $r[] = array_shift($t);
1178
+        }
1179
+    }
1180
+
1181
+    return $r;
1182 1182
 }
1183 1183
 
1184 1184
 /**
@@ -1211,31 +1211,31 @@  discard block
 block discarded – undo
1211 1211
  *       - 'join' => array() // jointures, si déclarées.
1212 1212
  **/
1213 1213
 function sql_showtable($table, $table_spip = false, $serveur = '', $option = true) {
1214
-	$f = sql_serveur('showtable', $serveur, $option === 'continue' or $option === false);
1215
-	if (!is_string($f) or !$f) {
1216
-		return false;
1217
-	}
1218
-
1219
-	// la globale n'est remplie qu'apres l'appel de sql_serveur.
1220
-	if ($table_spip) {
1221
-		$connexion = $GLOBALS['connexions'][$serveur ? strtolower($serveur) : 0];
1222
-		$prefixe = $connexion['prefixe'];
1223
-		$vraie_table = prefixer_table_spip($table, $prefixe);
1224
-	} else {
1225
-		$vraie_table = $table;
1226
-	}
1227
-
1228
-	$f = $f($vraie_table, $serveur, $option !== false);
1229
-	if (!$f) {
1230
-		return [];
1231
-	}
1232
-	if (isset($GLOBALS['tables_principales'][$table]['join'])) {
1233
-		$f['join'] = $GLOBALS['tables_principales'][$table]['join'];
1234
-	} elseif (isset($GLOBALS['tables_auxiliaires'][$table]['join'])) {
1235
-		$f['join'] = $GLOBALS['tables_auxiliaires'][$table]['join'];
1236
-	}
1237
-
1238
-	return $f;
1214
+    $f = sql_serveur('showtable', $serveur, $option === 'continue' or $option === false);
1215
+    if (!is_string($f) or !$f) {
1216
+        return false;
1217
+    }
1218
+
1219
+    // la globale n'est remplie qu'apres l'appel de sql_serveur.
1220
+    if ($table_spip) {
1221
+        $connexion = $GLOBALS['connexions'][$serveur ? strtolower($serveur) : 0];
1222
+        $prefixe = $connexion['prefixe'];
1223
+        $vraie_table = prefixer_table_spip($table, $prefixe);
1224
+    } else {
1225
+        $vraie_table = $table;
1226
+    }
1227
+
1228
+    $f = $f($vraie_table, $serveur, $option !== false);
1229
+    if (!$f) {
1230
+        return [];
1231
+    }
1232
+    if (isset($GLOBALS['tables_principales'][$table]['join'])) {
1233
+        $f['join'] = $GLOBALS['tables_principales'][$table]['join'];
1234
+    } elseif (isset($GLOBALS['tables_auxiliaires'][$table]['join'])) {
1235
+        $f['join'] = $GLOBALS['tables_auxiliaires'][$table]['join'];
1236
+    }
1237
+
1238
+    return $f;
1239 1239
 }
1240 1240
 
1241 1241
 
@@ -1262,21 +1262,21 @@  discard block
 block discarded – undo
1262 1262
  *     - false en cas d'erreur.
1263 1263
  **/
1264 1264
 function sql_table_exists(string $table, bool $table_spip = true, $serveur = '', $option = true) {
1265
-	$f = sql_serveur('table_exists', $serveur, $option === 'continue' or $option === false);
1266
-	if (!is_string($f) or !$f) {
1267
-		return false;
1268
-	}
1269
-
1270
-	// la globale n'est remplie qu'apres l'appel de sql_serveur.
1271
-	if ($table_spip) {
1272
-		$connexion = $GLOBALS['connexions'][$serveur ? strtolower($serveur) : 0];
1273
-		$prefixe = $connexion['prefixe'];
1274
-		$vraie_table = prefixer_table_spip($table, $prefixe);
1275
-	} else {
1276
-		$vraie_table = $table;
1277
-	}
1278
-
1279
-	return $f($vraie_table, $serveur, $option !== false);
1265
+    $f = sql_serveur('table_exists', $serveur, $option === 'continue' or $option === false);
1266
+    if (!is_string($f) or !$f) {
1267
+        return false;
1268
+    }
1269
+
1270
+    // la globale n'est remplie qu'apres l'appel de sql_serveur.
1271
+    if ($table_spip) {
1272
+        $connexion = $GLOBALS['connexions'][$serveur ? strtolower($serveur) : 0];
1273
+        $prefixe = $connexion['prefixe'];
1274
+        $vraie_table = prefixer_table_spip($table, $prefixe);
1275
+    } else {
1276
+        $vraie_table = $table;
1277
+    }
1278
+
1279
+    return $f($vraie_table, $serveur, $option !== false);
1280 1280
 }
1281 1281
 
1282 1282
 
@@ -1322,24 +1322,24 @@  discard block
 block discarded – undo
1322 1322
  *     true si succès, false en cas d'echec
1323 1323
  **/
1324 1324
 function sql_create(
1325
-	$nom,
1326
-	$champs,
1327
-	$cles = [],
1328
-	$autoinc = false,
1329
-	$temporary = false,
1330
-	$serveur = '',
1331
-	$option = true
1325
+    $nom,
1326
+    $champs,
1327
+    $cles = [],
1328
+    $autoinc = false,
1329
+    $temporary = false,
1330
+    $serveur = '',
1331
+    $option = true
1332 1332
 ) {
1333
-	$f = sql_serveur('create', $serveur, $option === 'continue' or $option === false);
1334
-	if (!is_string($f) or !$f) {
1335
-		return false;
1336
-	}
1337
-	$r = $f($nom, $champs, $cles, $autoinc, $temporary, $serveur, $option !== false);
1338
-	if ($r === false) {
1339
-		spip_sql_erreur($serveur);
1340
-	}
1341
-
1342
-	return $r;
1333
+    $f = sql_serveur('create', $serveur, $option === 'continue' or $option === false);
1334
+    if (!is_string($f) or !$f) {
1335
+        return false;
1336
+    }
1337
+    $r = $f($nom, $champs, $cles, $autoinc, $temporary, $serveur, $option !== false);
1338
+    if ($r === false) {
1339
+        spip_sql_erreur($serveur);
1340
+    }
1341
+
1342
+    return $r;
1343 1343
 }
1344 1344
 
1345 1345
 /**
@@ -1357,16 +1357,16 @@  discard block
 block discarded – undo
1357 1357
  * @return bool true si la base est créee.
1358 1358
  **/
1359 1359
 function sql_create_base($nom, $serveur = '', $option = true) {
1360
-	$f = sql_serveur('create_base', $serveur, $option === 'continue' or $option === false);
1361
-	if (!is_string($f) or !$f) {
1362
-		return false;
1363
-	}
1364
-	$r = $f($nom, $serveur, $option !== false);
1365
-	if ($r === false) {
1366
-		spip_sql_erreur($serveur);
1367
-	}
1368
-
1369
-	return $r;
1360
+    $f = sql_serveur('create_base', $serveur, $option === 'continue' or $option === false);
1361
+    if (!is_string($f) or !$f) {
1362
+        return false;
1363
+    }
1364
+    $r = $f($nom, $serveur, $option !== false);
1365
+    if ($r === false) {
1366
+        spip_sql_erreur($serveur);
1367
+    }
1368
+
1369
+    return $r;
1370 1370
 }
1371 1371
 
1372 1372
 
@@ -1396,16 +1396,16 @@  discard block
 block discarded – undo
1396 1396
  *     - false en cas d'échec.
1397 1397
  **/
1398 1398
 function sql_create_view($nom, $select_query, $serveur = '', $option = true) {
1399
-	$f = sql_serveur('create_view', $serveur, $option === 'continue' or $option === false);
1400
-	if (!is_string($f) or !$f) {
1401
-		return false;
1402
-	}
1403
-	$r = $f($nom, $select_query, $serveur, $option !== false);
1404
-	if ($r === false) {
1405
-		spip_sql_erreur($serveur);
1406
-	}
1407
-
1408
-	return $r;
1399
+    $f = sql_serveur('create_view', $serveur, $option === 'continue' or $option === false);
1400
+    if (!is_string($f) or !$f) {
1401
+        return false;
1402
+    }
1403
+    $r = $f($nom, $select_query, $serveur, $option !== false);
1404
+    if ($r === false) {
1405
+        spip_sql_erreur($serveur);
1406
+    }
1407
+
1408
+    return $r;
1409 1409
 }
1410 1410
 
1411 1411
 /**
@@ -1434,12 +1434,12 @@  discard block
 block discarded – undo
1434 1434
  *     texte de sélection pour la requête
1435 1435
  */
1436 1436
 function sql_multi($sel, $lang, $serveur = '', $option = true) {
1437
-	$f = sql_serveur('multi', $serveur, $option === 'continue' or $option === false);
1438
-	if (!is_string($f) or !$f) {
1439
-		return false;
1440
-	}
1437
+    $f = sql_serveur('multi', $serveur, $option === 'continue' or $option === false);
1438
+    if (!is_string($f) or !$f) {
1439
+        return false;
1440
+    }
1441 1441
 
1442
-	return $f($sel, $lang);
1442
+    return $f($sel, $lang);
1443 1443
 }
1444 1444
 
1445 1445
 
@@ -1454,12 +1454,12 @@  discard block
 block discarded – undo
1454 1454
  *      False si le serveur est indisponible
1455 1455
  */
1456 1456
 function sql_error($serveur = '') {
1457
-	$f = sql_serveur('error', $serveur, true);
1458
-	if (!is_string($f) or !$f) {
1459
-		return false;
1460
-	}
1457
+    $f = sql_serveur('error', $serveur, true);
1458
+    if (!is_string($f) or !$f) {
1459
+        return false;
1460
+    }
1461 1461
 
1462
-	return $f('query inconnue', $serveur);
1462
+    return $f('query inconnue', $serveur);
1463 1463
 }
1464 1464
 
1465 1465
 /**
@@ -1473,12 +1473,12 @@  discard block
 block discarded – undo
1473 1473
  *      False si le serveur est indisponible
1474 1474
  */
1475 1475
 function sql_errno($serveur = '') {
1476
-	$f = sql_serveur('errno', $serveur, true);
1477
-	if (!is_string($f) or !$f) {
1478
-		return false;
1479
-	}
1476
+    $f = sql_serveur('errno', $serveur, true);
1477
+    if (!is_string($f) or !$f) {
1478
+        return false;
1479
+    }
1480 1480
 
1481
-	return $f($serveur);
1481
+    return $f($serveur);
1482 1482
 }
1483 1483
 
1484 1484
 /**
@@ -1496,16 +1496,16 @@  discard block
 block discarded – undo
1496 1496
  * @return array|false   Tableau de l'explication
1497 1497
  */
1498 1498
 function sql_explain($q, $serveur = '', $option = true) {
1499
-	$f = sql_serveur('explain', $serveur, true);
1500
-	if (!is_string($f) or !$f) {
1501
-		return false;
1502
-	}
1503
-	$r = $f($q, $serveur, $option !== false);
1504
-	if ($r === false) {
1505
-		spip_sql_erreur($serveur);
1506
-	}
1507
-
1508
-	return $r;
1499
+    $f = sql_serveur('explain', $serveur, true);
1500
+    if (!is_string($f) or !$f) {
1501
+        return false;
1502
+    }
1503
+    $r = $f($q, $serveur, $option !== false);
1504
+    if ($r === false) {
1505
+        spip_sql_erreur($serveur);
1506
+    }
1507
+
1508
+    return $r;
1509 1509
 }
1510 1510
 
1511 1511
 /**
@@ -1523,16 +1523,16 @@  discard block
 block discarded – undo
1523 1523
  * @return bool            Toujours true
1524 1524
  */
1525 1525
 function sql_optimize($table, $serveur = '', $option = true) {
1526
-	$f = sql_serveur('optimize', $serveur, $option === 'continue' or $option === false);
1527
-	if (!is_string($f) or !$f) {
1528
-		return false;
1529
-	}
1530
-	$r = $f($table, $serveur, $option !== false);
1531
-	if ($r === false) {
1532
-		spip_sql_erreur($serveur);
1533
-	}
1534
-
1535
-	return $r;
1526
+    $f = sql_serveur('optimize', $serveur, $option === 'continue' or $option === false);
1527
+    if (!is_string($f) or !$f) {
1528
+        return false;
1529
+    }
1530
+    $r = $f($table, $serveur, $option !== false);
1531
+    if ($r === false) {
1532
+        spip_sql_erreur($serveur);
1533
+    }
1534
+
1535
+    return $r;
1536 1536
 }
1537 1537
 
1538 1538
 /**
@@ -1552,16 +1552,16 @@  discard block
 block discarded – undo
1552 1552
  *     - true si la requête a réussie, false sinon
1553 1553
  */
1554 1554
 function sql_repair($table, $serveur = '', $option = true) {
1555
-	$f = sql_serveur('repair', $serveur, $option === 'continue' or $option === false);
1556
-	if (!is_string($f) or !$f) {
1557
-		return false;
1558
-	}
1559
-	$r = $f($table, $serveur, $option !== false);
1560
-	if ($r === false) {
1561
-		spip_sql_erreur($serveur);
1562
-	}
1563
-
1564
-	return $r;
1555
+    $f = sql_serveur('repair', $serveur, $option === 'continue' or $option === false);
1556
+    if (!is_string($f) or !$f) {
1557
+        return false;
1558
+    }
1559
+    $r = $f($table, $serveur, $option !== false);
1560
+    if ($r === false) {
1561
+        spip_sql_erreur($serveur);
1562
+    }
1563
+
1564
+    return $r;
1565 1565
 }
1566 1566
 
1567 1567
 
@@ -1586,16 +1586,16 @@  discard block
 block discarded – undo
1586 1586
  *     - array : Tableau décrivant requête et temps d'exécution si var_profile actif pour tracer.
1587 1587
  */
1588 1588
 function sql_query($ins, $serveur = '', $option = true) {
1589
-	$f = sql_serveur('query', $serveur, $option === 'continue' or $option === false);
1590
-	if (!is_string($f) or !$f) {
1591
-		return false;
1592
-	}
1593
-	$r = $f($ins, $serveur, $option !== false);
1594
-	if ($r === false) {
1595
-		spip_sql_erreur($serveur);
1596
-	}
1597
-
1598
-	return $r;
1589
+    $f = sql_serveur('query', $serveur, $option === 'continue' or $option === false);
1590
+    if (!is_string($f) or !$f) {
1591
+        return false;
1592
+    }
1593
+    $r = $f($ins, $serveur, $option !== false);
1594
+    if ($r === false) {
1595
+        spip_sql_erreur($serveur);
1596
+    }
1597
+
1598
+    return $r;
1599 1599
 }
1600 1600
 
1601 1601
 /**
@@ -1643,27 +1643,27 @@  discard block
 block discarded – undo
1643 1643
  *
1644 1644
  **/
1645 1645
 function sql_fetsel(
1646
-	$select = [],
1647
-	$from = [],
1648
-	$where = [],
1649
-	$groupby = [],
1650
-	$orderby = [],
1651
-	$limit = '',
1652
-	$having = [],
1653
-	$serveur = '',
1654
-	$option = true
1646
+    $select = [],
1647
+    $from = [],
1648
+    $where = [],
1649
+    $groupby = [],
1650
+    $orderby = [],
1651
+    $limit = '',
1652
+    $having = [],
1653
+    $serveur = '',
1654
+    $option = true
1655 1655
 ) {
1656
-	$q = sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, $option);
1657
-	if ($option === false) {
1658
-		return $q;
1659
-	}
1660
-	if (!$q) {
1661
-		return [];
1662
-	}
1663
-	$r = sql_fetch($q, $serveur, $option);
1664
-	sql_free($q, $serveur, $option);
1665
-
1666
-	return $r;
1656
+    $q = sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, $option);
1657
+    if ($option === false) {
1658
+        return $q;
1659
+    }
1660
+    if (!$q) {
1661
+        return [];
1662
+    }
1663
+    $r = sql_fetch($q, $serveur, $option);
1664
+    sql_free($q, $serveur, $option);
1665
+
1666
+    return $r;
1667 1667
 }
1668 1668
 
1669 1669
 
@@ -1720,22 +1720,22 @@  discard block
 block discarded – undo
1720 1720
  *
1721 1721
  **/
1722 1722
 function sql_allfetsel(
1723
-	$select = [],
1724
-	$from = [],
1725
-	$where = [],
1726
-	$groupby = [],
1727
-	$orderby = [],
1728
-	$limit = '',
1729
-	$having = [],
1730
-	$serveur = '',
1731
-	$option = true
1723
+    $select = [],
1724
+    $from = [],
1725
+    $where = [],
1726
+    $groupby = [],
1727
+    $orderby = [],
1728
+    $limit = '',
1729
+    $having = [],
1730
+    $serveur = '',
1731
+    $option = true
1732 1732
 ) {
1733
-	$q = sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, $option);
1734
-	if ($option === false) {
1735
-		return $q;
1736
-	}
1733
+    $q = sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, $option);
1734
+    if ($option === false) {
1735
+        return $q;
1736
+    }
1737 1737
 
1738
-	return sql_fetch_all($q, $serveur, $option);
1738
+    return sql_fetch_all($q, $serveur, $option);
1739 1739
 }
1740 1740
 
1741 1741
 
@@ -1782,33 +1782,33 @@  discard block
 block discarded – undo
1782 1782
  *
1783 1783
  **/
1784 1784
 function sql_getfetsel(
1785
-	$select,
1786
-	$from = [],
1787
-	$where = [],
1788
-	$groupby = [],
1789
-	$orderby = [],
1790
-	$limit = '',
1791
-	$having = [],
1792
-	$serveur = '',
1793
-	$option = true
1785
+    $select,
1786
+    $from = [],
1787
+    $where = [],
1788
+    $groupby = [],
1789
+    $orderby = [],
1790
+    $limit = '',
1791
+    $having = [],
1792
+    $serveur = '',
1793
+    $option = true
1794 1794
 ) {
1795
-	if (preg_match('/\s+as\s+(\w+)$/i', $select, $c)) {
1796
-		$id = $c[1];
1797
-	} elseif (!preg_match('/\W/', $select)) {
1798
-		$id = $select;
1799
-	} else {
1800
-		$id = 'n';
1801
-		$select .= ' AS n';
1802
-	}
1803
-	$r = sql_fetsel($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, $option);
1804
-	if ($option === false) {
1805
-		return $r;
1806
-	}
1807
-	if (!$r) {
1808
-		return null;
1809
-	}
1810
-
1811
-	return $r[$id];
1795
+    if (preg_match('/\s+as\s+(\w+)$/i', $select, $c)) {
1796
+        $id = $c[1];
1797
+    } elseif (!preg_match('/\W/', $select)) {
1798
+        $id = $select;
1799
+    } else {
1800
+        $id = 'n';
1801
+        $select .= ' AS n';
1802
+    }
1803
+    $r = sql_fetsel($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur, $option);
1804
+    if ($option === false) {
1805
+        return $r;
1806
+    }
1807
+    if (!$r) {
1808
+        return null;
1809
+    }
1810
+
1811
+    return $r[$id];
1812 1812
 }
1813 1813
 
1814 1814
 /**
@@ -1826,9 +1826,9 @@  discard block
 block discarded – undo
1826 1826
  *    Numero de version du serveur SQL
1827 1827
  **/
1828 1828
 function sql_version($serveur = '', $option = true) {
1829
-	$row = sql_fetsel('version() AS n', '', '', '', '', '', '', $serveur);
1829
+    $row = sql_fetsel('version() AS n', '', '', '', '', '', '', $serveur);
1830 1830
 
1831
-	return ($row['n']);
1831
+    return ($row['n']);
1832 1832
 }
1833 1833
 
1834 1834
 /**
@@ -1864,16 +1864,16 @@  discard block
 block discarded – undo
1864 1864
  *    Le serveur SQL prefere t'il des transactions pour les insertions multiples ?
1865 1865
  **/
1866 1866
 function sql_preferer_transaction($serveur = '', $option = true) {
1867
-	$f = sql_serveur('preferer_transaction', $serveur, true);
1868
-	if (!is_string($f) or !$f) {
1869
-		return false;
1870
-	}
1871
-	$r = $f($serveur, $option !== false);
1872
-	if ($r === false) {
1873
-		spip_sql_erreur($serveur);
1874
-	}
1875
-
1876
-	return $r;
1867
+    $f = sql_serveur('preferer_transaction', $serveur, true);
1868
+    if (!is_string($f) or !$f) {
1869
+        return false;
1870
+    }
1871
+    $r = $f($serveur, $option !== false);
1872
+    if ($r === false) {
1873
+        spip_sql_erreur($serveur);
1874
+    }
1875
+
1876
+    return $r;
1877 1877
 }
1878 1878
 
1879 1879
 ;
@@ -1898,16 +1898,16 @@  discard block
 block discarded – undo
1898 1898
  *      false en cas d'erreur
1899 1899
  **/
1900 1900
 function sql_demarrer_transaction($serveur = '', $option = true) {
1901
-	$f = sql_serveur('demarrer_transaction', $serveur, true);
1902
-	if (!is_string($f) or !$f) {
1903
-		return false;
1904
-	}
1905
-	$r = $f($serveur, $option !== false);
1906
-	if ($r === false) {
1907
-		spip_sql_erreur($serveur);
1908
-	}
1909
-
1910
-	return $r;
1901
+    $f = sql_serveur('demarrer_transaction', $serveur, true);
1902
+    if (!is_string($f) or !$f) {
1903
+        return false;
1904
+    }
1905
+    $r = $f($serveur, $option !== false);
1906
+    if ($r === false) {
1907
+        spip_sql_erreur($serveur);
1908
+    }
1909
+
1910
+    return $r;
1911 1911
 }
1912 1912
 
1913 1913
 ;
@@ -1932,16 +1932,16 @@  discard block
 block discarded – undo
1932 1932
  *      false en cas d'erreur
1933 1933
  **/
1934 1934
 function sql_terminer_transaction($serveur = '', $option = true) {
1935
-	$f = sql_serveur('terminer_transaction', $serveur, true);
1936
-	if (!is_string($f) or !$f) {
1937
-		return false;
1938
-	}
1939
-	$r = $f($serveur, $option !== false);
1940
-	if ($r === false) {
1941
-		spip_sql_erreur($serveur);
1942
-	}
1943
-
1944
-	return $r;
1935
+    $f = sql_serveur('terminer_transaction', $serveur, true);
1936
+    if (!is_string($f) or !$f) {
1937
+        return false;
1938
+    }
1939
+    $r = $f($serveur, $option !== false);
1940
+    if ($r === false) {
1941
+        spip_sql_erreur($serveur);
1942
+    }
1943
+
1944
+    return $r;
1945 1945
 }
1946 1946
 
1947 1947
 ;
@@ -1968,12 +1968,12 @@  discard block
 block discarded – undo
1968 1968
  *     Valeur hexadécimale attendue par le serveur SQL
1969 1969
  **/
1970 1970
 function sql_hex($val, $serveur = '', $option = true) {
1971
-	$f = sql_serveur('hex', $serveur, $option === 'continue' or $option === false);
1972
-	if (!is_string($f) or !$f) {
1973
-		return false;
1974
-	}
1971
+    $f = sql_serveur('hex', $serveur, $option === 'continue' or $option === false);
1972
+    if (!is_string($f) or !$f) {
1973
+        return false;
1974
+    }
1975 1975
 
1976
-	return $f($val);
1976
+    return $f($val);
1977 1977
 }
1978 1978
 
1979 1979
 /**
@@ -1999,12 +1999,12 @@  discard block
 block discarded – undo
1999 1999
  *     La chaine echappee
2000 2000
  **/
2001 2001
 function sql_quote($val, $serveur = '', $type = '') {
2002
-	$f = sql_serveur('quote', $serveur, true);
2003
-	if (!is_string($f) or !$f) {
2004
-		$f = '_q';
2005
-	}
2002
+    $f = sql_serveur('quote', $serveur, true);
2003
+    if (!is_string($f) or !$f) {
2004
+        $f = '_q';
2005
+    }
2006 2006
 
2007
-	return $f($val, $type);
2007
+    return $f($val, $type);
2008 2008
 }
2009 2009
 
2010 2010
 /**
@@ -2029,12 +2029,12 @@  discard block
 block discarded – undo
2029 2029
  *     - false si le serveur SQL est indisponible
2030 2030
  **/
2031 2031
 function sql_date_proche($champ, $interval, $unite, $serveur = '', $option = true) {
2032
-	$f = sql_serveur('date_proche', $serveur, true);
2033
-	if (!is_string($f) or !$f) {
2034
-		return false;
2035
-	}
2032
+    $f = sql_serveur('date_proche', $serveur, true);
2033
+    if (!is_string($f) or !$f) {
2034
+        return false;
2035
+    }
2036 2036
 
2037
-	return $f($champ, $interval, $unite);
2037
+    return $f($champ, $interval, $unite);
2038 2038
 }
2039 2039
 
2040 2040
 /**
@@ -2070,26 +2070,26 @@  discard block
 block discarded – undo
2070 2070
  *     Expression de requête SQL
2071 2071
  **/
2072 2072
 function sql_in_quote($champ, $valeurs, $not = '', $serveur = '', $type = '', $option = true) {
2073
-	$quote = sql_serveur('quote', $serveur, true);
2074
-	if (!is_string($quote) or !$quote) {
2075
-		return false;
2076
-	}
2077
-
2078
-	// sql_quote produit une chaine dans tous les cas
2079
-	$valeurs = array_filter($valeurs, fn($v) => !is_array($v));
2080
-	$valeurs = array_unique($valeurs);
2081
-	$valeurs = $quote($valeurs, $type);
2082
-
2083
-	if (!strlen(trim($valeurs))) {
2084
-		return ($not ? '0=0' : '0=1');
2085
-	}
2086
-
2087
-	$f = sql_serveur('in', $serveur, $option === 'continue' or $option === false);
2088
-	if (!is_string($f) or !$f) {
2089
-		return false;
2090
-	}
2091
-
2092
-	return $f($champ, $valeurs, $not ? 'NOT' : '', $serveur, $option !== false);
2073
+    $quote = sql_serveur('quote', $serveur, true);
2074
+    if (!is_string($quote) or !$quote) {
2075
+        return false;
2076
+    }
2077
+
2078
+    // sql_quote produit une chaine dans tous les cas
2079
+    $valeurs = array_filter($valeurs, fn($v) => !is_array($v));
2080
+    $valeurs = array_unique($valeurs);
2081
+    $valeurs = $quote($valeurs, $type);
2082
+
2083
+    if (!strlen(trim($valeurs))) {
2084
+        return ($not ? '0=0' : '0=1');
2085
+    }
2086
+
2087
+    $f = sql_serveur('in', $serveur, $option === 'continue' or $option === false);
2088
+    if (!is_string($f) or !$f) {
2089
+        return false;
2090
+    }
2091
+
2092
+    return $f($champ, $valeurs, $not ? 'NOT' : '', $serveur, $option !== false);
2093 2093
 }
2094 2094
 
2095 2095
 /**
@@ -2106,19 +2106,19 @@  discard block
 block discarded – undo
2106 2106
  * @param bool $option
2107 2107
  */
2108 2108
 function sql_in($champ, $valeurs, $not = '', $serveur = '', $option = true) {
2109
-	$type = '';
2110
-	if (!is_array($valeurs)) {
2111
-		$valeurs = strval($valeurs);
2112
-		if (isset($valeurs[0]) and $valeurs[0] === ',') {
2113
-			$valeurs = substr($valeurs, 1);
2114
-		}
2115
-		// on explode en tableau pour pouvoir securiser le contenu
2116
-		$valeurs = explode(',', $valeurs);
2117
-		// et on force un cast de type int donc
2118
-		$type = 'int';
2119
-	}
2120
-
2121
-	return sql_in_quote($champ, $valeurs, $not, $serveur, $type, $option);
2109
+    $type = '';
2110
+    if (!is_array($valeurs)) {
2111
+        $valeurs = strval($valeurs);
2112
+        if (isset($valeurs[0]) and $valeurs[0] === ',') {
2113
+            $valeurs = substr($valeurs, 1);
2114
+        }
2115
+        // on explode en tableau pour pouvoir securiser le contenu
2116
+        $valeurs = explode(',', $valeurs);
2117
+        // et on force un cast de type int donc
2118
+        $type = 'int';
2119
+    }
2120
+
2121
+    return sql_in_quote($champ, $valeurs, $not, $serveur, $type, $option);
2122 2122
 }
2123 2123
 
2124 2124
 
@@ -2159,24 +2159,24 @@  discard block
 block discarded – undo
2159 2159
  *     Expression de requête SQL
2160 2160
  **/
2161 2161
 function sql_in_select(
2162
-	$in,
2163
-	$select,
2164
-	$from = [],
2165
-	$where = [],
2166
-	$groupby = [],
2167
-	$orderby = [],
2168
-	$limit = '',
2169
-	$having = [],
2170
-	$serveur = ''
2162
+    $in,
2163
+    $select,
2164
+    $from = [],
2165
+    $where = [],
2166
+    $groupby = [],
2167
+    $orderby = [],
2168
+    $limit = '',
2169
+    $having = [],
2170
+    $serveur = ''
2171 2171
 ) {
2172
-	$liste = [];
2173
-	$res = sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur);
2174
-	while ($r = sql_fetch($res)) {
2175
-		$liste[] = array_shift($r);
2176
-	}
2177
-	sql_free($res);
2178
-
2179
-	return sql_in($in, $liste);
2172
+    $liste = [];
2173
+    $res = sql_select($select, $from, $where, $groupby, $orderby, $limit, $having, $serveur);
2174
+    while ($r = sql_fetch($res)) {
2175
+        $liste[] = array_shift($r);
2176
+    }
2177
+    sql_free($res);
2178
+
2179
+    return sql_in($in, $liste);
2180 2180
 }
2181 2181
 
2182 2182
 /**
@@ -2208,29 +2208,29 @@  discard block
 block discarded – undo
2208 2208
  *    Position apres le saut.
2209 2209
  */
2210 2210
 function sql_skip($res, $pos, $saut, $count, $serveur = '', $option = true) {
2211
-	// pas de saut en arriere qu'on ne sait pas faire sans sql_seek
2212
-	if (($saut = intval($saut)) <= 0) {
2213
-		return $pos;
2214
-	}
2215
-
2216
-	$seek = $pos + $saut;
2217
-	// si le saut fait depasser le maxi, on libere la resource
2218
-	// et on sort
2219
-	if ($seek >= $count) {
2220
-		sql_free($res, $serveur, $option);
2221
-
2222
-		return $count;
2223
-	}
2224
-
2225
-	if (sql_seek($res, $seek)) {
2226
-		$pos = $seek;
2227
-	} else {
2228
-		while ($pos < $seek and sql_fetch($res, $serveur, $option)) {
2229
-			$pos++;
2230
-		}
2231
-	}
2232
-
2233
-	return $pos;
2211
+    // pas de saut en arriere qu'on ne sait pas faire sans sql_seek
2212
+    if (($saut = intval($saut)) <= 0) {
2213
+        return $pos;
2214
+    }
2215
+
2216
+    $seek = $pos + $saut;
2217
+    // si le saut fait depasser le maxi, on libere la resource
2218
+    // et on sort
2219
+    if ($seek >= $count) {
2220
+        sql_free($res, $serveur, $option);
2221
+
2222
+        return $count;
2223
+    }
2224
+
2225
+    if (sql_seek($res, $seek)) {
2226
+        $pos = $seek;
2227
+    } else {
2228
+        while ($pos < $seek and sql_fetch($res, $serveur, $option)) {
2229
+            $pos++;
2230
+        }
2231
+    }
2232
+
2233
+    return $pos;
2234 2234
 }
2235 2235
 
2236 2236
 
@@ -2250,7 +2250,7 @@  discard block
 block discarded – undo
2250 2250
  *     True si le champ est de type entier
2251 2251
  */
2252 2252
 function sql_test_int($type, $serveur = '', $option = true) {
2253
-	return preg_match('/^(TINYINT|SMALLINT|MEDIUMINT|INT|INTEGER|BIGINT)/i', trim($type));
2253
+    return preg_match('/^(TINYINT|SMALLINT|MEDIUMINT|INT|INTEGER|BIGINT)/i', trim($type));
2254 2254
 }
2255 2255
 
2256 2256
 /**
@@ -2269,7 +2269,7 @@  discard block
 block discarded – undo
2269 2269
  *     True si le champ est de type entier
2270 2270
  */
2271 2271
 function sql_test_date($type, $serveur = '', $option = true) {
2272
-	return preg_match('/^(DATE|DATETIME|TIMESTAMP|TIME)/i', trim($type));
2272
+    return preg_match('/^(DATE|DATETIME|TIMESTAMP|TIME)/i', trim($type));
2273 2273
 }
2274 2274
 
2275 2275
 /**
@@ -2291,19 +2291,19 @@  discard block
 block discarded – undo
2291 2291
  *     La date formatee
2292 2292
  */
2293 2293
 function sql_format_date($annee = 0, $mois = 0, $jour = 0, $h = 0, $m = 0, $s = 0, $serveur = '') {
2294
-	$annee = sprintf('%04s', $annee);
2295
-	$mois = sprintf('%02s', $mois);
2296
-
2297
-	if ($annee == '0000') {
2298
-		$mois = 0;
2299
-	}
2300
-	if ($mois == '00') {
2301
-		$jour = 0;
2302
-	}
2303
-
2304
-	return sprintf('%04u', $annee) . '-' . sprintf('%02u', $mois) . '-'
2305
-	. sprintf('%02u', $jour) . ' ' . sprintf('%02u', $h) . ':'
2306
-	. sprintf('%02u', $m) . ':' . sprintf('%02u', $s);
2294
+    $annee = sprintf('%04s', $annee);
2295
+    $mois = sprintf('%02s', $mois);
2296
+
2297
+    if ($annee == '0000') {
2298
+        $mois = 0;
2299
+    }
2300
+    if ($mois == '00') {
2301
+        $jour = 0;
2302
+    }
2303
+
2304
+    return sprintf('%04u', $annee) . '-' . sprintf('%02u', $mois) . '-'
2305
+    . sprintf('%02u', $jour) . ' ' . sprintf('%02u', $h) . ':'
2306
+    . sprintf('%02u', $m) . ':' . sprintf('%02u', $s);
2307 2307
 }
2308 2308
 
2309 2309
 
@@ -2326,32 +2326,32 @@  discard block
 block discarded – undo
2326 2326
  **/
2327 2327
 function description_table($nom, $serveur = '') {
2328 2328
 
2329
-	static $trouver_table;
2329
+    static $trouver_table;
2330 2330
 
2331
-	/* toujours utiliser trouver_table
2331
+    /* toujours utiliser trouver_table
2332 2332
 	 qui renverra la description theorique
2333 2333
 	 car sinon on va se comporter differement selon que la table est declaree
2334 2334
 	 ou non
2335 2335
 	 */
2336
-	if (!$trouver_table) {
2337
-		$trouver_table = charger_fonction('trouver_table', 'base');
2338
-	}
2339
-	if ($desc = $trouver_table($nom, $serveur)) {
2340
-		return $desc;
2341
-	}
2342
-
2343
-	// sauf a l'installation :
2344
-	include_spip('base/serial');
2345
-	if (isset($GLOBALS['tables_principales'][$nom])) {
2346
-		return $GLOBALS['tables_principales'][$nom];
2347
-	}
2348
-
2349
-	include_spip('base/auxiliaires');
2350
-	if (isset($GLOBALS['tables_auxiliaires'][$nom])) {
2351
-		return $GLOBALS['tables_auxiliaires'][$nom];
2352
-	}
2353
-
2354
-	return false;
2336
+    if (!$trouver_table) {
2337
+        $trouver_table = charger_fonction('trouver_table', 'base');
2338
+    }
2339
+    if ($desc = $trouver_table($nom, $serveur)) {
2340
+        return $desc;
2341
+    }
2342
+
2343
+    // sauf a l'installation :
2344
+    include_spip('base/serial');
2345
+    if (isset($GLOBALS['tables_principales'][$nom])) {
2346
+        return $GLOBALS['tables_principales'][$nom];
2347
+    }
2348
+
2349
+    include_spip('base/auxiliaires');
2350
+    if (isset($GLOBALS['tables_auxiliaires'][$nom])) {
2351
+        return $GLOBALS['tables_auxiliaires'][$nom];
2352
+    }
2353
+
2354
+    return false;
2355 2355
 }
2356 2356
 
2357 2357
 /**
@@ -2364,8 +2364,8 @@  discard block
 block discarded – undo
2364 2364
  * @return string Table sql éventuellement renommée
2365 2365
  */
2366 2366
 function prefixer_table_spip($table, $prefixe) {
2367
-	if ($prefixe) {
2368
-		$table = preg_replace('/^spip_/', $prefixe . '_', $table);
2369
-	}
2370
-	return $table;
2367
+    if ($prefixe) {
2368
+        $table = preg_replace('/^spip_/', $prefixe . '_', $table);
2369
+    }
2370
+    return $table;
2371 2371
 }
Please login to merge, or discard this patch.
ecrire/base/create.php 1 patch
Indentation   +98 added lines, -98 removed lines patch added patch discarded remove patch
@@ -16,7 +16,7 @@  discard block
 block discarded – undo
16 16
  * @package SPIP\Core\Installation
17 17
  **/
18 18
 if (!defined('_ECRIRE_INC_VERSION')) {
19
-	return;
19
+    return;
20 20
 }
21 21
 
22 22
 include_spip('inc/acces');
@@ -33,18 +33,18 @@  discard block
 block discarded – undo
33 33
  * @return bool
34 34
  */
35 35
 function base_determine_autoinc($table, $desc = []) {
36
-	if ($t = lister_tables_principales() and isset($t[$table])) {
37
-		$autoinc = true;
38
-	} elseif ($t = lister_tables_auxiliaires() and isset($t[$table])) {
39
-		$autoinc = false;
40
-	} else {
41
-		// essayer de faire au mieux !
42
-		$autoinc = (isset($desc['key']['PRIMARY KEY'])
43
-			and !str_contains($desc['key']['PRIMARY KEY'], ',')
44
-			and !str_contains($desc['field'][$desc['key']['PRIMARY KEY']], 'default'));
45
-	}
36
+    if ($t = lister_tables_principales() and isset($t[$table])) {
37
+        $autoinc = true;
38
+    } elseif ($t = lister_tables_auxiliaires() and isset($t[$table])) {
39
+        $autoinc = false;
40
+    } else {
41
+        // essayer de faire au mieux !
42
+        $autoinc = (isset($desc['key']['PRIMARY KEY'])
43
+            and !str_contains($desc['key']['PRIMARY KEY'], ',')
44
+            and !str_contains($desc['field'][$desc['key']['PRIMARY KEY']], 'default'));
45
+    }
46 46
 
47
-	return $autoinc;
47
+    return $autoinc;
48 48
 }
49 49
 
50 50
 /**
@@ -61,58 +61,58 @@  discard block
 block discarded – undo
61 61
  * @return void
62 62
  */
63 63
 function creer_ou_upgrader_table($table, $desc, $autoinc, $upgrade = false, $serveur = '') {
64
-	#spip_log("creer_ou_upgrader_table table=$table autoinc=$autoinc upgrade=$upgrade","dbinstall"._LOG_INFO_IMPORTANTE);
65
-	$sql_desc = $upgrade ? sql_showtable($table, true, $serveur) : false;
66
-	#if (!$sql_desc) $sql_desc = false;
67
-	#spip_log("table=$table sql_desc:$sql_desc","dbinstall"._LOG_INFO_IMPORTANTE);
68
-	if (!$sql_desc) {
69
-		if ($autoinc === 'auto') {
70
-			$autoinc = base_determine_autoinc($table, $desc);
71
-		}
72
-		#spip_log("sql_create $table autoinc=$autoinc","dbinstall"._LOG_INFO_IMPORTANTE);
73
-		if (isset($desc['field']) and isset($desc['key'])) {
74
-			sql_create($table, $desc['field'], $desc['key'], $autoinc, false, $serveur);
75
-		}
76
-		// verifier la bonne installation de la table (php-fpm es-tu la ?)
77
-		$sql_desc = sql_showtable($table, true, $serveur);
78
-		#if (!$sql_desc) $sql_desc = false;
79
-		#spip_log("Resultat table=$table sql_desc:$sql_desc","dbinstall"._LOG_INFO_IMPORTANTE);
80
-		if (!$sql_desc) {
81
-			// on retente avec un sleep ?
82
-			sleep(1);
83
-			sql_create($table, $desc['field'], $desc['key'], $autoinc, false, $serveur);
84
-			$sql_desc = sql_showtable($table, true, $serveur);
85
-			#if (!$sql_desc) $sql_desc = false;
86
-			#spip_log("Resultat table=$table sql_desc:$sql_desc","dbinstall"._LOG_INFO_IMPORTANTE);
87
-			if (!$sql_desc) {
88
-				spip_log("Echec creation table $table", 'maj' . _LOG_CRITIQUE);
89
-			}
90
-		}
91
-	} else {
92
-		#spip_log("sql_alter $table ... (on s'en fiche)","dbinstall"._LOG_INFO_IMPORTANTE);
93
-		// ajouter les champs manquants
94
-		// on ne supprime jamais les champs, car c'est dangereux
95
-		// c'est toujours a faire manuellement
96
-		$last = '';
97
-		if (isset($desc['field'])) {
98
-			foreach ($desc['field'] as $field => $type) {
99
-				if (!isset($sql_desc['field'][$field])) {
100
-					sql_alter("TABLE $table ADD $field $type" . ($last ? " AFTER $last" : ''), $serveur);
101
-				}
102
-				$last = $field;
103
-			}
104
-		}
105
-		if (isset($desc['key'])) {
106
-			foreach ($desc['key'] as $key => $type) {
107
-				// Ne pas oublier les cas des cles non nommees dans la declaration et qui sont retournees
108
-				// par le showtable sous la forme d'un index de tableau "KEY $type" et non "KEY"
109
-				if (!isset($sql_desc['key'][$key]) and !isset($sql_desc['key']["$key $type"])) {
110
-					sql_alter("TABLE $table ADD $key ($type)", $serveur);
111
-				}
112
-				$last = $field;
113
-			}
114
-		}
115
-	}
64
+    #spip_log("creer_ou_upgrader_table table=$table autoinc=$autoinc upgrade=$upgrade","dbinstall"._LOG_INFO_IMPORTANTE);
65
+    $sql_desc = $upgrade ? sql_showtable($table, true, $serveur) : false;
66
+    #if (!$sql_desc) $sql_desc = false;
67
+    #spip_log("table=$table sql_desc:$sql_desc","dbinstall"._LOG_INFO_IMPORTANTE);
68
+    if (!$sql_desc) {
69
+        if ($autoinc === 'auto') {
70
+            $autoinc = base_determine_autoinc($table, $desc);
71
+        }
72
+        #spip_log("sql_create $table autoinc=$autoinc","dbinstall"._LOG_INFO_IMPORTANTE);
73
+        if (isset($desc['field']) and isset($desc['key'])) {
74
+            sql_create($table, $desc['field'], $desc['key'], $autoinc, false, $serveur);
75
+        }
76
+        // verifier la bonne installation de la table (php-fpm es-tu la ?)
77
+        $sql_desc = sql_showtable($table, true, $serveur);
78
+        #if (!$sql_desc) $sql_desc = false;
79
+        #spip_log("Resultat table=$table sql_desc:$sql_desc","dbinstall"._LOG_INFO_IMPORTANTE);
80
+        if (!$sql_desc) {
81
+            // on retente avec un sleep ?
82
+            sleep(1);
83
+            sql_create($table, $desc['field'], $desc['key'], $autoinc, false, $serveur);
84
+            $sql_desc = sql_showtable($table, true, $serveur);
85
+            #if (!$sql_desc) $sql_desc = false;
86
+            #spip_log("Resultat table=$table sql_desc:$sql_desc","dbinstall"._LOG_INFO_IMPORTANTE);
87
+            if (!$sql_desc) {
88
+                spip_log("Echec creation table $table", 'maj' . _LOG_CRITIQUE);
89
+            }
90
+        }
91
+    } else {
92
+        #spip_log("sql_alter $table ... (on s'en fiche)","dbinstall"._LOG_INFO_IMPORTANTE);
93
+        // ajouter les champs manquants
94
+        // on ne supprime jamais les champs, car c'est dangereux
95
+        // c'est toujours a faire manuellement
96
+        $last = '';
97
+        if (isset($desc['field'])) {
98
+            foreach ($desc['field'] as $field => $type) {
99
+                if (!isset($sql_desc['field'][$field])) {
100
+                    sql_alter("TABLE $table ADD $field $type" . ($last ? " AFTER $last" : ''), $serveur);
101
+                }
102
+                $last = $field;
103
+            }
104
+        }
105
+        if (isset($desc['key'])) {
106
+            foreach ($desc['key'] as $key => $type) {
107
+                // Ne pas oublier les cas des cles non nommees dans la declaration et qui sont retournees
108
+                // par le showtable sous la forme d'un index de tableau "KEY $type" et non "KEY"
109
+                if (!isset($sql_desc['key'][$key]) and !isset($sql_desc['key']["$key $type"])) {
110
+                    sql_alter("TABLE $table ADD $key ($type)", $serveur);
111
+                }
112
+                $last = $field;
113
+            }
114
+        }
115
+    }
116 116
 }
117 117
 
118 118
 /**
@@ -134,26 +134,26 @@  discard block
 block discarded – undo
134 134
  * @return void
135 135
  */
136 136
 function alterer_base($tables_inc, $tables_noinc, $up = false, $serveur = '') {
137
-	if ($up === false) {
138
-		$old = false;
139
-		$up = [];
140
-	} else {
141
-		$old = true;
142
-		if (!is_array($up)) {
143
-			$up = [$up];
144
-		}
145
-	}
146
-	foreach ($tables_inc as $k => $v) {
147
-		if (!$old or in_array($k, $up)) {
148
-			creer_ou_upgrader_table($k, $v, true, $old, $serveur);
149
-		}
150
-	}
137
+    if ($up === false) {
138
+        $old = false;
139
+        $up = [];
140
+    } else {
141
+        $old = true;
142
+        if (!is_array($up)) {
143
+            $up = [$up];
144
+        }
145
+    }
146
+    foreach ($tables_inc as $k => $v) {
147
+        if (!$old or in_array($k, $up)) {
148
+            creer_ou_upgrader_table($k, $v, true, $old, $serveur);
149
+        }
150
+    }
151 151
 
152
-	foreach ($tables_noinc as $k => $v) {
153
-		if (!$old or in_array($k, $up)) {
154
-			creer_ou_upgrader_table($k, $v, false, $old, $serveur);
155
-		}
156
-	}
152
+    foreach ($tables_noinc as $k => $v) {
153
+        if (!$old or in_array($k, $up)) {
154
+            creer_ou_upgrader_table($k, $v, false, $old, $serveur);
155
+        }
156
+    }
157 157
 }
158 158
 
159 159
 /**
@@ -173,16 +173,16 @@  discard block
 block discarded – undo
173 173
  */
174 174
 function creer_base($serveur = '') {
175 175
 
176
-	// Note: les mises a jour reexecutent ce code pour s'assurer
177
-	// de la conformite de la base
178
-	// pas de panique sur  "already exists" et "duplicate entry" donc.
176
+    // Note: les mises a jour reexecutent ce code pour s'assurer
177
+    // de la conformite de la base
178
+    // pas de panique sur  "already exists" et "duplicate entry" donc.
179 179
 
180
-	alterer_base(
181
-		lister_tables_principales(),
182
-		lister_tables_auxiliaires(),
183
-		false,
184
-		$serveur
185
-	);
180
+    alterer_base(
181
+        lister_tables_principales(),
182
+        lister_tables_auxiliaires(),
183
+        false,
184
+        $serveur
185
+    );
186 186
 }
187 187
 
188 188
 /**
@@ -202,10 +202,10 @@  discard block
 block discarded – undo
202 202
  * @return void
203 203
  */
204 204
 function maj_tables($upgrade_tables = [], $serveur = '') {
205
-	alterer_base(
206
-		lister_tables_principales(),
207
-		lister_tables_auxiliaires(),
208
-		$upgrade_tables,
209
-		$serveur
210
-	);
205
+    alterer_base(
206
+        lister_tables_principales(),
207
+        lister_tables_auxiliaires(),
208
+        $upgrade_tables,
209
+        $serveur
210
+    );
211 211
 }
Please login to merge, or discard this patch.
ecrire/action/inscrire_auteur.php 1 patch
Indentation   +236 added lines, -236 removed lines patch added patch discarded remove patch
@@ -21,7 +21,7 @@  discard block
 block discarded – undo
21 21
 
22 22
 
23 23
 if (!defined('_ECRIRE_INC_VERSION')) {
24
-	return;
24
+    return;
25 25
 }
26 26
 
27 27
 
@@ -44,70 +44,70 @@  discard block
 block discarded – undo
44 44
  * @return array|string
45 45
  */
46 46
 function action_inscrire_auteur_dist($statut, $mail_complet, $nom, $options = []) {
47
-	if (!is_array($options)) {
48
-		$options = ['id' => $options];
49
-	}
50
-
51
-	if (function_exists('test_inscription')) {
52
-		$f = 'test_inscription';
53
-	} else {
54
-		$f = 'test_inscription_dist';
55
-	}
56
-	$desc = $f($statut, $mail_complet, $nom, $options);
57
-
58
-	// erreur ?
59
-	if (!is_array($desc)) {
60
-		return _T($desc);
61
-	}
62
-
63
-	include_spip('base/abstract_sql');
64
-	$res = sql_select('statut, id_auteur, login, email, nom', 'spip_auteurs', 'email=' . sql_quote($desc['email']));
65
-	// erreur ?
66
-	if (!$res) {
67
-		return _T('titre_probleme_technique');
68
-	}
69
-
70
-	$row = sql_fetch($res);
71
-	sql_free($res);
72
-	if ($row) {
73
-		if (isset($options['force_nouveau']) and $options['force_nouveau'] == true) {
74
-			$desc['id_auteur'] = $row['id_auteur'];
75
-			$desc = inscription_nouveau($desc);
76
-		} else {
77
-			$desc = $row;
78
-		}
79
-	} else // s'il n'existe pas deja, creer les identifiants
80
-	{
81
-		$desc = inscription_nouveau($desc);
82
-	}
83
-
84
-	// erreur ?
85
-	if (!is_array($desc)) {
86
-		return $desc;
87
-	}
88
-
89
-
90
-	// generer le mot de passe (ou le refaire si compte inutilise)
91
-	$desc['pass'] = creer_pass_pour_auteur($desc['id_auteur']);
92
-
93
-	// attribuer un jeton pour confirmation par clic sur un lien
94
-	$desc['jeton'] = auteur_attribuer_jeton($desc['id_auteur']);
95
-
96
-	// charger de suite cette fonction, pour ses utilitaires
97
-	$envoyer_inscription = charger_fonction('envoyer_inscription', '');
98
-	[$sujet, $msg, $from, $head] = $envoyer_inscription($desc, $nom, $statut, $options);
99
-
100
-	$notifications = charger_fonction('notifications', 'inc');
101
-	notifications_envoyer_mails($mail_complet, $msg, $sujet, $from, $head);
102
-
103
-	// Notifications
104
-	$notifications(
105
-		'inscription',
106
-		$desc['id_auteur'],
107
-		['nom' => $desc['nom'], 'email' => $desc['email']]
108
-	);
109
-
110
-	return $desc;
47
+    if (!is_array($options)) {
48
+        $options = ['id' => $options];
49
+    }
50
+
51
+    if (function_exists('test_inscription')) {
52
+        $f = 'test_inscription';
53
+    } else {
54
+        $f = 'test_inscription_dist';
55
+    }
56
+    $desc = $f($statut, $mail_complet, $nom, $options);
57
+
58
+    // erreur ?
59
+    if (!is_array($desc)) {
60
+        return _T($desc);
61
+    }
62
+
63
+    include_spip('base/abstract_sql');
64
+    $res = sql_select('statut, id_auteur, login, email, nom', 'spip_auteurs', 'email=' . sql_quote($desc['email']));
65
+    // erreur ?
66
+    if (!$res) {
67
+        return _T('titre_probleme_technique');
68
+    }
69
+
70
+    $row = sql_fetch($res);
71
+    sql_free($res);
72
+    if ($row) {
73
+        if (isset($options['force_nouveau']) and $options['force_nouveau'] == true) {
74
+            $desc['id_auteur'] = $row['id_auteur'];
75
+            $desc = inscription_nouveau($desc);
76
+        } else {
77
+            $desc = $row;
78
+        }
79
+    } else // s'il n'existe pas deja, creer les identifiants
80
+    {
81
+        $desc = inscription_nouveau($desc);
82
+    }
83
+
84
+    // erreur ?
85
+    if (!is_array($desc)) {
86
+        return $desc;
87
+    }
88
+
89
+
90
+    // generer le mot de passe (ou le refaire si compte inutilise)
91
+    $desc['pass'] = creer_pass_pour_auteur($desc['id_auteur']);
92
+
93
+    // attribuer un jeton pour confirmation par clic sur un lien
94
+    $desc['jeton'] = auteur_attribuer_jeton($desc['id_auteur']);
95
+
96
+    // charger de suite cette fonction, pour ses utilitaires
97
+    $envoyer_inscription = charger_fonction('envoyer_inscription', '');
98
+    [$sujet, $msg, $from, $head] = $envoyer_inscription($desc, $nom, $statut, $options);
99
+
100
+    $notifications = charger_fonction('notifications', 'inc');
101
+    notifications_envoyer_mails($mail_complet, $msg, $sujet, $from, $head);
102
+
103
+    // Notifications
104
+    $notifications(
105
+        'inscription',
106
+        $desc['id_auteur'],
107
+        ['nom' => $desc['nom'], 'email' => $desc['email']]
108
+    );
109
+
110
+    return $desc;
111 111
 }
112 112
 
113 113
 
@@ -130,23 +130,23 @@  discard block
 block discarded – undo
130 130
  *
131 131
  */
132 132
 function test_inscription_dist($statut, $mail, $nom, $options) {
133
-	include_spip('inc/filtres');
134
-	if (!$r = email_valide($mail)) {
135
-		return 'info_email_invalide';
136
-	}
137
-	$nom = trim(corriger_caracteres($nom));
138
-	$res = ['email' => $r, 'nom' => $nom, 'prefs' => $statut];
139
-	if (isset($options['login'])) {
140
-		$login = trim(corriger_caracteres($options['login']));
141
-		if ((strlen($login) >= _LOGIN_TROP_COURT) and (strlen($nom) <= 64)) {
142
-			$res['login'] = $login;
143
-		}
144
-	}
145
-	if (!isset($res['login']) and ((strlen($nom) < _LOGIN_TROP_COURT) or (strlen($nom) > 64))) {
146
-		return 'ecrire:info_login_trop_court';
147
-	}
148
-
149
-	return $res;
133
+    include_spip('inc/filtres');
134
+    if (!$r = email_valide($mail)) {
135
+        return 'info_email_invalide';
136
+    }
137
+    $nom = trim(corriger_caracteres($nom));
138
+    $res = ['email' => $r, 'nom' => $nom, 'prefs' => $statut];
139
+    if (isset($options['login'])) {
140
+        $login = trim(corriger_caracteres($options['login']));
141
+        if ((strlen($login) >= _LOGIN_TROP_COURT) and (strlen($nom) <= 64)) {
142
+            $res['login'] = $login;
143
+        }
144
+    }
145
+    if (!isset($res['login']) and ((strlen($nom) < _LOGIN_TROP_COURT) or (strlen($nom) > 64))) {
146
+        return 'ecrire:info_login_trop_court';
147
+    }
148
+
149
+    return $res;
150 150
 }
151 151
 
152 152
 
@@ -159,33 +159,33 @@  discard block
 block discarded – undo
159 159
  * @return mixed|string
160 160
  */
161 161
 function inscription_nouveau($desc) {
162
-	if (!isset($desc['login']) or !strlen($desc['login'])) {
163
-		$desc['login'] = test_login($desc['nom'], $desc['email']);
164
-	}
162
+    if (!isset($desc['login']) or !strlen($desc['login'])) {
163
+        $desc['login'] = test_login($desc['nom'], $desc['email']);
164
+    }
165 165
 
166
-	$desc['statut'] = 'nouveau';
167
-	include_spip('action/editer_auteur');
168
-	if (isset($desc['id_auteur'])) {
169
-		$id_auteur = $desc['id_auteur'];
170
-	} else {
171
-		$id_auteur = auteur_inserer();
172
-	}
166
+    $desc['statut'] = 'nouveau';
167
+    include_spip('action/editer_auteur');
168
+    if (isset($desc['id_auteur'])) {
169
+        $id_auteur = $desc['id_auteur'];
170
+    } else {
171
+        $id_auteur = auteur_inserer();
172
+    }
173 173
 
174
-	if (!$id_auteur) {
175
-		return _T('titre_probleme_technique');
176
-	}
174
+    if (!$id_auteur) {
175
+        return _T('titre_probleme_technique');
176
+    }
177 177
 
178
-	$desc['lang'] = $GLOBALS['spip_lang'];
178
+    $desc['lang'] = $GLOBALS['spip_lang'];
179 179
 
180
-	include_spip('inc/autoriser');
181
-	// lever l'autorisation pour pouvoir modifier le statut
182
-	autoriser_exception('modifier', 'auteur', $id_auteur);
183
-	auteur_modifier($id_auteur, $desc);
184
-	autoriser_exception('modifier', 'auteur', $id_auteur, false);
180
+    include_spip('inc/autoriser');
181
+    // lever l'autorisation pour pouvoir modifier le statut
182
+    autoriser_exception('modifier', 'auteur', $id_auteur);
183
+    auteur_modifier($id_auteur, $desc);
184
+    autoriser_exception('modifier', 'auteur', $id_auteur, false);
185 185
 
186
-	$desc['id_auteur'] = $id_auteur;
186
+    $desc['id_auteur'] = $id_auteur;
187 187
 
188
-	return $desc;
188
+    return $desc;
189 189
 }
190 190
 
191 191
 
@@ -202,27 +202,27 @@  discard block
 block discarded – undo
202 202
  * @return string
203 203
  */
204 204
 function test_login($nom, $mail) {
205
-	include_spip('inc/charsets');
206
-	$nom = strtolower(translitteration($nom));
207
-	$login_base = preg_replace('/[^\w\d_]/', '_', $nom);
208
-
209
-	// il faut eviter que le login soit vraiment trop court
210
-	if (strlen($login_base) < 3) {
211
-		$mail = strtolower(translitteration(preg_replace('/@.*/', '', $mail)));
212
-		$login_base = preg_replace('/[^\w\d]/', '_', $mail);
213
-	}
214
-	if (strlen($login_base) < 3) {
215
-		$login_base = 'user';
216
-	}
217
-
218
-	$login = $login_base;
219
-
220
-	for ($i = 1;; $i++) {
221
-		if (!sql_countsel('spip_auteurs', "login='$login'")) {
222
-			return $login;
223
-		}
224
-		$login = $login_base . $i;
225
-	}
205
+    include_spip('inc/charsets');
206
+    $nom = strtolower(translitteration($nom));
207
+    $login_base = preg_replace('/[^\w\d_]/', '_', $nom);
208
+
209
+    // il faut eviter que le login soit vraiment trop court
210
+    if (strlen($login_base) < 3) {
211
+        $mail = strtolower(translitteration(preg_replace('/@.*/', '', $mail)));
212
+        $login_base = preg_replace('/[^\w\d]/', '_', $mail);
213
+    }
214
+    if (strlen($login_base) < 3) {
215
+        $login_base = 'user';
216
+    }
217
+
218
+    $login = $login_base;
219
+
220
+    for ($i = 1;; $i++) {
221
+        if (!sql_countsel('spip_auteurs', "login='$login'")) {
222
+            return $login;
223
+        }
224
+        $login = $login_base . $i;
225
+    }
226 226
 }
227 227
 
228 228
 
@@ -240,26 +240,26 @@  discard block
 block discarded – undo
240 240
  */
241 241
 function envoyer_inscription_dist($desc, $nom, $mode, $options = []) {
242 242
 
243
-	$contexte = array_merge($desc, $options);
244
-	$contexte['nom'] = $nom;
245
-	$contexte['mode'] = $mode;
246
-	$contexte['url_confirm'] = generer_url_action('confirmer_inscription', '', true, true);
247
-	$contexte['url_confirm'] = parametre_url($contexte['url_confirm'], 'email', $desc['email']);
248
-	$contexte['url_confirm'] = parametre_url($contexte['url_confirm'], 'jeton', $desc['jeton']);
249
-	// S'il y a l'option redirect, on l'ajoute directement ici
250
-	if (isset($options['redirect'])) {
251
-		$contexte['url_confirm'] = parametre_url($contexte['url_confirm'], 'redirect', $options['redirect']);
252
-	}
253
-
254
-	$modele_mail = 'modeles/mail_inscription';
255
-	if (isset($options['modele_mail']) and $options['modele_mail']) {
256
-		$modele_mail = $options['modele_mail'];
257
-	}
258
-	$message = recuperer_fond($modele_mail, $contexte);
259
-	$from = ($options['from'] ?? '');
260
-	$head = '';
261
-
262
-	return ['', $message, $from, $head];
243
+    $contexte = array_merge($desc, $options);
244
+    $contexte['nom'] = $nom;
245
+    $contexte['mode'] = $mode;
246
+    $contexte['url_confirm'] = generer_url_action('confirmer_inscription', '', true, true);
247
+    $contexte['url_confirm'] = parametre_url($contexte['url_confirm'], 'email', $desc['email']);
248
+    $contexte['url_confirm'] = parametre_url($contexte['url_confirm'], 'jeton', $desc['jeton']);
249
+    // S'il y a l'option redirect, on l'ajoute directement ici
250
+    if (isset($options['redirect'])) {
251
+        $contexte['url_confirm'] = parametre_url($contexte['url_confirm'], 'redirect', $options['redirect']);
252
+    }
253
+
254
+    $modele_mail = 'modeles/mail_inscription';
255
+    if (isset($options['modele_mail']) and $options['modele_mail']) {
256
+        $modele_mail = $options['modele_mail'];
257
+    }
258
+    $message = recuperer_fond($modele_mail, $contexte);
259
+    $from = ($options['from'] ?? '');
260
+    $head = '';
261
+
262
+    return ['', $message, $from, $head];
263 263
 }
264 264
 
265 265
 
@@ -270,12 +270,12 @@  discard block
 block discarded – undo
270 270
  * @return string
271 271
  */
272 272
 function creer_pass_pour_auteur($id_auteur) {
273
-	include_spip('inc/acces');
274
-	$pass = creer_pass_aleatoire(max(_PASS_LONGUEUR_MINI, 16), $id_auteur);
275
-	include_spip('action/editer_auteur');
276
-	auteur_instituer($id_auteur, ['pass' => $pass]);
273
+    include_spip('inc/acces');
274
+    $pass = creer_pass_aleatoire(max(_PASS_LONGUEUR_MINI, 16), $id_auteur);
275
+    include_spip('action/editer_auteur');
276
+    auteur_instituer($id_auteur, ['pass' => $pass]);
277 277
 
278
-	return $pass;
278
+    return $pass;
279 279
 }
280 280
 
281 281
 /**
@@ -288,17 +288,17 @@  discard block
 block discarded – undo
288 288
  * @return string
289 289
  */
290 290
 function tester_statut_inscription($statut_tmp, $id) {
291
-	include_spip('inc/autoriser');
292
-	if ($statut_tmp) {
293
-		return autoriser('inscrireauteur', $statut_tmp, $id) ? $statut_tmp : '';
294
-	} elseif (
295
-		autoriser('inscrireauteur', $statut_tmp = '1comite', $id)
296
-		or autoriser('inscrireauteur', $statut_tmp = '6forum', $id)
297
-	) {
298
-		return $statut_tmp;
299
-	}
300
-
301
-	return '';
291
+    include_spip('inc/autoriser');
292
+    if ($statut_tmp) {
293
+        return autoriser('inscrireauteur', $statut_tmp, $id) ? $statut_tmp : '';
294
+    } elseif (
295
+        autoriser('inscrireauteur', $statut_tmp = '1comite', $id)
296
+        or autoriser('inscrireauteur', $statut_tmp = '6forum', $id)
297
+    ) {
298
+        return $statut_tmp;
299
+    }
300
+
301
+    return '';
302 302
 }
303 303
 
304 304
 
@@ -312,35 +312,35 @@  discard block
 block discarded – undo
312 312
  * @return array
313 313
  */
314 314
 function confirmer_statut_inscription($auteur) {
315
-	// securite
316
-	if ($auteur['statut'] != 'nouveau') {
317
-		return $auteur;
318
-	}
319
-
320
-	$s = $auteur['prefs'];
321
-	// securite, au cas ou prefs aurait ete corrompu (ou deja ecrase par un tableau serialize)
322
-	if (!preg_match(',^\w+$,', $s)) {
323
-		$s = '6forum';
324
-	}
325
-	include_spip('inc/autoriser');
326
-	if (!autoriser('inscrireauteur', $s)) {
327
-		return $auteur;
328
-	}
329
-
330
-	include_spip('inc/autoriser');
331
-	// accorder l'autorisation de modif du statut auteur
332
-	autoriser_exception('modifier', 'auteur', $auteur['id_auteur']);
333
-	include_spip('action/editer_auteur');
334
-	// changer le statut
335
-	auteur_modifier($auteur['id_auteur'], ['statut' => $s]);
336
-	unset($_COOKIE['spip_session']); // forcer la maj de la session
337
-	// lever l'autorisation de modif du statut auteur
338
-	autoriser_exception('modifier', 'auteur', $auteur['id_auteur'], false);
339
-
340
-	// mettre a jour le statut
341
-	$auteur['statut'] = $s;
342
-
343
-	return $auteur;
315
+    // securite
316
+    if ($auteur['statut'] != 'nouveau') {
317
+        return $auteur;
318
+    }
319
+
320
+    $s = $auteur['prefs'];
321
+    // securite, au cas ou prefs aurait ete corrompu (ou deja ecrase par un tableau serialize)
322
+    if (!preg_match(',^\w+$,', $s)) {
323
+        $s = '6forum';
324
+    }
325
+    include_spip('inc/autoriser');
326
+    if (!autoriser('inscrireauteur', $s)) {
327
+        return $auteur;
328
+    }
329
+
330
+    include_spip('inc/autoriser');
331
+    // accorder l'autorisation de modif du statut auteur
332
+    autoriser_exception('modifier', 'auteur', $auteur['id_auteur']);
333
+    include_spip('action/editer_auteur');
334
+    // changer le statut
335
+    auteur_modifier($auteur['id_auteur'], ['statut' => $s]);
336
+    unset($_COOKIE['spip_session']); // forcer la maj de la session
337
+    // lever l'autorisation de modif du statut auteur
338
+    autoriser_exception('modifier', 'auteur', $auteur['id_auteur'], false);
339
+
340
+    // mettre a jour le statut
341
+    $auteur['statut'] = $s;
342
+
343
+    return $auteur;
344 344
 }
345 345
 
346 346
 
@@ -354,20 +354,20 @@  discard block
 block discarded – undo
354 354
  * @return string
355 355
  */
356 356
 function auteur_attribuer_jeton($id_auteur): string {
357
-	include_spip('base/abstract_sql');
358
-	include_spip('inc/acces');
359
-
360
-	// s'assurer de l'unicite du jeton pour le couple (email,cookie)
361
-	do {
362
-		// Un morceau du jeton est lisible en bdd pour éviter de devoir déchiffrer
363
-		// tous les jetons connus pour vérifier le jeton d’un auteur.
364
-		$public = substr(creer_uniqid(), 0, 7) . '.';
365
-		$jeton = $public . creer_uniqid();
366
-		$jeton_chiffre_prefixe = $public . Chiffrement::chiffrer($jeton, SpipCles::secret_du_site());
367
-		sql_updateq('spip_auteurs', ['cookie_oubli' => $jeton_chiffre_prefixe], 'id_auteur=' . intval($id_auteur));
368
-	} while (sql_countsel('spip_auteurs', 'cookie_oubli=' . sql_quote($jeton_chiffre_prefixe, '', 'string')) > 1);
369
-
370
-	return $jeton;
357
+    include_spip('base/abstract_sql');
358
+    include_spip('inc/acces');
359
+
360
+    // s'assurer de l'unicite du jeton pour le couple (email,cookie)
361
+    do {
362
+        // Un morceau du jeton est lisible en bdd pour éviter de devoir déchiffrer
363
+        // tous les jetons connus pour vérifier le jeton d’un auteur.
364
+        $public = substr(creer_uniqid(), 0, 7) . '.';
365
+        $jeton = $public . creer_uniqid();
366
+        $jeton_chiffre_prefixe = $public . Chiffrement::chiffrer($jeton, SpipCles::secret_du_site());
367
+        sql_updateq('spip_auteurs', ['cookie_oubli' => $jeton_chiffre_prefixe], 'id_auteur=' . intval($id_auteur));
368
+    } while (sql_countsel('spip_auteurs', 'cookie_oubli=' . sql_quote($jeton_chiffre_prefixe, '', 'string')) > 1);
369
+
370
+    return $jeton;
371 371
 }
372 372
 
373 373
 /**
@@ -381,19 +381,19 @@  discard block
 block discarded – undo
381 381
  * @return string|null
382 382
  */
383 383
 function auteur_lire_jeton(int $id_auteur, bool $autoInit = false): ?string {
384
-	include_spip('base/abstract_sql');
385
-	$jeton_chiffre_prefixe = sql_getfetsel('cookie_oubli', 'spip_auteurs', 'id_auteur=' . $id_auteur);
386
-	if ($jeton_chiffre_prefixe) {
387
-		$jeton_chiffre = substr($jeton_chiffre_prefixe, 8);
388
-		$jeton = Chiffrement::dechiffrer($jeton_chiffre, SpipCles::secret_du_site());
389
-		if ($jeton) {
390
-			return $jeton;
391
-		}
392
-	}
393
-	if ($autoInit) {
394
-		return auteur_attribuer_jeton($id_auteur);
395
-	}
396
-	return null;
384
+    include_spip('base/abstract_sql');
385
+    $jeton_chiffre_prefixe = sql_getfetsel('cookie_oubli', 'spip_auteurs', 'id_auteur=' . $id_auteur);
386
+    if ($jeton_chiffre_prefixe) {
387
+        $jeton_chiffre = substr($jeton_chiffre_prefixe, 8);
388
+        $jeton = Chiffrement::dechiffrer($jeton_chiffre, SpipCles::secret_du_site());
389
+        if ($jeton) {
390
+            return $jeton;
391
+        }
392
+    }
393
+    if ($autoInit) {
394
+        return auteur_attribuer_jeton($id_auteur);
395
+    }
396
+    return null;
397 397
 }
398 398
 
399 399
 /**
@@ -403,24 +403,24 @@  discard block
 block discarded – undo
403 403
  * @return array|bool
404 404
  */
405 405
 function auteur_verifier_jeton($jeton) {
406
-	// refuser un jeton corrompu
407
-	if (preg_match(',[^0-9a-f.],i', $jeton)) {
408
-		return false;
409
-	}
410
-
411
-	include_spip('base/abstract_sql');
412
-	$public = substr($jeton, 0, 8);
413
-
414
-	// Les auteurs qui ont un jetons ressemblant
415
-	$auteurs = sql_allfetsel('*', 'spip_auteurs', 'cookie_oubli LIKE ' . sql_quote($public . '%'));
416
-	foreach ($auteurs as $auteur) {
417
-		$jeton_chiffre = substr($auteur['cookie_oubli'], 8);
418
-		$_jeton = Chiffrement::dechiffrer($jeton_chiffre, SpipCles::secret_du_site());
419
-		if ($_jeton and hash_equals($jeton, $_jeton)) {
420
-			return $auteur;
421
-		}
422
-	}
423
-	return false;
406
+    // refuser un jeton corrompu
407
+    if (preg_match(',[^0-9a-f.],i', $jeton)) {
408
+        return false;
409
+    }
410
+
411
+    include_spip('base/abstract_sql');
412
+    $public = substr($jeton, 0, 8);
413
+
414
+    // Les auteurs qui ont un jetons ressemblant
415
+    $auteurs = sql_allfetsel('*', 'spip_auteurs', 'cookie_oubli LIKE ' . sql_quote($public . '%'));
416
+    foreach ($auteurs as $auteur) {
417
+        $jeton_chiffre = substr($auteur['cookie_oubli'], 8);
418
+        $_jeton = Chiffrement::dechiffrer($jeton_chiffre, SpipCles::secret_du_site());
419
+        if ($_jeton and hash_equals($jeton, $_jeton)) {
420
+            return $auteur;
421
+        }
422
+    }
423
+    return false;
424 424
 }
425 425
 
426 426
 /**
@@ -430,6 +430,6 @@  discard block
 block discarded – undo
430 430
  * @return bool
431 431
  */
432 432
 function auteur_effacer_jeton($id_auteur) {
433
-	include_spip('base/abstract_sql');
434
-	return sql_updateq('spip_auteurs', ['cookie_oubli' => ''], 'id_auteur=' . intval($id_auteur));
433
+    include_spip('base/abstract_sql');
434
+    return sql_updateq('spip_auteurs', ['cookie_oubli' => ''], 'id_auteur=' . intval($id_auteur));
435 435
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Iterateur/Condition.php 1 patch
Indentation   +8 added lines, -8 removed lines patch added patch discarded remove patch
@@ -9,12 +9,12 @@
 block discarded – undo
9 9
  */
10 10
 class Condition extends Data
11 11
 {
12
-	/**
13
-	 * Obtenir les données de la boucle CONDITION.
14
-	 *
15
-	 * @param array $command
16
-	 */
17
-	protected function select($command) {
18
-		$this->tableau = [0 => 1];
19
-	}
12
+    /**
13
+     * Obtenir les données de la boucle CONDITION.
14
+     *
15
+     * @param array $command
16
+     */
17
+    protected function select($command) {
18
+        $this->tableau = [0 => 1];
19
+    }
20 20
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Boucle.php 1 patch
Indentation   +363 added lines, -363 removed lines patch added patch discarded remove patch
@@ -7,367 +7,367 @@
 block discarded – undo
7 7
  */
8 8
 class Boucle
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'boucle';
12
-
13
-	/** Identifiant de la boucle */
14
-	public string $id_boucle;
15
-
16
-	/** Identifiant de la boucle parente */
17
-	public string $id_parent = '';
18
-
19
-	/** Un nom explicite qui peut être affecté manuellement à certaines boucles générées */
20
-	public string $nom = '';
21
-
22
-	/**
23
-	 * Partie avant toujours affichee
24
-	 *
25
-	 * @var string|array
26
-	 */
27
-	public $preaff = '';
28
-
29
-	/**
30
-	 * Partie optionnelle avant
31
-	 *
32
-	 * @var string|array
33
-	 */
34
-	public $avant = '';
35
-
36
-	/**
37
-	 * Pour chaque élément
38
-	 *
39
-	 * @var string|array
40
-	 */
41
-	public $milieu = '';
42
-
43
-	/**
44
-	 * Partie optionnelle après
45
-	 *
46
-	 * @var string|array
47
-	 */
48
-	public $apres = '';
49
-
50
-	/**
51
-	 * Partie alternative, si pas de résultat dans la boucle
52
-	 *
53
-	 * @var string|array
54
-	 */
55
-	public $altern = '';
56
-
57
-	/**
58
-	 * Partie apres toujours affichee
59
-	 *
60
-	 * @var string|array
61
-	 */
62
-	public $postaff = '';
63
-
64
-
65
-	/**
66
-	 * La boucle doit-elle sélectionner la langue ?
67
-	 *
68
-	 * Valeurs : '', 'oui', 'non'
69
-	 */
70
-	public string $lang_select = '';
71
-
72
-	/**
73
-	 * Alias de table d'application de la requête ou nom complet de la table SQL
74
-	 *
75
-	 * FIXME: un seul typage (string ?)
76
-	 *
77
-	 * @var string|false|null
78
-	 */
79
-	public $type_requete = null;
80
-
81
-	/**
82
-	 * La table est elle optionnelle ?
83
-	 *
84
-	 * Si oui, aucune erreur ne sera générée si la table demandée n'est pas présente
85
-	 */
86
-	public bool $table_optionnelle = false;
87
-
88
-	/**
89
-	 * Nom du fichier de connexion
90
-	 */
91
-	public string $sql_serveur = '';
92
-
93
-	/**
94
-	 * Paramètres de la boucle
95
-	 *
96
-	 * Description des paramètres passés à la boucle, qui servent ensuite
97
-	 * au calcul des critères
98
-	 *
99
-	 * FIXME: type unique.
100
-	 * @var false|array
101
-	 *     - false: erreur de syntaxe
102
-	 */
103
-	public $param = [];
104
-
105
-	/**
106
-	 * Critères de la boucle
107
-	 *
108
-	 * FIXME: type array unique.
109
-	 *
110
-	 * @var string|Critere[]
111
-	 * - string: phrasage (code brut). Il reste si erreur de critère
112
-	 * - array: analyse correcte des critères...
113
-	 */
114
-	public $criteres = [];
115
-
116
-	/**
117
-	 * Textes insérés entre 2 éléments de boucle (critère inter)
118
-	 *
119
-	 * @var string[]
120
-	 */
121
-	public array $separateur = [];
122
-
123
-	/**
124
-	 * Liste des jointures possibles avec cette table
125
-	 *
126
-	 * Les jointures par défaut de la table sont complétées en priorité
127
-	 * des jointures déclarées explicitement sur la boucle
128
-	 *
129
-	 * @see base_trouver_table_dist()
130
-	 */
131
-	public array $jointures = [];
132
-
133
-	/**
134
-	 * Jointures explicites avec cette table
135
-	 *
136
-	 * Ces jointures sont utilisées en priorité par rapport aux jointures
137
-	 * normales possibles pour retrouver les colonnes demandées extérieures
138
-	 * à la boucle.
139
-	 *
140
-	 * @var string|bool
141
-	 */
142
-	public $jointures_explicites = false;
143
-
144
-	/**
145
-	 * Nom de la variable PHP stockant le noms de doublons utilisés "$doublons_index"
146
-	 */
147
-	public string $doublons = '';
148
-
149
-	/**
150
-	 * Code PHP ajouté au début de chaque itération de boucle.
151
-	 *
152
-	 * Utilisé entre autre par les critères {pagination}, {n-a,b}, {a/b}...
153
-	 */
154
-	public string $partie = '';
155
-
156
-	/**
157
-	 * Nombre de divisions de la boucle, d'éléments à afficher,
158
-	 * ou de soustractions d'éléments à faire
159
-	 *
160
-	 * Dans les critères limitant le nombre d'éléments affichés
161
-	 * {a,b}, {a,n-b}, {a/b}, {pagination b}, b est affecté à total_parties.
162
-	 */
163
-	public string $total_parties = '';
164
-
165
-	/**
166
-	 * Code PHP ajouté avant l'itération de boucle.
167
-	 *
168
-	 * Utilisé entre autre par les critères {pagination}, {a,b}, {a/b}
169
-	 * pour initialiser les variables de début et de fin d'itération.
170
-	 */
171
-	public string $mode_partie = '';
172
-
173
-	/**
174
-	 * Identifiant d'une boucle qui appelle celle-ci de manière récursive
175
-	 *
176
-	 * Si une boucle est appelée de manière récursive quelque part par
177
-	 * une autre boucle comme <BOUCLE_rec(boucle_identifiant) />, cette
178
-	 * boucle (identifiant) reçoit dans cette propriété l'identifiant
179
-	 * de l'appelant (rec)
180
-	 */
181
-	public string $externe = '';
182
-
183
-	// champs pour la construction de la requete SQL
184
-
185
-	/**
186
-	 * Liste des champs à récupérer par la boucle
187
-	 *
188
-	 * Expression 'table.nom_champ' ou calculée 'nom_champ AS x'
189
-	 *
190
-	 * @var string[]
191
-	 */
192
-	public array $select = [];
193
-
194
-	/**
195
-	 * Liste des alias / tables SQL utilisées dans la boucle
196
-	 *
197
-	 * L'index est un identifiant (xx dans spip_xx assez souvent) qui servira
198
-	 * d'alias au nom de la table ; la valeur est le nom de la table SQL désirée.
199
-	 *
200
-	 * L'index 0 peut définir le type de sources de données de l'itérateur DATA
201
-	 *
202
-	 * @var string[]
203
-	 */
204
-	public array $from = [];
205
-
206
-	/**
207
-	 * Liste des alias / type de jointures utilisées dans la boucle
208
-	 *
209
-	 * L'index est le nom d'alias (comme pour la propriété $from), et la valeur
210
-	 * un type de jointure parmi 'INNER', 'LEFT', 'RIGHT', 'OUTER'.
211
-	 *
212
-	 * Lorsque le type n'est pas déclaré pour un alias, c'est 'INNER'
213
-	 * qui sera utilisé par défaut (créant donc un INNER JOIN).
214
-	 *
215
-	 * @var string[]
216
-	 */
217
-	public array $from_type = [];
218
-
219
-	/**
220
-	 * Liste des conditions WHERE de la boucle
221
-	 *
222
-	 * Permet de restreindre les éléments retournés par une boucle
223
-	 * en fonctions des conditions transmises dans ce tableau.
224
-	 *
225
-	 * Ce tableau peut avoir plusieurs niveaux de profondeur.
226
-	 *
227
-	 * Les éléments du premier niveau sont reliés par des AND, donc
228
-	 * chaque élément ajouté directement au where par
229
-	 * $boucle->where[] = array(...) ou $boucle->where[] = "'expression'"
230
-	 * est une condition AND en plus.
231
-	 *
232
-	 * Par contre, lorsqu'on indique un tableau, il peut décrire des relations
233
-	 * internes différentes. Soit $expr un tableau d'expressions quelconques de 3 valeurs :
234
-	 * $expr = array(operateur, val1, val2)
235
-	 *
236
-	 * Ces 3 valeurs sont des expressions PHP. L'index 0 désigne l'opérateur
237
-	 * à réaliser tel que :
238
-	 *
239
-	 * - "'='" , "'>='", "'<'", "'IN'", "'REGEXP'", "'LIKE'", ... :
240
-	 *    val1 et val2 sont des champs et valeurs à utiliser dans la comparaison
241
-	 *    suivant cet ordre : "val1 operateur val2".
242
-	 *    Exemple : $boucle->where[] = array("'='", "'articles.statut'", "'\"publie\"'");
243
-	 * - "'AND'", "'OR'", "'NOT'" :
244
-	 *    dans ce cas val1 et val2 sont également des expressions
245
-	 *    de comparaison complètes, et peuvent être eux-même des tableaux comme $expr
246
-	 *    Exemples :
247
-	 *    $boucle->where[] = array("'OR'", $expr1, $expr2);
248
-	 *    $boucle->where[] = array("'NOT'", $expr); // val2 n'existe pas avec NOT
249
-	 *
250
-	 * D'autres noms sont possibles pour l'opérateur (le nombre de valeurs diffère) :
251
-	 * - "'SELF'", "'SUBSELECT'" : indiquent des sous requêtes
252
-	 * - "'?'" : indique une condition à faire évaluer (val1 ? val2 : val3)
253
-	 */
254
-	public array $where = [];
255
-
256
-	public array $join = [];
257
-	public array $having = [];
258
-	public $limit = '';
259
-	public array $group = [];
260
-	public array $order = [];
261
-	public array $default_order = [];
262
-	public string $date = 'date';
263
-	public string $hash = '';
264
-	public $in = '';
265
-	public bool $sous_requete = false;
266
-
267
-	/**
268
-	 * Code PHP qui sera ajouté en tout début de la fonction de boucle
269
-	 *
270
-	 * Il sert à insérer le code calculant une hierarchie
271
-	 */
272
-	public string $hierarchie = '';
273
-
274
-	// champs pour la construction du corps PHP
275
-
276
-	/**
277
-	 * Description des sources de données de la boucle
278
-	 *
279
-	 * Description des données de la boucle issu de trouver_table
280
-	 * dans le cadre de l'itérateur SQL et contenant au moins l'index 'field'.
281
-	 *
282
-	 * @see base_trouver_table_dist()
283
-	 */
284
-	public array $show = [];
285
-
286
-	/**
287
-	 * Nom de la table SQL principale de la boucle, sans son préfixe
288
-	 */
289
-	public string $id_table = '';
290
-
291
-	/**
292
-	 * Nom de la clé primaire de la table SQL principale de la boucle
293
-	 */
294
-	public string $primary = '';
295
-
296
-	/**
297
-	 * Code PHP compilé de la boucle
298
-	 *
299
-	 * FIXME: un seul type (string ?)
300
-	 *
301
-	 * - false: boucle fautive ?
302
-	 *
303
-	 * @var string|false
304
-	 */
305
-	public $return = '';
306
-
307
-	public $numrows = false;
308
-	public $cptrows = false;
309
-
310
-	/**
311
-	 * Description du squelette
312
-	 *
313
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
314
-	 *
315
-	 * Peut contenir les index :
316
-	 *
317
-	 * - nom : Nom du fichier de cache
318
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
319
-	 * - sourcefile : Chemin du squelette
320
-	 * - squelette : Code du squelette
321
-	 * - id_mere : Identifiant de la boucle parente
322
-	 * - documents : Pour embed et img dans les textes
323
-	 * - session : Pour un cache sessionné par auteur
324
-	 * - niv : Niveau de tabulation
325
-	 */
326
-	public array $descr = [];
327
-
328
-	/** Numéro de ligne dans le code source du squelette */
329
-	public int $ligne = 0;
330
-
331
-
332
-	/**
333
-	 * table pour stocker les modificateurs de boucle tels que tout, plat ...,
334
-	 * utilisable par les plugins egalement
335
-	 *
336
-	 * @var array<string, mixed>
337
-	 */
338
-	public array $modificateur = [];
339
-
340
-	/**
341
-	 * Type d'itérateur utilisé pour cette boucle
342
-	 *
343
-	 * - 'SQL' dans le cadre d'une boucle sur une table SQL
344
-	 * - 'DATA' pour l'itérateur DATA, ...
345
-	 *
346
-	 * @var string
347
-	 */
348
-	public string $iterateur = ''; // type d'iterateur
349
-
350
-	/**
351
-	 * @var array $debug Textes qui seront insérés dans l’entête de boucle du mode debug
352
-	 */
353
-	public array $debug = [];
354
-
355
-	/**
356
-	 * Index de la boucle dont le champ présent dans cette boucle est originaire,
357
-	 * notamment si le champ a été trouve dans une boucle parente
358
-	 *
359
-	 * Tableau nom du champ => index de boucle
360
-	*/
361
-	public array $index_champ = [];
362
-
363
-	/** Résultat de la compilation (?) (sert au débusqueur) */
364
-	public string $code = '';
365
-
366
-	/** Source des filtres (compatibilité) (?) */
367
-	public array $fonctions = [];
368
-
369
-	// obsoletes, conserves provisoirement pour compatibilite
370
-	public $tout = false;
371
-	public $plat = false;
372
-	public $lien = false;
10
+    /** Type de noeud */
11
+    public string $type = 'boucle';
12
+
13
+    /** Identifiant de la boucle */
14
+    public string $id_boucle;
15
+
16
+    /** Identifiant de la boucle parente */
17
+    public string $id_parent = '';
18
+
19
+    /** Un nom explicite qui peut être affecté manuellement à certaines boucles générées */
20
+    public string $nom = '';
21
+
22
+    /**
23
+     * Partie avant toujours affichee
24
+     *
25
+     * @var string|array
26
+     */
27
+    public $preaff = '';
28
+
29
+    /**
30
+     * Partie optionnelle avant
31
+     *
32
+     * @var string|array
33
+     */
34
+    public $avant = '';
35
+
36
+    /**
37
+     * Pour chaque élément
38
+     *
39
+     * @var string|array
40
+     */
41
+    public $milieu = '';
42
+
43
+    /**
44
+     * Partie optionnelle après
45
+     *
46
+     * @var string|array
47
+     */
48
+    public $apres = '';
49
+
50
+    /**
51
+     * Partie alternative, si pas de résultat dans la boucle
52
+     *
53
+     * @var string|array
54
+     */
55
+    public $altern = '';
56
+
57
+    /**
58
+     * Partie apres toujours affichee
59
+     *
60
+     * @var string|array
61
+     */
62
+    public $postaff = '';
63
+
64
+
65
+    /**
66
+     * La boucle doit-elle sélectionner la langue ?
67
+     *
68
+     * Valeurs : '', 'oui', 'non'
69
+     */
70
+    public string $lang_select = '';
71
+
72
+    /**
73
+     * Alias de table d'application de la requête ou nom complet de la table SQL
74
+     *
75
+     * FIXME: un seul typage (string ?)
76
+     *
77
+     * @var string|false|null
78
+     */
79
+    public $type_requete = null;
80
+
81
+    /**
82
+     * La table est elle optionnelle ?
83
+     *
84
+     * Si oui, aucune erreur ne sera générée si la table demandée n'est pas présente
85
+     */
86
+    public bool $table_optionnelle = false;
87
+
88
+    /**
89
+     * Nom du fichier de connexion
90
+     */
91
+    public string $sql_serveur = '';
92
+
93
+    /**
94
+     * Paramètres de la boucle
95
+     *
96
+     * Description des paramètres passés à la boucle, qui servent ensuite
97
+     * au calcul des critères
98
+     *
99
+     * FIXME: type unique.
100
+     * @var false|array
101
+     *     - false: erreur de syntaxe
102
+     */
103
+    public $param = [];
104
+
105
+    /**
106
+     * Critères de la boucle
107
+     *
108
+     * FIXME: type array unique.
109
+     *
110
+     * @var string|Critere[]
111
+     * - string: phrasage (code brut). Il reste si erreur de critère
112
+     * - array: analyse correcte des critères...
113
+     */
114
+    public $criteres = [];
115
+
116
+    /**
117
+     * Textes insérés entre 2 éléments de boucle (critère inter)
118
+     *
119
+     * @var string[]
120
+     */
121
+    public array $separateur = [];
122
+
123
+    /**
124
+     * Liste des jointures possibles avec cette table
125
+     *
126
+     * Les jointures par défaut de la table sont complétées en priorité
127
+     * des jointures déclarées explicitement sur la boucle
128
+     *
129
+     * @see base_trouver_table_dist()
130
+     */
131
+    public array $jointures = [];
132
+
133
+    /**
134
+     * Jointures explicites avec cette table
135
+     *
136
+     * Ces jointures sont utilisées en priorité par rapport aux jointures
137
+     * normales possibles pour retrouver les colonnes demandées extérieures
138
+     * à la boucle.
139
+     *
140
+     * @var string|bool
141
+     */
142
+    public $jointures_explicites = false;
143
+
144
+    /**
145
+     * Nom de la variable PHP stockant le noms de doublons utilisés "$doublons_index"
146
+     */
147
+    public string $doublons = '';
148
+
149
+    /**
150
+     * Code PHP ajouté au début de chaque itération de boucle.
151
+     *
152
+     * Utilisé entre autre par les critères {pagination}, {n-a,b}, {a/b}...
153
+     */
154
+    public string $partie = '';
155
+
156
+    /**
157
+     * Nombre de divisions de la boucle, d'éléments à afficher,
158
+     * ou de soustractions d'éléments à faire
159
+     *
160
+     * Dans les critères limitant le nombre d'éléments affichés
161
+     * {a,b}, {a,n-b}, {a/b}, {pagination b}, b est affecté à total_parties.
162
+     */
163
+    public string $total_parties = '';
164
+
165
+    /**
166
+     * Code PHP ajouté avant l'itération de boucle.
167
+     *
168
+     * Utilisé entre autre par les critères {pagination}, {a,b}, {a/b}
169
+     * pour initialiser les variables de début et de fin d'itération.
170
+     */
171
+    public string $mode_partie = '';
172
+
173
+    /**
174
+     * Identifiant d'une boucle qui appelle celle-ci de manière récursive
175
+     *
176
+     * Si une boucle est appelée de manière récursive quelque part par
177
+     * une autre boucle comme <BOUCLE_rec(boucle_identifiant) />, cette
178
+     * boucle (identifiant) reçoit dans cette propriété l'identifiant
179
+     * de l'appelant (rec)
180
+     */
181
+    public string $externe = '';
182
+
183
+    // champs pour la construction de la requete SQL
184
+
185
+    /**
186
+     * Liste des champs à récupérer par la boucle
187
+     *
188
+     * Expression 'table.nom_champ' ou calculée 'nom_champ AS x'
189
+     *
190
+     * @var string[]
191
+     */
192
+    public array $select = [];
193
+
194
+    /**
195
+     * Liste des alias / tables SQL utilisées dans la boucle
196
+     *
197
+     * L'index est un identifiant (xx dans spip_xx assez souvent) qui servira
198
+     * d'alias au nom de la table ; la valeur est le nom de la table SQL désirée.
199
+     *
200
+     * L'index 0 peut définir le type de sources de données de l'itérateur DATA
201
+     *
202
+     * @var string[]
203
+     */
204
+    public array $from = [];
205
+
206
+    /**
207
+     * Liste des alias / type de jointures utilisées dans la boucle
208
+     *
209
+     * L'index est le nom d'alias (comme pour la propriété $from), et la valeur
210
+     * un type de jointure parmi 'INNER', 'LEFT', 'RIGHT', 'OUTER'.
211
+     *
212
+     * Lorsque le type n'est pas déclaré pour un alias, c'est 'INNER'
213
+     * qui sera utilisé par défaut (créant donc un INNER JOIN).
214
+     *
215
+     * @var string[]
216
+     */
217
+    public array $from_type = [];
218
+
219
+    /**
220
+     * Liste des conditions WHERE de la boucle
221
+     *
222
+     * Permet de restreindre les éléments retournés par une boucle
223
+     * en fonctions des conditions transmises dans ce tableau.
224
+     *
225
+     * Ce tableau peut avoir plusieurs niveaux de profondeur.
226
+     *
227
+     * Les éléments du premier niveau sont reliés par des AND, donc
228
+     * chaque élément ajouté directement au where par
229
+     * $boucle->where[] = array(...) ou $boucle->where[] = "'expression'"
230
+     * est une condition AND en plus.
231
+     *
232
+     * Par contre, lorsqu'on indique un tableau, il peut décrire des relations
233
+     * internes différentes. Soit $expr un tableau d'expressions quelconques de 3 valeurs :
234
+     * $expr = array(operateur, val1, val2)
235
+     *
236
+     * Ces 3 valeurs sont des expressions PHP. L'index 0 désigne l'opérateur
237
+     * à réaliser tel que :
238
+     *
239
+     * - "'='" , "'>='", "'<'", "'IN'", "'REGEXP'", "'LIKE'", ... :
240
+     *    val1 et val2 sont des champs et valeurs à utiliser dans la comparaison
241
+     *    suivant cet ordre : "val1 operateur val2".
242
+     *    Exemple : $boucle->where[] = array("'='", "'articles.statut'", "'\"publie\"'");
243
+     * - "'AND'", "'OR'", "'NOT'" :
244
+     *    dans ce cas val1 et val2 sont également des expressions
245
+     *    de comparaison complètes, et peuvent être eux-même des tableaux comme $expr
246
+     *    Exemples :
247
+     *    $boucle->where[] = array("'OR'", $expr1, $expr2);
248
+     *    $boucle->where[] = array("'NOT'", $expr); // val2 n'existe pas avec NOT
249
+     *
250
+     * D'autres noms sont possibles pour l'opérateur (le nombre de valeurs diffère) :
251
+     * - "'SELF'", "'SUBSELECT'" : indiquent des sous requêtes
252
+     * - "'?'" : indique une condition à faire évaluer (val1 ? val2 : val3)
253
+     */
254
+    public array $where = [];
255
+
256
+    public array $join = [];
257
+    public array $having = [];
258
+    public $limit = '';
259
+    public array $group = [];
260
+    public array $order = [];
261
+    public array $default_order = [];
262
+    public string $date = 'date';
263
+    public string $hash = '';
264
+    public $in = '';
265
+    public bool $sous_requete = false;
266
+
267
+    /**
268
+     * Code PHP qui sera ajouté en tout début de la fonction de boucle
269
+     *
270
+     * Il sert à insérer le code calculant une hierarchie
271
+     */
272
+    public string $hierarchie = '';
273
+
274
+    // champs pour la construction du corps PHP
275
+
276
+    /**
277
+     * Description des sources de données de la boucle
278
+     *
279
+     * Description des données de la boucle issu de trouver_table
280
+     * dans le cadre de l'itérateur SQL et contenant au moins l'index 'field'.
281
+     *
282
+     * @see base_trouver_table_dist()
283
+     */
284
+    public array $show = [];
285
+
286
+    /**
287
+     * Nom de la table SQL principale de la boucle, sans son préfixe
288
+     */
289
+    public string $id_table = '';
290
+
291
+    /**
292
+     * Nom de la clé primaire de la table SQL principale de la boucle
293
+     */
294
+    public string $primary = '';
295
+
296
+    /**
297
+     * Code PHP compilé de la boucle
298
+     *
299
+     * FIXME: un seul type (string ?)
300
+     *
301
+     * - false: boucle fautive ?
302
+     *
303
+     * @var string|false
304
+     */
305
+    public $return = '';
306
+
307
+    public $numrows = false;
308
+    public $cptrows = false;
309
+
310
+    /**
311
+     * Description du squelette
312
+     *
313
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
314
+     *
315
+     * Peut contenir les index :
316
+     *
317
+     * - nom : Nom du fichier de cache
318
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
319
+     * - sourcefile : Chemin du squelette
320
+     * - squelette : Code du squelette
321
+     * - id_mere : Identifiant de la boucle parente
322
+     * - documents : Pour embed et img dans les textes
323
+     * - session : Pour un cache sessionné par auteur
324
+     * - niv : Niveau de tabulation
325
+     */
326
+    public array $descr = [];
327
+
328
+    /** Numéro de ligne dans le code source du squelette */
329
+    public int $ligne = 0;
330
+
331
+
332
+    /**
333
+     * table pour stocker les modificateurs de boucle tels que tout, plat ...,
334
+     * utilisable par les plugins egalement
335
+     *
336
+     * @var array<string, mixed>
337
+     */
338
+    public array $modificateur = [];
339
+
340
+    /**
341
+     * Type d'itérateur utilisé pour cette boucle
342
+     *
343
+     * - 'SQL' dans le cadre d'une boucle sur une table SQL
344
+     * - 'DATA' pour l'itérateur DATA, ...
345
+     *
346
+     * @var string
347
+     */
348
+    public string $iterateur = ''; // type d'iterateur
349
+
350
+    /**
351
+     * @var array $debug Textes qui seront insérés dans l’entête de boucle du mode debug
352
+     */
353
+    public array $debug = [];
354
+
355
+    /**
356
+     * Index de la boucle dont le champ présent dans cette boucle est originaire,
357
+     * notamment si le champ a été trouve dans une boucle parente
358
+     *
359
+     * Tableau nom du champ => index de boucle
360
+     */
361
+    public array $index_champ = [];
362
+
363
+    /** Résultat de la compilation (?) (sert au débusqueur) */
364
+    public string $code = '';
365
+
366
+    /** Source des filtres (compatibilité) (?) */
367
+    public array $fonctions = [];
368
+
369
+    // obsoletes, conserves provisoirement pour compatibilite
370
+    public $tout = false;
371
+    public $plat = false;
372
+    public $lien = false;
373 373
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Inclure.php 1 patch
Indentation   +52 added lines, -52 removed lines patch added patch discarded remove patch
@@ -7,63 +7,63 @@
 block discarded – undo
7 7
  **/
8 8
 class Inclure
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'include';
10
+    /** Type de noeud */
11
+    public string $type = 'include';
12 12
 
13
-	/**
14
-	 * Nom d'un fichier inclu
15
-	 *
16
-	 * - Objet Texte si inclusion d'un autre squelette
17
-	 * - chaîne si inclusion d'un fichier PHP directement
18
-	 *
19
-	 * @var string|Texte
20
-	 */
21
-	public $texte;
13
+    /**
14
+     * Nom d'un fichier inclu
15
+     *
16
+     * - Objet Texte si inclusion d'un autre squelette
17
+     * - chaîne si inclusion d'un fichier PHP directement
18
+     *
19
+     * @var string|Texte
20
+     */
21
+    public $texte;
22 22
 
23
-	/**
24
-	 * Inutilisé, propriété générique de l'AST
25
-	 *
26
-	 * @var string|array
27
-	 */
28
-	public $avant = '';
23
+    /**
24
+     * Inutilisé, propriété générique de l'AST
25
+     *
26
+     * @var string|array
27
+     */
28
+    public $avant = '';
29 29
 
30
-	/**
31
-	 * Inutilisé, propriété générique de l'AST
32
-	 *
33
-	 * @var string|array
34
-	 */
35
-	public $apres = '';
30
+    /**
31
+     * Inutilisé, propriété générique de l'AST
32
+     *
33
+     * @var string|array
34
+     */
35
+    public $apres = '';
36 36
 
37
-	/** Numéro de ligne dans le code source du squelette */
38
-	public int $ligne = 0;
37
+    /** Numéro de ligne dans le code source du squelette */
38
+    public int $ligne = 0;
39 39
 
40
-	/**
41
-	 * Valeurs des paramètres
42
-	 *
43
-	 * FIXME: type unique.
44
-	 * @var false|array
45
-	 *     - false: erreur de syntaxe
46
-	 */
47
-	public $param = [];
40
+    /**
41
+     * Valeurs des paramètres
42
+     *
43
+     * FIXME: type unique.
44
+     * @var false|array
45
+     *     - false: erreur de syntaxe
46
+     */
47
+    public $param = [];
48 48
 
49
-	/** Source des filtres (compatibilité) (?) */
50
-	public array $fonctions = [];
49
+    /** Source des filtres (compatibilité) (?) */
50
+    public array $fonctions = [];
51 51
 
52
-	/**
53
-	 * Description du squelette
54
-	 *
55
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
56
-	 *
57
-	 * Peut contenir les index :
58
-	 *
59
-	 * - nom : Nom du fichier de cache
60
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
61
-	 * - sourcefile : Chemin du squelette
62
-	 * - squelette : Code du squelette
63
-	 * - id_mere : Identifiant de la boucle parente
64
-	 * - documents : Pour embed et img dans les textes
65
-	 * - session : Pour un cache sessionné par auteur
66
-	 * - niv : Niveau de tabulation
67
-	 */
68
-	public array $descr = [];
52
+    /**
53
+     * Description du squelette
54
+     *
55
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
56
+     *
57
+     * Peut contenir les index :
58
+     *
59
+     * - nom : Nom du fichier de cache
60
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
61
+     * - sourcefile : Chemin du squelette
62
+     * - squelette : Code du squelette
63
+     * - id_mere : Identifiant de la boucle parente
64
+     * - documents : Pour embed et img dans les textes
65
+     * - session : Pour un cache sessionné par auteur
66
+     * - niv : Niveau de tabulation
67
+     */
68
+    public array $descr = [];
69 69
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Texte.php 1 patch
Indentation   +22 added lines, -22 removed lines patch added patch discarded remove patch
@@ -7,30 +7,30 @@
 block discarded – undo
7 7
  **/
8 8
 class Texte
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'texte';
10
+    /** Type de noeud */
11
+    public string $type = 'texte';
12 12
 
13
-	/** Le texte */
14
-	public string $texte;
13
+    /** Le texte */
14
+    public string $texte;
15 15
 
16
-	/**
17
-	 * Contenu avant le texte.
18
-	 *
19
-	 * Vide ou apostrophe simple ou double si le texte en était entouré
20
-	 *
21
-	 * @var string|array
22
-	 */
23
-	public $avant = '';
16
+    /**
17
+     * Contenu avant le texte.
18
+     *
19
+     * Vide ou apostrophe simple ou double si le texte en était entouré
20
+     *
21
+     * @var string|array
22
+     */
23
+    public $avant = '';
24 24
 
25
-	/**
26
-	 * Contenu après le texte.
27
-	 *
28
-	 * Vide ou apostrophe simple ou double si le texte en était entouré
29
-	 *
30
-	 * @var string|array
31
-	 */
32
-	public $apres = '';
25
+    /**
26
+     * Contenu après le texte.
27
+     *
28
+     * Vide ou apostrophe simple ou double si le texte en était entouré
29
+     *
30
+     * @var string|array
31
+     */
32
+    public $apres = '';
33 33
 
34
-	/** Numéro de ligne dans le code source du squelette */
35
-	public int $ligne = 0;
34
+    /** Numéro de ligne dans le code source du squelette */
35
+    public int $ligne = 0;
36 36
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Polyglotte.php 1 patch
Indentation   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -9,16 +9,16 @@
 block discarded – undo
9 9
  **/
10 10
 class Polyglotte
11 11
 {
12
-	/** Type de noeud */
13
-	public string $type = 'polyglotte';
12
+    /** Type de noeud */
13
+    public string $type = 'polyglotte';
14 14
 
15
-	/**
16
-	 * Tableau des traductions possibles classées par langue
17
-	 *
18
-	 * Tableau code de langue => texte
19
-	 */
20
-	public array $traductions = [];
15
+    /**
16
+     * Tableau des traductions possibles classées par langue
17
+     *
18
+     * Tableau code de langue => texte
19
+     */
20
+    public array $traductions = [];
21 21
 
22
-	/** Numéro de ligne dans le code source du squelette */
23
-	public int $ligne = 0;
22
+    /** Numéro de ligne dans le code source du squelette */
23
+    public int $ligne = 0;
24 24
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Contexte.php 1 patch
Indentation   +25 added lines, -25 removed lines patch added patch discarded remove patch
@@ -14,33 +14,33 @@
 block discarded – undo
14 14
  */
15 15
 class Contexte
16 16
 {
17
-	/**
18
-	 * Description du squelette
19
-	 *
20
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
21
-	 *
22
-	 * Peut contenir les index :
23
-	 *
24
-	 * - nom : Nom du fichier de cache
25
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
26
-	 * - sourcefile : Chemin du squelette
27
-	 * - squelette : Code du squelette
28
-	 * - id_mere : Identifiant de la boucle parente
29
-	 * - documents : Pour embed et img dans les textes
30
-	 * - session : Pour un cache sessionné par auteur
31
-	 * - niv : Niveau de tabulation
32
-	 */
33
-	public array $descr = [];
17
+    /**
18
+     * Description du squelette
19
+     *
20
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
21
+     *
22
+     * Peut contenir les index :
23
+     *
24
+     * - nom : Nom du fichier de cache
25
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
26
+     * - sourcefile : Chemin du squelette
27
+     * - squelette : Code du squelette
28
+     * - id_mere : Identifiant de la boucle parente
29
+     * - documents : Pour embed et img dans les textes
30
+     * - session : Pour un cache sessionné par auteur
31
+     * - niv : Niveau de tabulation
32
+     */
33
+    public array $descr = [];
34 34
 
35
-	/** Identifiant de la boucle */
36
-	public string $id_boucle = '';
35
+    /** Identifiant de la boucle */
36
+    public string $id_boucle = '';
37 37
 
38
-	/** Numéro de ligne dans le code source du squelette */
39
-	public int $ligne = 0;
38
+    /** Numéro de ligne dans le code source du squelette */
39
+    public int $ligne = 0;
40 40
 
41
-	/** Langue d'exécution */
42
-	public string $lang = '';
41
+    /** Langue d'exécution */
42
+    public string $lang = '';
43 43
 
44
-	/** Résultat de la compilation: toujours une expression PHP */
45
-	public string $code = '';
44
+    /** Résultat de la compilation: toujours une expression PHP */
45
+    public string $code = '';
46 46
 }
Please login to merge, or discard this patch.