ru
Feedback
Deworker Pro

Deworker Pro

Открыть в Telegram
1 411
Подписчики
Нет данных24 часа
-37 дней
-130 день
Архив постов
Пока в Вилларибо празднуют, успешно используя в PHP явную типизацию и Psalm, в Виллабаджио на JavaScript всё ещё программируют наугад без типов и боятся обновлять пакеты. Пришло время это исправить. Сравнить виды типизации в разных языках программирования и посмотреть, чем в этом плане JavaScript отличается от PHP и что там можно сделать. Этим мы и займёмся.

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

Раньше мы рассматривали написание пайплайна тестирования и деплоя в GitHub Actions. Но мы это делали до того, как перешли на использование secrets для паролей. И в последнее время переименовался реестр в GitHub Packages. Актуальный рабочий вариант пайплайна сейчас можно посмотреть в свежих исходниках блога: https://t.me/elisdnru/31

Для компонента аутентификации нам осталось доделать возможность входа через OAuth-провайдер на другом домене или поддомене. Для указания хоста мы можем использовать переменные окружения как мы делаем в бэкенде. Но работа с окружением во фронтенде сильно отличается тем, что JavaScript код выполняется не на севрере, а в браузере, где никаких переменных нет. И для динамической подстановки значений в момент запуска сервера нам придётся использовать особые подходы. Поэтому сегодня разберём внутреннюю работу и использование переменных окружения в React при разработке и при деплое с Docker. Заодно познакомимся с аргументами для пробрасывания ключей доступа к приватным репозиториям в процессе сборки контейнеров.

Фича-флаг добавили и готовые компоненты рассмотрели. Пора реализовать всё в проекте. Сегодня сделаем полноценный клиент аутентификации в React для получения токенов JWT с бэкенда по протоколу OAuth2 с PKCE. Рассмотрим подходы к автообновлению токенов и нюансы безопасности. Заодно добавим возможность действия от имени пользователя в E2E-тестах.

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

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

В комментариях под скринкастами вы часто задаёте интересные вопросы, на которые я стараюсь дать подробный ответ. Но новые комментарии под сотней просмотренных ранее видеороликов никто не ищет. Большой пласт информации проходит мимо зрителей и теряется в тысячах других комментариев. Чтобы это исправить, добавлен новый раздел Q&A, куда вручную отбираются комментарии с интересными вопросами и ответами. Об этом и другом рассказываем в свежем дайджесте.

Самое грандиозное событие этого года завершено. Записан мегаскринкаст про работу HTTP-сервера с нашим программным кодом. И про недопонимания и заблуждения, которые порой бывают у PHP-программистов.

Начинаем

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

По мотивам прошлых стримов и дайджестов делимся текущим прогрессом. У нас накопилось несколько новостей о том, сколько всего мы прошли, что делаем сейчас и что уже сделали: Что там есть

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

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

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

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

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

Выступил с докладом на третьем митапе BeerPHP SPb. Рассказал про вертикальную группировку кода проекта по фичам на модули и компоненты вместо горизонтального разделения исходников по типам классов. Рассмотрел, что делать с контроллерами, и как удобнее раскладывать тесты и конфигурацию в такой структуре: https://elisdn.ru/blog/149/code-structure

Мы разобрали внешний дизайн аукциона и его функциональность. Пришло время продумать внутренний вид личных кабинетов покупателя и продавца.

С целями по HTTP-фреймворку мы в прошлый раз определились. Пора приступать к написанию. Сегодня подготовим всю необходимую инфраструктуру, как мы с вами уже умеем делать с помощью Docker по опыту проекта аукциона. Мы также установим и настроим локальный HTTP-сервер с PHP. А потом определим структуру проекта для написания наших классов. Потом для тестирования установим PHPUnit и напишем свой первый тест. И заодно настроим интерпретатор и запуск тестов в PHPUnit.

Deworker Pro - Статистика и аналитика Telegram-канала @deworkerpro