Если хочешь, чтобы код всегда был аккуратным и соответствовал стандартам — не делай это вручную, настрой автоформатирование в IDE!
🔍 Как это работает:
Используй PSR-12 стандарт для форматирования кода.
Подключи php-cs-fixer к проекту:
composer require --dev friendsofphp/php-cs-fixer
Настрой IDE (PhpStorm, VS Code) так, чтобы код автоматически форматировался при сохранении файла.
./vendor/bin/php-cs-fixer fix
⚡️ Почему это круто:
✅ Все файлы соответствуют стандарту без ручной правки
✅ Экономия времени на ревью и исправления стиля
✅ Чистый и читаемый код для всей команды
💡 Совет: можно настроить pre-commit hook через Composer, чтобы перед каждым коммитом код автоматически форматировался:
"noscripts": {
"pre-commit": "php-cs-fixer fix"
}Теперь каждая сохранённая строка кода и каждый коммит будут соответствовать стандартам без лишней работы.
Библиотека пхпшника
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥8🥱3👍2👏1😁1
💥 Октябрь — месяц апгрейда!
До конца этого месяца действует скидка 40% на все курсы Proglib Academy(кроме AI-агентов, ML для старта и математики) .
Под акцию попал и наш хит — курс «Алгоритмы и структуры данных».
👨💻 Он подойдёт джунам, мидлам и всем, кто хочет писать код осознанно, а не наугад.
👨🏫 Преподаватели — инженеры из Яндекса и ВШЭ.
🎓 Сертификат по итогам обучения — в портфолио.
➖ 47 видеоуроков и 150 практических задач;
➖ поддержка преподавателей и чат;
➖ доступ к материалам на 12 месяцев.
Полная программа курса тут 👈
👉 Остальные курсы
До конца этого месяца действует скидка 40% на все курсы Proglib Academy
Под акцию попал и наш хит — курс «Алгоритмы и структуры данных».
👨💻 Он подойдёт джунам, мидлам и всем, кто хочет писать код осознанно, а не наугад.
👨🏫 Преподаватели — инженеры из Яндекса и ВШЭ.
🎓 Сертификат по итогам обучения — в портфолио.
➖ 47 видеоуроков и 150 практических задач;
➖ поддержка преподавателей и чат;
➖ доступ к материалам на 12 месяцев.
Полная программа курса тут 👈
👉 Остальные курсы
🐘 PHP для начинающих: жизненный цикл приложений на Laravel
Статья объясняет жизненный цикл Laravel (Laravel Lifecycle) — то есть путь, который проходит HTTP-запрос от пользователя до формирования ответа в браузере.
Она предназначена для начинающих PHP-разработчиков и часто встречается на собеседованиях.
Ключевые идеи:
Laravel Lifecycle — это последовательность шагов, через которые проходит запрос внутри фреймворка.
Основные этапы:
Service Providers — инициализируют основные функции: БД, кэш, маршрутизацию, аутентификацию.
Middleware — фильтры, проверяющие запросы (например, авторизацию).
Routing и Controller — определяют, какой метод контроллера должен обработать запрос.
Models и Database — при необходимости извлекаются данные из БД.
View и Response — данные преобразуются в HTML-ответ и отправляются пользователю.
Авторы объясняют это на примере ресторана:
вход —
кухня —
повар — контроллер,
блюдо — ответ пользователю.
Понимание жизненного цикла Laravel помогает лучше дебажить, писать оптимизированный код и осознать, как фреймворк превращает обычный HTTP-запрос в готовую HTML-страницу.
👉 Читать статью
Библиотека пхпшника
#php_азбука
Статья объясняет жизненный цикл Laravel (Laravel Lifecycle) — то есть путь, который проходит HTTP-запрос от пользователя до формирования ответа в браузере.
Она предназначена для начинающих PHP-разработчиков и часто встречается на собеседованиях.
Ключевые идеи:
Laravel Lifecycle — это последовательность шагов, через которые проходит запрос внутри фреймворка.
Основные этапы:
public/index.php — точка входа, с которой всё начинается.bootstrap/app.php — создаётся экземпляр приложения и подгружается ядро (Kernel).Service Providers — инициализируют основные функции: БД, кэш, маршрутизацию, аутентификацию.
Middleware — фильтры, проверяющие запросы (например, авторизацию).
Routing и Controller — определяют, какой метод контроллера должен обработать запрос.
Models и Database — при необходимости извлекаются данные из БД.
View и Response — данные преобразуются в HTML-ответ и отправляются пользователю.
Авторы объясняют это на примере ресторана:
вход —
index.php,кухня —
app.php,повар — контроллер,
блюдо — ответ пользователю.
Понимание жизненного цикла Laravel помогает лучше дебажить, писать оптимизированный код и осознать, как фреймворк превращает обычный HTTP-запрос в готовую HTML-страницу.
👉 Читать статью
Библиотека пхпшника
#php_азбука
❤3👍2
Говорят, айтишника можно опознать по двум признакам: тёмная тема в IDE и 100+ вкладок в браузере, которые съели всю ОЗУ. Давайте проверим, на чём всё это крутится.
Расскажите в комментариях, какой у вас рабочий ноутбук? Что за модель, какой чип и сколько гигабайт памяти спасают вас от коллапса системы?
Please open Telegram to view this post
VIEW IN TELEGRAM
🥱4
❗ Laravel-совет
Директива
В нашем примере директива
Библиотека пхпшника
#vardump
Директива
@env_required() позволяет проверять, что переменная среды установлена и имеет значение, отличное от null. Она может быть полезна для обеспечения того, чтобы приложение работало правильно только при наличии определенных переменных среды.В нашем примере директива
@env_required() используется для проверки переменной среды APP_KEY. Если переменная не установлена, будет выброшено исключение.Библиотека пхпшника
#vardump
👍6❤3👾1
👍19🥰3
Forwarded from Книги для программистов
В книге автор собрал все ключевые идеи реляционных СУБД — от понятия данных до логики работы транзакций. Тебя ждет фундаментальная теория и наглядная практика проектирования БД:
Please open Telegram to view this post
VIEW IN TELEGRAM
❤6
💻 Подборка новостей по PHP за неделю:
🔹 PHP 8.5.0 RC2 — второй релиз-кандидат доступен для тестирования. Выход финальной версии всё ближе: разработчиков призывают проверять совместимость и сообщать о багах.
🔹 Closures в константных выражениях (PHP 8.5) — теперь можно использовать замыкания прямо в константах и как значения по умолчанию (например, в атрибутах). Это существенно расширяет выразительность языка.
🔹 Новый URI-экстеншен в PHP 8.5 — в стандартную библиотеку добавлен полноценный парсер URI, соответствующий RFC 3986 и WHATWG URL. Больше не нужно сторонних пакетов для корректного парсинга URL.
🔹 Laravel 12.34 — появился failover queue driver для отказоустойчивости очередей, улучшен полнотекстовый поиск в Scout и добавлена возможность откладывать выполнение HTTP batch-запросов.
🔹 Symfony 13–19 октября — продолжается полировка релизов 7.4 и 8.0, запущен сайт к 20-летию Symfony и опубликована первая статья серии New in Symfony 7.4.
Библиотека пхпшника
#свежак
🔹 PHP 8.5.0 RC2 — второй релиз-кандидат доступен для тестирования. Выход финальной версии всё ближе: разработчиков призывают проверять совместимость и сообщать о багах.
🔹 Closures в константных выражениях (PHP 8.5) — теперь можно использовать замыкания прямо в константах и как значения по умолчанию (например, в атрибутах). Это существенно расширяет выразительность языка.
🔹 Новый URI-экстеншен в PHP 8.5 — в стандартную библиотеку добавлен полноценный парсер URI, соответствующий RFC 3986 и WHATWG URL. Больше не нужно сторонних пакетов для корректного парсинга URL.
🔹 Laravel 12.34 — появился failover queue driver для отказоустойчивости очередей, улучшен полнотекстовый поиск в Scout и добавлена возможность откладывать выполнение HTTP batch-запросов.
🔹 Symfony 13–19 октября — продолжается полировка релизов 7.4 и 8.0, запущен сайт к 20-летию Symfony и опубликована первая статья серии New in Symfony 7.4.
Библиотека пхпшника
#свежак
😍3❤1👏1
💡 Совет по Laravel: Результат команды
Знаете ли вы, что Laravel позволяет определять колбеки, которые будут выполняться в зависимости от результата запланированной задачи? Это помогает регистрировать сбои или выполнять связанные действия в случае успеха 🚀
Библиотека пхпшника
#vardump
Знаете ли вы, что Laravel позволяет определять колбеки, которые будут выполняться в зависимости от результата запланированной задачи? Это помогает регистрировать сбои или выполнять связанные действия в случае успеха 🚀
Библиотека пхпшника
#vardump
🧠 Готовишься к собесам, а ноутбук еле тянет IDE?
Самое время прокачать скиллы и апгрейднуть железо!
Proglib Academy разыгрывает MacBook Pro 14 (M3 Pro, 36 GB, 1 TB SSD) 💻
Купи любой наш курс до 15 ноября → пройди 2 недели обучения → напиши куратору #розыгрыш. Всё, ты в игре!
📚 Среди курсов:
▫️ Алгоритмы и структуры данных — топ для подготовки к собесам в Яндекс и FAANG.
▫️ Архитектуры и шаблоны проектирования — чтобы думать как senior.
▫️ Python, математика для DS, основы IT и другие направления.
👉 Принять участие
Самое время прокачать скиллы и апгрейднуть железо!
Proglib Academy разыгрывает MacBook Pro 14 (M3 Pro, 36 GB, 1 TB SSD) 💻
Купи любой наш курс до 15 ноября → пройди 2 недели обучения → напиши куратору #розыгрыш. Всё, ты в игре!
📚 Среди курсов:
▫️ Алгоритмы и структуры данных — топ для подготовки к собесам в Яндекс и FAANG.
▫️ Архитектуры и шаблоны проектирования — чтобы думать как senior.
▫️ Python, математика для DS, основы IT и другие направления.
👉 Принять участие
😁4👾1
🧩 Enums в Laravel: конец магическим строкам
Если вы когда-либо писали
С выходом Laravel 12 они перестали быть просто “новинкой языка” — это теперь must-have инструмент для чистого, безопасного и предсказуемого кода.
💡 Зачем они нужны
Enums заменяют беспорядок из строк, флагов и констант.
— гарантируют типобезопасность: вы даёте переменной не просто строку, а определённое значение из “набора”.
— код становится само-документируемым: “это состояние” видно из названия enum-класса, а не приходится гуглить что означают разные статусы.
— легче поддержка: менее вероятно, что в коде появится “typo” или неизвестное состояние.
— интеграция с Laravel становится проще: например, enum-кастинг колонок модели, валидация enum-значения — меньше “шаблонного” кода.
🛠 Как мыслить без кода
Представьте: у вас есть список чётких, фиксированных значений — например, “ожидает”, “в работе”, “завершено”, “отменено”.
Раньше: множество строк, массивов, проверки типа
С Enums: “статус задачи” — это не просто строка, это экземпляр типа, который не может быть чем-то другим.
База данных остаётся привычной, интерфейсы — знакомыми, но логика приложения читается лучше.
📊 Что принесёт использование Enums
— меньше ошибок на проде (например: “неверное состояние”),
— лучше автодополнение и подсказки в IDE,
— меньше “магических строк” в коде,
— единое место для описания значений и поведения (если enum-тип расширить методами типа “label” или “сортировка”).
Разработчики отмечают, что применение Enums делает код более выразительным и легче рефакторить.
В контексте Laravel 12 это уже не эксперимент — это один из рекомендуемых подходов.
🎯 Когда начинать?
Если вы ещё не используете Enums, то:
— при новом проекте на Laravel 12/13 — смело включайте их “с самого начала”.
— при рефакторинге старого проекта — начните с ключевых участков: статусы, роли, состояние процесса.
— если используете строковые флаги или массивы “констант” — обратите внимание: Enums может стать шагом к более стабильной архитектуре.
📣 Общее настроение
Enums — это не просто синтаксический сахар. Это шаг к более выразительному, поддерживаемому и устойчивому коду.
Если вы программист-artisan, стремящийся не просто “сделать” приложение, а выстроить его красиво и последовательно — Enums это инструмент, который стоит в арсенале.
🔗 Medium
Библиотека пхпшника
Если вы когда-либо писали
status = 'pending' и потом искали, где же опечатались или где вдруг “Pending” и “pending” трактуются по-разному — добро пожаловать в мир нативных Enums в PHP 8.1.С выходом Laravel 12 они перестали быть просто “новинкой языка” — это теперь must-have инструмент для чистого, безопасного и предсказуемого кода.
💡 Зачем они нужны
Enums заменяют беспорядок из строк, флагов и констант.
— гарантируют типобезопасность: вы даёте переменной не просто строку, а определённое значение из “набора”.
— код становится само-документируемым: “это состояние” видно из названия enum-класса, а не приходится гуглить что означают разные статусы.
— легче поддержка: менее вероятно, что в коде появится “typo” или неизвестное состояние.
— интеграция с Laravel становится проще: например, enum-кастинг колонок модели, валидация enum-значения — меньше “шаблонного” кода.
🛠 Как мыслить без кода
Представьте: у вас есть список чётких, фиксированных значений — например, “ожидает”, “в работе”, “завершено”, “отменено”.
Раньше: множество строк, массивов, проверки типа
if status == 'completed'.С Enums: “статус задачи” — это не просто строка, это экземпляр типа, который не может быть чем-то другим.
База данных остаётся привычной, интерфейсы — знакомыми, но логика приложения читается лучше.
📊 Что принесёт использование Enums
— меньше ошибок на проде (например: “неверное состояние”),
— лучше автодополнение и подсказки в IDE,
— меньше “магических строк” в коде,
— единое место для описания значений и поведения (если enum-тип расширить методами типа “label” или “сортировка”).
Разработчики отмечают, что применение Enums делает код более выразительным и легче рефакторить.
В контексте Laravel 12 это уже не эксперимент — это один из рекомендуемых подходов.
🎯 Когда начинать?
Если вы ещё не используете Enums, то:
— при новом проекте на Laravel 12/13 — смело включайте их “с самого начала”.
— при рефакторинге старого проекта — начните с ключевых участков: статусы, роли, состояние процесса.
— если используете строковые флаги или массивы “констант” — обратите внимание: Enums может стать шагом к более стабильной архитектуре.
📣 Общее настроение
Enums — это не просто синтаксический сахар. Это шаг к более выразительному, поддерживаемому и устойчивому коду.
Если вы программист-artisan, стремящийся не просто “сделать” приложение, а выстроить его красиво и последовательно — Enums это инструмент, который стоит в арсенале.
🔗 Medium
Библиотека пхпшника
👍6❤1
Forwarded from Библиотека задач по PHP | тесты, код, задания
Архитектура — Dependency Injection & SOLID
Какой принцип SOLID здесь соблюдён?
Какой принцип SOLID здесь соблюдён?
Forwarded from Библиотека задач по PHP | тесты, код, задания
Какой принцип SOLID здесь соблюдён?
Anonymous Quiz
15%
Single Responsibility
9%
Open/Closed
54%
Dependency Inversion
22%
Interface Segregation
😁8🥱1
🧩 Composer noscripts vs Makefile — что выбрать для PHP-проектов?
Каждый из нас хоть раз приходил в проект и задавал одни и те же вопросы:
🌀 «Как тут запускаются тесты?»
🌀 «Какой линтер у вас — Pint или PHP-CS-Fixer?»
🌀 «Где вообще список команд?»
Хаос в командах — типичная боль, особенно когда у каждого своя консольная магия.
Решение простое: централизуйте команды качества кода.
🔹 Composer noscripts — встроенный, лёгкий, без зависимостей.
Идеален для небольших или чисто PHP-проектов.
🔹 Makefile — гибкий, мощный, автоматизация на стероидах.
Подходит, если в проекте намешано PHP + JS + Docker + CI/CD.
📊 Когда что выбрать
— Monorepo или мультистек → Makefile
— Малый проект или пакет → Composer noscripts
💡 Главное — не инструмент, а принцип:
👉 Читать статью
Библиотека пхпшника
#элементарный_выбор
Каждый из нас хоть раз приходил в проект и задавал одни и те же вопросы:
🌀 «Как тут запускаются тесты?»
🌀 «Какой линтер у вас — Pint или PHP-CS-Fixer?»
🌀 «Где вообще список команд?»
Хаос в командах — типичная боль, особенно когда у каждого своя консольная магия.
Решение простое: централизуйте команды качества кода.
🔹 Composer noscripts — встроенный, лёгкий, без зависимостей.
Идеален для небольших или чисто PHP-проектов.
composer all-check — и всё: Pint, Rector, PHPStan, тесты.🔹 Makefile — гибкий, мощный, автоматизация на стероидах.
Подходит, если в проекте намешано PHP + JS + Docker + CI/CD.
make all-check — и порядок наведен.📊 Когда что выбрать
— Monorepo или мультистек → Makefile
— Малый проект или пакет → Composer noscripts
💡 Главное — не инструмент, а принцип:
сделай запуск проверок простым, чтобы никто не ленился их запускать.
👉 Читать статью
Библиотека пхпшника
#элементарный_выбор
Парсер JSON
Парсер с нулевыми зависимостями для чтения больших JSON из любого источника с эффективным использованием памяти.
🔗 Github
Библиотека пхпшника
#инструменты
Парсер с нулевыми зависимостями для чтения больших JSON из любого источника с эффективным использованием памяти.
🔗 Github
Библиотека пхпшника
#инструменты
👍6🔥2
🚀 How to: Создать Telegram-бота и отправить сообщения с помощью Laravel 12
В этой статье рассматривается процесс создания Telegram-бота и его интеграции с Laravel 12. Пройдите пошаговую инструкцию по получению API токена, настройке пакета
👉 Ссылка на статью
Библиотека пхпшника
В этой статье рассматривается процесс создания Telegram-бота и его интеграции с Laravel 12. Пройдите пошаговую инструкцию по получению API токена, настройке пакета
irazasyed/telegram-bot-sdk и отправке сообщений через вашего бота. Этот гайд подойдет как для новичков, так и для опытных разработчиков, желающих добавить функциональность Telegram в свои приложения и улучшить взаимодействие с пользователями.👉 Ссылка на статью
Библиотека пхпшника
👍3😁1
🎁 Конкурс от Proglib Academy!
Кстати, если кто-то ещё не в курсе — у нас тут раздают MacBook Pro 14.
Да-да, не шутка, настоящий, железный, с M3 Pro
Но! Чтобы успеть пройти 2 недели обучения к 15 ноября, курс нужно взять до конца октября — и сейчас на всё скидка 40%.
Чтобы поучаствовать, нужно:
1️⃣ Покупаешь любой курс до конца октября;
2️⃣ Проходишь 2 недели обучения к 15 ноября;
3️⃣ Написать куратору в чат #розыгрыш.
До 15 ноября, потом всё — поезд (и макбук) уйдёт.
👉 Участвовать в розыгрыше
Кстати, если кто-то ещё не в курсе — у нас тут раздают MacBook Pro 14.
Да-да, не шутка, настоящий, железный, с M3 Pro
Но! Чтобы успеть пройти 2 недели обучения к 15 ноября, курс нужно взять до конца октября — и сейчас на всё скидка 40%.
Чтобы поучаствовать, нужно:
1️⃣ Покупаешь любой курс до конца октября;
2️⃣ Проходишь 2 недели обучения к 15 ноября;
3️⃣ Написать куратору в чат #розыгрыш.
До 15 ноября, потом всё — поезд (и макбук) уйдёт.
👉 Участвовать в розыгрыше
🚀 Как построить надёжную шину событий с Redis Streams в PHP
Redis Streams давно перестали быть экзотикой и стали нормальным способом передачи событий между сервисами. В PHP есть два популярных подхода для работы с ними: Amp с неблокирующим I/O и Swoole с корутинами. Оба подхода позволяют реализовать устойчивые consumer-группы, ручной ack, автоматическое перенаправление зависших сообщений, backpressure, экспоненциальные ретраи и дед-лейтер.
🛠️ Что строим
Задача — создать шину событий заказов. Продюсер записывает события в
⚙️ Варианты реализации
Amp: Неблокирующее чтение с использованием
Swoole: Использование корутин с каналом как семафором, Redis из
🔁 Экспоненциальные ретраи
Redis Streams не поддерживают отложенные сообщения, но можно реализовать экспоненциальные ретраи с использованием ZSET. При ошибке вы подтверждаете задачу и кладёте её в
📊 Мониторинг и масштабирование
Для мониторинга используйте команду
🔗 Хабр
Библиотека пхпшника
Redis Streams давно перестали быть экзотикой и стали нормальным способом передачи событий между сервисами. В PHP есть два популярных подхода для работы с ними: Amp с неблокирующим I/O и Swoole с корутинами. Оба подхода позволяют реализовать устойчивые consumer-группы, ручной ack, автоматическое перенаправление зависших сообщений, backpressure, экспоненциальные ретраи и дед-лейтер.
🛠️ Что строим
Задача — создать шину событий заказов. Продюсер записывает события в
orders:events с помощью команды XADD с триммингом. Несколько воркеров читают из consumer-группы orders:cg с использованием XREADGROUP в блокирующем режиме, подтверждают обработку через XACK, а зависшие записи перенаправляются на активного потребителя через XAUTOCLAIM. Если событие стабильно не обрабатывается, оно отправляется в orders:events:dlq и больше не участвует в основном потоке. Мониторинг задержки группы осуществляется через XINFO GROUPS, а хвосты периодически очищаются.⚙️ Варианты реализации
Amp: Неблокирующее чтение с использованием
XREADGROUP, ограничение параллельной обработки с помощью LocalSemaphore, подтверждение XACK пачками. Для подбора зависших сообщений параллельно запускается цикл XAUTOCLAIM.Swoole: Использование корутин с каналом как семафором, Redis из
ext-phpredis. Параллельная обработка ограничивается размером канала.🔁 Экспоненциальные ретраи
Redis Streams не поддерживают отложенные сообщения, но можно реализовать экспоненциальные ретраи с использованием ZSET. При ошибке вы подтверждаете задачу и кладёте её в
ZSET orders:retry со значением score = now + backoffMs. Отдельная корутина периодически извлекает задачи из ZSET и повторно добавляет их в основной стрим с увеличенным счётчиком попыток.📊 Мониторинг и масштабирование
Для мониторинга используйте команду
XINFO GROUPS, чтобы отслеживать количество записей, которые ещё не доставлены группе. Если лаг стабильно растёт, добавляйте консьюмеров. Если лаг «пилит» около нуля, можно уменьшить число воркеров.🔗 Хабр
Библиотека пхпшника
👍5
🧠 PHP-лайфхак: подключи PHPStan или Psalm для статического анализа
Хочешь ловить баги до запуска кода? Используй статический анализ.
Это инструмент, который проверяет твой PHP-код на ошибки, несоответствия типам и подозрительные конструкции — без выполнения программы.
🔍 Как это работает
🧩 Установи PHPStan:
Запусти анализ:
Можно использовать уровни от 0 до 9 — начни с 5–6, чтобы не утонуть в предупреждениях.
⚡️ Что даёт PHPStan / Psalm
🐞 Находит ошибки типов ещё до запуска кода
🚫 Предупреждает о неиспользуемых переменных и мёртвом коде
🧩 Помогает навести порядок в архитектуре
🔒 Снижает риск багов при рефакторинге
💡 Интеграция с Composer и CI/CD
Добавь команду в
Теперь можно запускать проверку просто:
А в CI — добавить шаг перед деплоем, чтобы ни один коммит с ошибками типов не ушёл в прод.
🧠 Совет: если проект большой — начни с "--level=5" и постепенно повышай. Так ты постепенно приведёшь код в порядок без боли.
Библиотека пхпшника
Хочешь ловить баги до запуска кода? Используй статический анализ.
Это инструмент, который проверяет твой PHP-код на ошибки, несоответствия типам и подозрительные конструкции — без выполнения программы.
🔍 Как это работает
🧩 Установи PHPStan:
composer require --dev phpstan/phpstan
Запусти анализ:
./vendor/bin/phpstan analyse src --level=max
--level=max включает максимально строгую проверку.Можно использовать уровни от 0 до 9 — начни с 5–6, чтобы не утонуть в предупреждениях.
⚡️ Что даёт PHPStan / Psalm
🐞 Находит ошибки типов ещё до запуска кода
🚫 Предупреждает о неиспользуемых переменных и мёртвом коде
🧩 Помогает навести порядок в архитектуре
🔒 Снижает риск багов при рефакторинге
💡 Интеграция с Composer и CI/CD
Добавь команду в
composer.json:"noscripts": {
"analyze": "phpstan analyse src --level=max"
}Теперь можно запускать проверку просто:
composer analyzeА в CI — добавить шаг перед деплоем, чтобы ни один коммит с ошибками типов не ушёл в прод.
🧠 Совет: если проект большой — начни с "--level=5" и постепенно повышай. Так ты постепенно приведёшь код в порядок без боли.
Библиотека пхпшника
🥱2