Deworker Pro
1.41K subscribers
5 photos
187 links
Download Telegram
Forwarded from ElisDN.ru
Выступил с докладом на третьем митапе BeerPHP SPb.

Рассказал про вертикальную группировку кода проекта по фичам на модули и компоненты вместо горизонтального разделения исходников по типам классов. Рассмотрел, что делать с контроллерами, и как удобнее раскладывать тесты и конфигурацию в такой структуре:

https://elisdn.ru/blog/149/code-structure
Вот мы с вами и составили примерное задание для разработки нашего демонстрационного аукциона. На этих требованиях мы с вами остановимся и начнём всё это программировать.

Но с ростом реального проекта после запуска будут приходить новые идеи. Сейчас мы можем только предположить, как всё это будет происходить и какие из идей можно будет реализовать позже.

Поэтому сегодня обсудим, как функциональность проекта может развиваться со временем вширь и вглубь. И по итогам эпизода будет конкурс, где вы можете выиграть бесплатное продление подписки.
Месяц назад вышел PHP 8.1 с новыми возможностями. Атрибуты теперь поддерживают вложенность, которой раньше не было. Это нам мешало перейти на них в 8.0. Теперь нас ничто не останавливает.

Пришла пора завершить переход на PHP 8.0 и перевести наш проект с классических аннотаций на новые нативные атрибуты для валидатора и Doctrine ORM. Поговорить, что делать с ними в legacy-проектах.

И заодно пощупать новые компоненты из версии Symfony 6 для бэкенда и новый React Router 6 для фронтенда.
Мы с вами завершили написание техзадания аукциона. Теперь пора поговорить о том, в какой последовательности и с помощью каких инструментов мы будем всё это реализовывать.

Поэтому 3 января в понедельник в 16:00 по московскому времени мы в прямом эфире разберём все требования с точки зрения программиста и обсудим, как мы всё это будем разрабатывать.
В разделе скринкастов появилась вкладка истории просмотренных вами эпизодов. Достаточно залогиниться, и ваша страница истории начнёт работать. Так вам будет сразу видно, какие эпизоды вы посмотрели, а какие нет.

И для каждого видео теперь работает запоминание текущей позиции. Если вы зайдёте в недосмотренный вами ранее скринкаст и нажмёте Play, то воспроизведение продолжится с прошлого сохранённого момента.

Приятного просмотра!
Напоминаем, что через полчаса в 16:00 по московскому времени мы разберём все требования с точки зрения программиста и обсудим, как мы всё это будем разрабатывать. Приходите к нам на эфир https://youtu.be/8YFD5lTHyXk
По мотивам прошлых стримов и дайджестов делимся текущим прогрессом. У нас накопилось несколько новостей о том, сколько всего мы прошли, что делаем сейчас и что уже сделали:

Что там есть
Помимо переобработки старых видео записываем обещанный мегаэпизод про работу HTTP-сервера с синхронным и асинхронным запуском PHP. За эту неделю записали пока восемь часов материала и осталось записать ещё два-три, чтобы в итоге смонтировать концентрированный двухчасовой шедевр. Задача оказалось сложнее и интереснее, чем мы задумывали, но мы справимся.

А пока работа кипит, можем завтра отдохнуть и подвести с вами итоги года в мире PHP в утреннем стриме. Там как раз обсудим, чем полезно и чем вредно задавать технические вопросы в чатах. И заодно расскажем, что собрались с этим делать на deworker.pro.
Самое грандиозное событие этого года завершено. Записан мегаскринкаст про работу HTTP-сервера с нашим программным кодом. И про недопонимания и заблуждения, которые порой бывают у PHP-программистов.
В комментариях под скринкастами вы часто задаёте интересные вопросы, на которые я стараюсь дать подробный ответ. Но новые комментарии под сотней просмотренных ранее видеороликов никто не ищет. Большой пласт информации проходит мимо зрителей и теряется в тысячах других комментариев.

Чтобы это исправить, добавлен новый раздел Q&A, куда вручную отбираются комментарии с интересными вопросами и ответами. И теперь можно интересные скринкасты и комментарии добавлять в избранное.

