Changeset 97273 in spip-zone


Ignore:
Timestamp:
May 7, 2016, 1:31:42 PM (3 years ago)
Author:
marcimat@…
Message:

On ne peut plus créer de champ extra qui serait :

  • un champ déjà déclaré ailleurs
  • un mot clé (My)SQL

\o/

Location:
_plugins_/champs_extras_interface/trunk
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • _plugins_/champs_extras_interface/trunk/lang/iextras_fr.php

    r97236 r97273  
    3636        'erreur_action' => 'Action @action@ inconnue.',
    3737        'erreur_enregistrement_champ' => 'Problème de création du champ extra.',
     38        'erreur_nom_champ_mysql_keyword' => 'Ce nom de champ est un mot clé réservé par SQL et ne peut être utilisé.',
     39        'erreur_nom_champ_utilise' => 'Ce nom de champ est déjà utilisé par SPIP ou un plugin actif.',
    3840        'erreur_format_export' => 'Format d’export @format@ inconnu.',
    3941        'exporter_objet' => 'Exporter tous les champs extras de : @objet@',
  • _plugins_/champs_extras_interface/trunk/paquet.xml

    r97269 r97273  
    22        prefix="iextras"
    33        categorie="outil"
    4         version="3.4.0"
     4        version="3.5.0"
    55        etat="stable"
    66        compatibilite="[3.0.0;3.1.*]"
  • _plugins_/champs_extras_interface/trunk/verifier/nom_champ_extra.php

    r97271 r97273  
    2222 *   Retourne une chaine vide si c'est valide, sinon une chaine expliquant l'erreur.
    2323 */
    24 function verifier_nom_champ_extra_dist($valeur, $options=array()){
     24function verifier_nom_champ_extra_dist($valeur, $options = array()){
     25        include_spip('base/objets');
     26        include_spip('inc/iextras');
     27        include_spip('inc/saisies');
    2528
    2629        $erreur = '';
    27         // tester l'expression
     30
     31        $table = $options['table'];
     32        $valeur = strtolower($valeur);
     33
     34        // Champs extras (interface) / Saisies gérent déjà l'unicité des champs extras
     35        // déclarés dans une table : on ne peut créer 2 champs extras de même nom.
     36        // Ici on vérifie en plus que ce champ n'existe pas hors de champs extras.
     37        $tables_spip = lister_tables_objets_sql($table);
     38        $champs_declares = array_keys($tables_spip['field']);
     39        $champs_declares = array_filter($champs_declares, 'strtolower'); // precaution
     40
     41        $champs_iextras = iextras_champs_extras_definis($table);
     42        $champs_iextras = array_keys(saisies_lister_avec_sql($champs_iextras));
     43        $champs_iextras = array_filter($champs_iextras, 'strtolower'); // precaution
     44
     45        // les champs utilisés en dehors de champs extras, sont la différence
     46        $champs_utilises = array_diff($champs_declares, $champs_iextras);
     47
     48        if (in_array($valeur, $champs_utilises)) {
     49                $erreur = _T('iextras:erreur_nom_champ_utilise');
     50        }
     51
     52        // vérifier que le champ n'est pas un mot clé sql
     53        if (!$erreur) {
     54                if (in_array(strtoupper($valeur), iextras_sql_reserved_keywords())) {
     55                        $erreur = _T('iextras:erreur_nom_champ_mysql_keyword');
     56                }
     57        }
     58
     59        // vérifier que le champ est bien formaté  (expression régulière)
    2860        if (!$erreur) {
    2961                $verifier = charger_fonction('verifier', 'inc');
     
    3668
    3769
     70
     71function iextras_sql_reserved_keywords() {
     72        return array (
     73                'ACCESSIBLE', 'ADD', 'ALL', 'ALTER', 'ANALYZE', 'AND', 'AS', 'ASC', 'ASENSITIVE',
     74
     75                'BEFORE', 'BETWEEN', 'BIGINT', 'BINARY', 'BLOB', 'BOTH', 'BY',
     76
     77                'CALL', 'CASCADE', 'CASE', 'CHANGE', 'CHAR', 'CHARACTER', 'CHECK', 'COLLATE', 'COLUMN',
     78                'CONDITION', 'CONSTRAINT', 'CONTINUE', 'CONVERT', 'CREATE', 'CROSS',
     79                'CURRENT_DATE', 'CURRENT_TIME', 'CURRENT_TIMESTAMP', 'CURRENT_USER', 'CURSOR',
     80
     81                'DATABASE', 'DATABASES', 'DAY_HOUR', 'DAY_MICROSECOND', 'DAY_MINUTE',
     82                'DAY_SECOND', 'DEC', 'DECIMAL', 'DECLARE', 'DEFAULT', 'DELAYED', 'DELETE', 'DESC', 'DESCRIBE',
     83                'DETERMINISTIC', 'DISTINCT', 'DISTINCTROW', 'DIV', 'DOUBLE', 'DROP', 'DUAL',
     84
     85                'EACH', 'ELSE', 'ELSEIF', 'ENCLOSED', 'ESCAPED', 'EXISTS', 'EXIT', 'EXPLAIN',
     86
     87                'FALSE', 'FETCH', 'FLOAT', 'FLOAT4', 'FLOAT8', 'FOR', 'FORCE', 'FOREIGN', 'FROM', 'FULLTEXT',
     88
     89                'GENERATED[i]', 'GET', 'GRANT', 'GROUP',
     90
     91                'HAVING', 'HIGH_PRIORITY', 'HOUR_MICROSECOND', 'HOUR_MINUTE', 'HOUR_SECOND',
     92
     93                'IF', 'IGNORE', 'IN', 'INDEX', 'INFILE', 'INNER', 'INOUT', 'INSENSITIVE', 'INSERT',
     94                'INT', 'INT1', 'INT2', 'INT3', 'INT4', 'INT8', 'INTEGER', 'INTERVAL', 'INTO',
     95                'IO_AFTER_GTIDS', 'IO_BEFORE_GTIDS', 'IS', 'ITERATE',
     96
     97                'JOIN',
     98
     99                'KEY', 'KEYS', 'KILL',
     100
     101                'LEADING', 'LEAVE', 'LEFT', 'LIKE', 'LIMIT', 'LINEAR', 'LINES', 'LOAD',
     102                'LOCALTIME', 'LOCALTIMESTAMP', 'LOCK', 'LONG', 'LONGBLOB', 'LONGTEXT', 'LOOP', 'LOW_PRIORITY',
     103
     104                'MASTER_BIND', 'MASTER_SSL_VERIFY_SERVER_CERT', 'MATCH', 'MAXVALUE',
     105                'MEDIUMBLOB', 'MEDIUMINT', 'MEDIUMTEXT', 'MIDDLEINT', 'MINUTE_MICROSECOND', 'MINUTE_SECOND', 'MOD', 'MODIFIES',
     106
     107                'NATURAL', 'NOT', 'NO_WRITE_TO_BINLOG', 'NULL', 'NUMERIC',
     108
     109                'ON', 'OPTIMIZE', 'OPTIMIZER_COSTS[r]', 'OPTION', 'OPTIONALLY', 'OR', 'ORDER', 'OUT', 'OUTER', 'OUTFILE',
     110
     111                'PARTITION', 'PRECISION', 'PRIMARY', 'PROCEDURE', 'PURGE',
     112
     113                'RANGE', 'READ', 'READS', 'READ_WRITE', 'REAL', 'REFERENCES', 'REGEXP',
     114                'RELEASE', 'RENAME', 'REPEAT', 'REPLACE', 'REQUIRE', 'RESIGNAL', 'RESTRICT', 'RETURN', 'REVOKE', 'RIGHT', 'RLIKE',
     115
     116                'SCHEMA', 'SCHEMAS', 'SECOND_MICROSECOND', 'SELECT', 'SENSITIVE', 'SEPARATOR', 'SET', 'SHOW', 'SIGNAL', 'SMALLINT',
     117                'SPATIAL', 'SPECIFIC', 'SQL', 'SQLEXCEPTION', 'SQLSTATE', 'SQLWARNING', 'SQL_BIG_RESULT', 'SQL_CALC_FOUND_ROWS',
     118                'SQL_SMALL_RESULT', 'SSL', 'STARTING', 'STORED[ac]', 'STRAIGHT_JOIN',
     119
     120                'TABLE', 'TERMINATED', 'THEN', 'TINYBLOB', 'TINYINT', 'TINYTEXT', 'TO', 'TRAILING', 'TRIGGER', 'TRUE',
     121
     122                'UNDO', 'UNION', 'UNIQUE', 'UNLOCK', 'UNSIGNED', 'UPDATE', 'USAGE', 'USE', 'USING', 'UTC_DATE', 'UTC_TIME', 'UTC_TIMESTAMP',
     123
     124                'VALUES', 'VARBINARY', 'VARCHAR', 'VARCHARACTER', 'VARYING', 'VIRTUAL[ae]',
     125
     126                'WHEN', 'WHERE', 'WHILE', 'WITH', 'WRITE',
     127
     128                'XOR',
     129
     130                'YEAR_MONTH',
     131
     132                'ZEROFILL',
     133        );
     134}
Note: See TracChangeset for help on using the changeset viewer.