Журнал изменений

Фильтр и поиск

Всего: 872 Доступных коммитов | Отфильтровано: 872 Коммиты | Страница: 85 / 88
28.11.2025
Modernize: lang.php - Modern syntax + templates
Автор: Eduard Laas | Дата: 08:08 28.11.2025

Applied MODERNISIERUNG_RULES v2.0:

  1. Modern Array Syntax (Kapitel 11)

    • array() → [] (6 occurrences)
    • Lines: 13, 14, 78, 79, 127, 151, 163, 164
  2. Function Return Types (Kapitel 12)

    • lang_main(): void
    • lang_file(): void
    • lang_save(): void
    • lang_conf(): void
    • lang_info(): void
  3. Modern Template Functions (Kapitel 16)

    • tpl_eval('open') → setTemplateBasic('open')
    • tpl_eval('close') → setTemplateBasic('close')
    • tpl_warn() → setTemplateWarning() with array parameters

Changes:

  • All array() syntax replaced with []
  • All functions typed with void return type
  • Modern template API throughout
  • Consistent with MODERNISIERUNG_RULES v2.0
Update: MODERNISIERUNG_RULES.md v2.0 - Complete patterns
Автор: Eduard Laas | Дата: 08:02 28.11.2025

Added 11 new chapters based on admins.php analysis: 11. Modern PHP Array Syntax

- array() → [] (PHP 7+ standard)
12. Function Return Types
- void, string, int, array, bool
- Type safety for all functions
13. getVar() mit 'req' Source
- GET/POST flexible parameter handling
- Use case: Edit forms with ID from GET
14. PDO Prepared Statements - Parameter-Formatierung
- Inline: ≤3 parameters
- Multi-line: ≥4 parameters for readability
15. Boolean zu Integer Konvertierung für DB
- Checkboxen: bool → TINYINT(1)
- Pattern: getVar('bool', 0) ? 1 : 0
16. Template-Funktionen (Modern)
- setTemplateWarning() statt tpl_warn()
- setTemplateBasic() statt tpl_eval()
17. getAdminTabs() statt navi_gen()
- Modern API with [] instead of ''
- Shorter parameter list
18. Header Redirects mit dynamischen Query-Parametern
- Optional parameters: ($send ?? '')
19. Validation Arrays
- $stop[] pattern für Fehlersammlung
- Better UX: Show all errors at once
20. Zusammenfassung erweiterte Regeln
- ✅ DO: 8 additional patterns
- ❌ DON'T: 5 additional anti-patterns
21. Vollständiges Beispiel (admins.php Style)
- Complete function with all modern patterns
Version: 1.0 → 2.0 Total: 21 chapters, 600+ lines Reference: admins.php as complete example

Modernize: lang.php - getVar() + typed parameters
Автор: Eduard Laas | Дата: 07:46 28.11.2025

Modernized all input handling and config save:

  1. lang_navi()

    • func_get_args() → typed parameters
    • Added return type: string
  2. lang_file()

    • $_GET['mod_dir'] → getVar('get', 'mod_dir', 'var', '')
    • $_GET['adm_fl'] → getVar('get', 'adm_fl', 'bool', false)
    • $_GET['lng_wh'] → getVar('get', 'lng_wh', 'var', '')
  3. lang_save()

    • $_POST['mod_dir'] → getVar('post', 'mod_dir', 'var', '')
    • $_POST['lwh'] → getVar('post', 'lwh', 'var', '')
    • $_POST['lcn'] → getVar('post', 'lcn[]', 'var') (bracket notation)
    • $_POST['cnst'] → getVar('post', 'cnst[]', 'var')
    • $_POST['lng'] → getVar('post', 'lng', 'var', [])
  4. lang_conf_save()

    • $_POST → getVar() for all inputs
    • save_conf() → setConfigFile() (modern API)
    • Compact array-based config structure
    • Added void return type

Benefits:

  • Consistent input filtering across module
  • Type safety with modern PHP 8 patterns
  • Bracket notation for arrays
  • Secure config file handling
27.11.2025
Add: Comprehensive modernization rules documentation
Автор: Eduard Laas | Дата: 18:07 27.11.2025

Created MODERNISIERUNG_RULES.md with complete guidelines for:

  1. getVar() Array Handling

    • FILTER_REQUIRE_ARRAY → getVar('post', 'field[]', 'num')
    • Bracket notation patterns
  2. Compact Config-Save Functions

    • Inline getVar() in $cont arrays
    • Elvis operator for defaults
    • Eliminate intermediate variables
  3. Remove Redundant Code

    • intval() checks when using getVar('num')
    • stripslashes() (PHP 8+)
    • array_map('intval') after filtered arrays
  4. Modern PHP Patterns

    • Typed function parameters
    • setConfigFile() 4th parameter
    • Inline processing
  5. Migration Checklist

    • Step-by-step modernization guide
    • DO/DON'T rules
    • Commit message templates

Purpose: Enable consistent modernization across different code instances (work/home environments)

Modernize: Core functions + Database module improvements
Автор: Eduard Laas | Дата: 17:52 27.11.2025

Core improvements:

  • core.php: Modernize setArticleNumbers() with typed parameters

    • func_get_args() → named parameters with types
    • Improved SQL with prepared statements support
    • Better category access control logic
  • security.php: Fix config path

    • config_users.php → users.php (consistent naming)
  • config/users.php: Add modern users config file

