voral / joke
A minimal PHP microframework with manual routing and dependency injection container.
Installs: 9
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/voral/joke
Requires
- php: ^8.4
Requires (Dev)
- php-mock/php-mock-phpunit: ^2.14
- phpunit/phpunit: ^12.5
- voral/version-increment: ^3.2
This package is auto-updated.
Last update: 2026-02-20 05:15:03 UTC
README
Joke — это учебный микрофреймворк с ручной маршрутизацией и встроенным DI-контейнером. Он разрабатывается в рамках образовательного челленджа и не претендует на конкуренцию с промышленными решениями, такими как Laravel или Symfony.
Несмотря на скромный функционал, реализуемые компоненты стремятся быть надёжными, тестируемыми и пригодными для использования в реальных проектах — в том числе в обучающих или прототипных задачах.
По условиям челенджа: не использовать существующие решения (кромe composer, PHPUnit, voral/version-increment)
Требования
- PHP 8.4+
- Composer
Реализованная функциональность
- Ручная маршрутизация HTTP-запросов
- DI-контейнер с поддержкой автовайринга параметров
- Система middleware (блокирующие и неблокирующие)
- Управление сессиями (включая поддержку «неблокирующего» режима — данные сессии считываются в начале обработки запроса, после чего сессия немедленно закрывается, позволяя другим запросам от того же пользователя работать параллельно без ожидания завершения текущего.)
- Обработка ошибок и исключений
Как начать
Самый простой способ начать — использовать официальный скелетон:
composer create-project voral/joke-minimal my-app
cd my-app
composer run dev
Приложение будет доступно по адресу: http://localhost:8000
Документация
Документация по фреймворку размещена здесь
Основные этапы челенджа
- Создание фреймворка
- Реализация маршрутизации
- Реализация сервисный контейнер
- Консольная система команд
- Авторизация
- Валидация данных
- Обработка ошибок
- Логирование
- Создание построителя SQL запросов
- Миграции
- Настраиваемое окружение через .env файл
- Создание шаблонизатора
- Создание базового шаблонизатора HTML
- Рендер Markdown файлов для быстрого создания документационных сайтов из .md файлов.
- Рендер Swagger yaml файлов для автоматического отображения OpenAPI-спецификаций без внешних UI (например, без Swagger UI)
- Создание приложения форума
- Создание скелетонов
- REST API приложения
- Приложения веб представления Markdown файлов
Joke — A Micro Framework for PHP
Joke is an educational microframework featuring manual routing and a built-in DI container. It is developed as part of a learning challenge and is not intended to compete with production-grade frameworks like Laravel or Symfony.
Despite its limited scope, the implemented components aim to be reliable, testable, and suitable for real-world use—even in educational or prototyping scenarios.
As per the challenge rules, no existing solutions may be used except for Composer, PHPUnit, and voral/version-increment.
Requirements
- PHP 8.4+
- Composer
Implemented Features
- Manual HTTP request routing
- DI container with automatic parameter wiring
- Middleware system (blocking and non-blocking)
- Session management, including non-blocking mode — session data is read at the beginning of request processing and the session is immediately closed, allowing concurrent requests from the same user to proceed without waiting for the current request to finish
- Error and exception handling
Getting Started
The easiest way to get started is to use the official skeleton:
composer create-project voral/joke-minimal my-app
cd my-app
composer run dev
Your application will be available at: http://localhost:8000
Challenge Roadmap
-
Framework Core
- Implement routing
- Implement service container
- Console command system
- Authentication
- Data validation
- Error handling
- Logging
- SQL query builder
- Database migrations
- Environment configuration via
.envfile
-
Template Engine
- Basic HTML template engine
- Render Markdown files for quickly generating documentation sites from
.mdfiles - Render Swagger YAML files to display OpenAPI specifications without external UIs (e.g., without Swagger UI)
-
Build a Forum Application
-
Create Project Skeletons
- For REST API applications
- For documentation sites based on Markdown files