Co se chystá v příštích verzích?

by David Grudl 6 months ago in Nette

Co přinesou příští verze Nette Frameworku a jaký je plán pro další vývoj?

Nette je tvořeno řadou knihoven, z nichž některé patří mezi světovou špičku: Latte je nejbezpečnější šablonovací systém, Tracy je mnohými považován za nejpřívětivější debugovací nástroj, Dependency Injection Container patří mezi ty nejpohodlněji použitelné. Spousta konceptů vznikla šťastnou rukou a fungují v prakticky nezměněné podobě už 10 let, například formuláře nebo komponentový systém presenterů.

Nicméně ve všech oblastech je hodně příležitostí co vylepšovat a inovovat. A nápadů je spousta.

Brzký příchod Nette 3

Jelikož podpora Nette 2.4 podle harmonogramu skončila v červnu 2018, tedy po dvou letech od jeho vydání, je hlavní prioritou brzký příchod nové verze Nette 3. Ta bude určená pro PHP 7.1 a bude využívat jeho zásadních novinek, jako:

  • poběží ve striktním režimu
  • kód bude používat skalární typehinty
  • metody budou mít návratové typehinty

Zároveň je záměr připravit:

  • nástroj pro automatizovanou aktualizaci kódu pro novou verzi frameworku (jako tomu bývalo u Nette 0.9 a 2.0)
  • aktualizovat dokumentaci včetně příkladů
  • vygenerovat API dokumentaci na webu https://api.nette.org (v současnosti chybí generátor dokumentace)
  • zajistit kompatibilitu s připravovaným PHP 7.3

Do Nette 3 se mohou zahrnout i některé z plánovaných featur uvedených níže, ale nic, co by oddalovalo vydání. Stabilní verze následovaná po testovacích RC by mohla vyjít v rozmezí října až listopadu 2018 (viz konec článku).

Nette 4

Ihned po vydání Nette 3 by začal vývoj Nette 4. Hlavní novinkou by byla změna vnitřní architektury na tzv. middleware. Komponenta pro zpracování a sanitizaci HTTP požadavku, router, PresenterFactory i samotný presenter by byly vrstvy middleware, mezi které bude možné snadno včlenit další vrstvy, nebo tyhle existující nahradit. Mělo by tak být mnohem snadnější provozování různých aplikací či dokonce frameworků na jednom webu. Každá vrstva by mohla požadavek odmítnout, třeba router by mohl legitimně vyhodit chybu 404. Zároveň by nové řešení mělo být plně kompatibilní se stávajícími presentery, takže bude možné vytvářet aplikace využívající jak nových middleware-presenterů, tak i presenterů současných.

Tato změna architektury vyřeší řadu issues, které ve frameworku existují už dlouho, ale nebylo snadné je zprovodit ze světa:

Další plány

Alespoň bodově se pokusím zmínit další plány pro důležité balíčky. Ve které verzi budou implementované je zatím otevřené.

Application

  • nativní presenter pro REST a API
  • oddělit routování do samostatného balíčku
  • snadnější používání LinkGenerator pod CLI

Application\UI

  • nahradit přímé odesílání HTTP hlaviček (přes HttpResponse) abstrakcí
  • zrychlit generování odkazů kešováním
  • možnost vkládat bloky šablony do komponent
  • CSRF ochrana pro odkazy
  • pokusit se odstranit parametr _fid
  • vyřešit problém s odkazem this nebo formulářem v Error presenteru
  • nativní podpora oprávnění na úrovní presenterů a akcí, makro n:if-allowed
  • cmdline nástroj pro předgenerování presenterů a šablon

DI

  • autodiscovery: automatická registrace služeb pomocí masky, podobně jako u presenterů
  • validovatelné schéma pro formát NEON
  • podpora pro předání pole služeb určitého typu (@param Service[])
  • podpora pro předání pole služeb pomocí tagu
  • umožnit rozšířením registrovat vlastní options (jako inject:, autowired:) v definicích služeb
  • vyřešit problém s prioritou volání rozšíření

Forms

  • vytvořit nativní podporu pro plně dynamické formuláře
  • podpora pro nativní validaci přes AJAX
  • automatická CSRF ochrana
  • provázání na třídy entit, setDefaults() bude přijímat a getValues() vracet objekt entity
  • upravit objektový návrh tak, aby setValue() a getValue() mohly mít správné typehinty
  • připravit ukázku rendereru pro Bootstrap 4

Latte

  • vytvoření nového AST parseru, který posune možnosti maker na novou úroveň
  • možnost spojení šablony se třídu (a jejími properties), aby fungovalo našeptávání nebo statická kontrola i v šabloně
  • implementovat sandbox režim
  • zjednodušit ověřování validity šablon
  • generovat “source map” – kterým bude rozumět Tracy
  • doplnit podporu pro další knihovny a frameworky, vytvořit návody nebo převodníky pro ostatní šablonovací systémy

Tracy

  • podpora source maps

Web a forum

  • v plánu je změnit navigaci a rozčlenění podle jednotlivých komponent
  • nahradit fórum za nějaké novější, už kvůli bezpečnosti
  • a samozřejmě postupné vylepšování dokumentace jako doposud

Je toho prostě opravdu hodně.

Kdy to bude?

Cílem je vydávat novou velkou verzi každý rok na podzim. To bude možné za předpokladu, že se získá plné financování, o což usiluje nový crowdfundingový program. V případě nenaplnění cílů by byl vývoj značně pomalejší a možnosti limitované, proto tento plán berte jako reálný v případě naplnění cílů.

Comments (RSS)

  1. balbos #1

    Ahoj Davide,
    plánuje se vydání Nette 3 ještě tento rok? Díky

    2 months ago

Sign in to submit a comment

Recent posts