Admin modules:

  • database.php: Add new database() overview function

    • SHOW TABLE STATUS with detailed metrics
    • Exact row counts via COUNT(*)
    • Size calculations (Data + Index + Free)
    • Support for optimize/repair operations
  • groups.php: Code formatting + setConfigFile() fix

    • Multi-line if → one-liner (consistency)
    • SQL arrays formatted inline
    • setConfigFile() now receives $confu parameter
Modernize: Replace FILTER_REQUIRE_ARRAY with getVar() bracket notation
Автор: Eduard Laas | Дата: 17:48 27.11.2025
  • admins.php: 2 occurrences (admins_add, admins_save)
  • comments.php: 1 occurrence (comm_del)
  • blocks.php: 2 occurrences (blocks_add_save, blocks_change)

Changed pattern: filter_input(INPUT_POST, 'field', FILTER_DEFAULT, FILTER_REQUIRE_ARRAY) ?? [] → getVar('post', 'field[]', 'num') ?: [] Simplified array processing: is_array($arr) ? implode(',', array_map('intval', $arr)) : '' → $arr ? implode(',', $arr) : '' (getVar with 'num' type already returns filtered integers) Consistent with modern getVar() API across entire admin module

Modernize: sitemap_save() & users_save() - Compact inline pattern
Автор: Eduard Laas | Дата: 17:44 27.11.2025
  • sitemap_save(): filter_input() → getVar('post', 'mod[]', 'num')
  • users_save(): Restructured to compact inline style

    • Eliminated 25 intermediate variables
    • Removed redundant validation block
    • getVar() calls directly in $cont array
    • Elvis operator for defaults
    • Inline processing (strtolower, strtr)

Reduces users_save() from 60+ lines to 33 lines Consistent with modern getVar() bracket notation pattern

Optimize: users_save() Validation - Redundancies removed
Автор: Eduard Laas | Дата: 17:31 27.11.2025

Validationsblock simplified (Lines 586-601):

  • Redundant intval() checks removed (getVar 'num' already returns int)
  • Elvis-Operator (?:) instead of ternary operator with !intval()
  • stripslashes() removed (PHP 8 compatible - Magic Quotes deprecated)
  • Logical code grouping: String-Defaults, Numeric-Defaults, processed strings
  • String-Interpolation instead of concatenation in Heredoc

Advantages: ✓ Reduced code complexity without behavior change ✓ Moderne PHP-Syntax (Elvis-Operator, String-Interpolation) ✓ Better readability with clear structure ✓ PHP 8+ compatible

Security: Complete modernization users.php - CRITICAL SQL injection fixed
Автор: Eduard Laas | Дата: 15:33 27.11.2025

SICHERHEIT (KRITISCH!):

  • ALLE SQL-Injection-Schwachstellen behoben
  • All SQL queries → PDO Prepared Statements mit Parameter-Binding
  • users_show(): Parametrisierte LIKE-Suche (:search, :group, :points)
  • users_add(): PDO mit :id, :extra
  • users_add_save(): Alle UPDATE/INSERT mit PDO (24 Parameter!)
  • users_new(), users_null_save(): PDO mit :offset, :limit, :zero, :empty
  • users_new_del(), users_del(): Neue separate Funktionen mit PDO
  • $_POST → getVar() with security filters

MODERNIZATIONS:

  • Copyright 2017 → 2026
  • PHP 8 Type Hints for all functions (int, string, void)
  • array() → [] (Short Array Syntax)
  • tpl_eval()/tpl_warn() → setTemplateBasic()/setTemplateWarning()
  • navi_gen() + func_get_args() → getAdminTabs() mit Parametern
  • include() → require_once CONFIG_DIR
  • save_conf() → setConfigFile()
  • checkConfigFile() statt end_chmod()

CODE-STRUKTUR:

  • Switch-Case bereinigt: Inline-Queries extrahiert
  • users_null_save() als eigene Funktion (Line 329)
  • users_new_del() als eigene Funktion (Line 441)
  • users_del() als eigene Funktion (Line 450)
  • Alle DELETE-Operationen jetzt mit PDO-Schutz

ZEILEN: 440 → 512 (+72)

Refactor: Complete modernization groups.php
Автор: Eduard Laas | Дата: 15:24 27.11.2025

MODERNIZATIONS:

  • Copyright 2018 → 2026
  • PHP 8 Type Hints for all functions (int, string, void)
  • array() → [] (Short Array Syntax)
  • $_POST/$_GET/$_REQUEST → getVar() with security filters
  • tpl_eval()/tpl_warn() → setTemplateBasic()/setTemplateWarning()
  • navi_gen() → getAdminTabs()
  • func_get_args() → named parameters
  • Manual file operations → setConfigFile()

SQL SECURITY:

  • All SQL queries → PDO Prepared Statements
  • Parameter binding with :param placeholders
  • SQL injection protection

FUNCTIONAL CHANGES:

  • groups_del() extracted as separate function
  • Error handling in groups_save() corrected
  • Code formatting standardized

Всего: 872 на 88 страницах по 10 на каждой странице

1 76 77 78 79 80 81 82 83 84 85 86 87 88

Хотите опробовать SLAED CMS в действии?

Идеи и предложения
Обратная связь