Об этом и другом рассказываем в свежем дайджесте.
Продолжаем разработку проекта на Slim & React. Сегодня соберём накопившиеся за всё это время обновления и переведём проект на PHP 8.1 и новый React 18.
Пора для аукциона сделать аутентификацию на React. Этим теперь и займёмся.

Сегодня добавим кнопку входа под фича-флагом аутентификации и займёмся поиском подходящего компонента для работы с OAuth2 в React. Обсудим, какие могут быть трудности при подключении сторонних библиотек и какие есть способы это решить.
Фича-флаг добавили и готовые компоненты рассмотрели. Пора реализовать всё в проекте.

Сегодня сделаем полноценный клиент аутентификации в React для получения токенов JWT с бэкенда по протоколу OAuth2 с PKCE.

Рассмотрим подходы к автообновлению токенов и нюансы безопасности. Заодно добавим возможность действия от имени пользователя в E2E-тестах.
Для компонента аутентификации нам осталось доделать возможность входа через OAuth-провайдер на другом домене или поддомене. Для указания хоста мы можем использовать переменные окружения как мы делаем в бэкенде.

Но работа с окружением во фронтенде сильно отличается тем, что JavaScript код выполняется не на севрере, а в браузере, где никаких переменных нет. И для динамической подстановки значений в момент запуска сервера нам придётся использовать особые подходы.

Поэтому сегодня разберём внутреннюю работу и использование переменных окружения в React при разработке и при деплое с Docker. Заодно познакомимся с аргументами для пробрасывания ключей доступа к приватным репозиториям в процессе сборки контейнеров.
Раньше мы рассматривали написание пайплайна тестирования и деплоя в GitHub Actions. Но мы это делали до того, как перешли на использование secrets для паролей. И в последнее время переименовался реестр в GitHub Packages.

Актуальный рабочий вариант пайплайна сейчас можно посмотреть в свежих исходниках блога:

https://t.me/elisdnru/31
Спешим сообщить, что нам удалось восстановить приём иностранных платежей.

Если у вас не было возможности оплачивать ранее, то теперь можете ни в чём себе не отказывать. Можете посмотреть крайне полезный мегаскринкаст о работе HTTP-серверов и о связанных с этим часто возникающих заблуждениях у PHP-программистов. И потом досмотреть свежие эпизоды по Slim и React.

Кнопка оплаты и инструкция теперь доступны в кабинете.
Пока в Вилларибо празднуют, успешно используя в PHP явную типизацию и Psalm, в Виллабаджио на JavaScript всё ещё программируют наугад без типов и боятся обновлять пакеты.

Пришло время это исправить. Сравнить виды типизации в разных языках программирования и посмотреть, чем в этом плане JavaScript отличается от PHP и что там можно сделать. Этим мы и займёмся.
Когда разобрались с видами типизации и с TypeScript пришла пора внедрить всё это в наш проект. Сегодня проведём полную интеграцию с CucumberJS для наших E2E-тестов и исправим все недочёты, которые при этом найдём.
После типизации наших E2E-тестов пора перейти к пошаговому добавлению типизации фронтенда, учитывая разные нюансы. Как раз этим займёмся в сегодняшнем мегаскринкасте про внедрение TypeScript в проект на ReactJS.

Помимо всех страниц проставим типы компоненту FeatureToggle и полностью типизируем AuthProvider. Проверим, сколько недочётов было в нашем коде.

Заодно напишем фейковый провайдер аутентификации для оборачивания им других компонентах в юнит-тестах.
Для FREE-доступа открыт мегаскринкаст про работу HTTP-сервера с PHP и про частые заблуждения, с этим связанные.

Если у вас скоро собеседование, то будет особенно полезно.
Впереди у нас подключение Serializer и проектирование доменной модели аукциона.

А пока перед этими темами завершим начатое ранее обновление конфигурации Doctrine ORM и переведём её консольные команды на инъекцию зависимостей в конструктор. Заодно перепишем структуры на использование модификатора readonly и переведём сервисы на синтаксис с constructor property promotion. Поворим, где это уместно, а где не очень.