PHPackages                             walkweb/dw-framework - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Framework](/categories/framework)
4. /
5. walkweb/dw-framework

ActiveLibrary[Framework](/categories/framework)

walkweb/dw-framework
====================

Micro MVC Framework

10[1 PRs](https://github.com/WalkWeb/DW-Framework/pulls)PHPCI passing

Since Jan 16Pushed 3mo agoCompare

[ Source](https://github.com/WalkWeb/DW-Framework)[ Packagist](https://packagist.org/packages/walkweb/dw-framework)[ RSS](/packages/walkweb-dw-framework/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependenciesVersions (2)Used By (0)

DW-Framework – минималистичный и производительный MVC-фреймворк

Он был написан для следующих целей:

- «Хочешь разобраться как что-то работает – напиши свой аналог с нуля». Мне было интересно как работают MVC-фреймворки, и чтобы разобраться в этом я написал свой 😈
- Получить фреймворк с максимальной производительностью – по этой причине не используются интерфейсы, не используются стандартные [PSR Request/Response](https://www.php-fig.org/psr/psr-7/), переменные окружения (конфиг сделан через константы) и прочее.
- В качестве отдыха от навороченной и тяжелой связки Symfony+Doctrine с которой работаю на обычной работе уже последние 5 лет.

Если вам интересно посмотреть пример качественного ООП — загляните в [Battle Module](https://github.com/WalkWeb/Battle-Module). В противоположность этому проекту, там я заморочился с качественным ООП, но производительность, разумеется, страдает (чем больше ООП-наворотов и абстракций — тем хуже производительность).

Установка
=========

[](#установка)

`cd /var/www/`

`git clone https://github.com/WalkWeb/DW-Framework.git dw-framework.loc`

`cd dw-framework.loc`

`composer i`

Копируем `config.php` переименовываем в `config.local.php` и указываем нужные параметры

Выполнение миграций и фикстур:

`make migration`

`make fixture`

Далее необходимо настроить локальный домен (nginx/apache/встроенный веб-сервер в php — на ваш выбор)

Запуск тестов
=============

[](#запуск-тестов)

Запуск тестов:

`make test`

Запуск покрытия кода тестами:

`make coverage`

Результат можно посмотреть в директории html.

Демо-пользователь
=================

[](#демо-пользователь)

login: Login-1

password: 12345

Покрытие тестами
================

[](#покрытие-тестами)

[![alt text](public/images/test-coverage.png)](public/images/test-coverage.png)

Планы
=====

[](#планы)

- Перевод README.md и всех комментариев в коде на английский
- Добавить phpstan
- Добавить проверку code style

КлассКонтейнерСтатикаПримечаниеCaptcha+Connection+Cookie+Csrf+Logger+MigrationRuntime+Session+Убрать статикуValidator+Request+Mailer+P.S.
----

[](#ps)

[Первая версия самописного микрофреймворка](https://github.com/WalkWeb/TickTackToe), просто чтобы ужаснуться :)

###  Health Score

20

—

LowBetter than 14% of packages

Maintenance53

Moderate activity, may be stable

Popularity2

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity18

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/9022ff0a6ebacd1fbba1b715b2881f078468141f5b4d1dd1f4d33e27266d11fb?d=identicon)[WalkWeb](/maintainers/WalkWeb)

---

Top Contributors

[![WalkWeb](https://avatars.githubusercontent.com/u/25296122?v=4)](https://github.com/WalkWeb "WalkWeb (257 commits)")

---

Tags

frameworkmicroframework

### Embed Badge

![Health badge](/badges/walkweb-dw-framework/health.svg)

```
[![Health](https://phpackages.com/badges/walkweb-dw-framework/health.svg)](https://phpackages.com/packages/walkweb-dw-framework)
```

###  Alternatives

[laravel/passport

Laravel Passport provides OAuth2 server support to Laravel.

3.4k85.0M532](/packages/laravel-passport)[nolimits4web/swiper

Most modern mobile touch slider and framework with hardware accelerated transitions

41.8k177.2k1](/packages/nolimits4web-swiper)[laravel/dusk

Laravel Dusk provides simple end-to-end testing and browser automation.

1.9k36.7M259](/packages/laravel-dusk)[laravel/prompts

Add beautiful and user-friendly forms to your command-line applications.

712181.8M596](/packages/laravel-prompts)[cakephp/chronos

A simple API extension for DateTime.

1.4k47.7M121](/packages/cakephp-chronos)[laravel/pail

Easily delve into your Laravel application's log files directly from the command line.

91545.3M590](/packages/laravel-pail)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
