The Dragon Code News
260 subscribers
218 photos
7 videos
4 files
241 links
Рассказываем о том, над чем работаем и что может быть полезным разработчикам 🙂

dragon-code.pro
Download Telegram
Laravel Deploy Operations 6.0.0 released

Changed

- Added suggestion for dragon-code/laravel-data-dumper

- Database transaction settings moved to configuration file
- The $async property moved to configuration file
- The enabledTransactions method has been renamed to hasTransactions

- Update doc's title
- [6.x] Rename the project to “Deploy Operations” from “Deploy Actions”

Fixed

- Fixed documentation hostname
- Fixed upgrade processor

https://github.com/TheDragonCode/laravel-deploy-operations/releases/tag/6.0.0

#laravel_deploy_operations #deploy #laravel #operations
Docker Hub - всё

Сегодня с утра на территории России перестал открываться Docker Hub. Ведь это так поможет бороться...

В сети уже появились ссылки на китайские зеркала, но доверие к ним под большим вопросом. Не хочется стать помощником в распространении вполне вероятного вредоносного ПО с их стороны...
😡1
Инструкция по настройке зеркала для Docker

Вследствие внезапно возникшего сообщения о блокировке сервиса Docker Hub на территории России.

Необходимо указать зеркала сервиса одним из способов:

1. Через файл конфигурации докера
Linux, regular setup
/etc/docker/daemon.json

Linux, rootless mode
~/.config/docker/daemon.json

Windows
C:\ProgramData\docker\config\daemon.json

Windows с Docker Desktop
%USERPROFILE%\.docker\daemon.json


2. Через Docker Desktop

Перейдите в настройки, далее вкладка "Docker Engine" и добавьте зеркала.

Зеркала для добавления (указывайте на свой страх и риск):

{ "registry-mirrors" : [ "https://huecker.io", "https://mirror.gcr.io" ] }


Известные прокси:

Хуёкер      https://huecker.io
Google https://mirror.gcr.io
China https://daocloud.io
China https://c.163.com
China https://registry.docker-cn.com


Доверять ли этим прокси - решать только Вам.
Сегодня внезапно из России перестал работать домен dragon-code.pro со всеми его поддоменами, включая deploy-operations.dragon-code.pro

На сайт пускает только под VPN. Подобное поведение уже было, когда Роскомнадзор внёс в список блокировок пул адресов CloudFlare. В этой ситуации остаётся лишь ждать когда либо CF изменят пул, либо РКН снимет блокировку ☹️
Список удобных алиасов для работы с Laravel и Composer

composer normalize приводит состояние файла composer.json согласно официальной схеме Composer. Реализуется путём глобальной установки пакета ergebnis/composer-normalize.
Forwarded from Andrey Helldar
Простой и быстрый способ локализации маршрутов 🗺

Сегодня наша команда поздравляет Вас с выходом одного из запланированных проектов - laravel-lang/routes.

Его задача заключается в локализации приложения при входящих запросах посредством URL-параметра, заголовка, куков или данных сессии.

Информацию по установке и использованию можно найти в документации: https://laravel-lang.com/packages-routes.html
👍1
Порядок регистрации пакетов в Laravel

Сегодня столкнулись с проблемой, следствием которой стала невозможность установки пакетов в приложение.

Разобравшись в деталях, была найдена причина и возможные варианты её обхода. Возможно, кому-то пригодится.

Итак, в данном случае устанавливали пакет laravel-lang/common, который имеет свои зависимости. Некоторые из них, в конечном итоге, обращаются к пакету конфигурации, вынесенному отдельно для удобства работы с ними в рамках проекта Laravel-Lang.

Так вот, после установки, Laravel вызывает механизм Illuminate\Foundation\ComposerScripts::postAutoloadDump, который проходит по всем пакетам и регистрирует их. Composer отдаёт этот список в алфавитном порядке, а так как Actions находится выше Config, то и инициализируется раньше.

Далее идёт цепочка:

1. Actions вызывает внутреннюю механику Publisher
2. Publisher обращается к скрытой (читай системной) области конфигураций
3. Конфигурация возвращает ошибку потому что в этот момент она ещё не была зарегистрирована.

Добавлять вызов сервис-провайдера от Config в блок extra файла composer.json тоже бесполезно - не работает, проверено.

Но что же делать? - спросите.

И решения найдено два:

1. В случае "отсутствия" конфигурации тип конечной переменной должен быть готов принять null в качестве значения, либо его инициализатор должен учитывать это состояние и подставлять "дефолтное" значение.

2. Можно добавить вызов регистрации сервис-провайдера в метод register самого пакета. Например:

use \LaravelLang\Config\ServiceProvider as CSP;

$this->app->register(CSP::class);


Но если таких пакетов много, то второй вариант максимально близок к утопии.
🔥1
Новый проект в стадии активной разработки

Уже скоро в Laravel-Lang! 😊
👀2👍1🔥1🤔1
Работа с новой архитектурой в Laravel 11

Основная "киллер-фича" фреймворка Laravel версии 11 - "плоский код". Под капот убрано всё, что большинством разработчиков не используется и, по сути, является "мусором". А также убраны некоторые действительно полезные вещи.

В статье мы рассмотрим что куда делось и как улучшить взаимодействие с новой архитектурой.

https://habr.com/ru/articles/822185/
🔥41
Алиасы устанавливаемых зависимостей

При разработке пакетов часто нужно подгружать dev версии зависимостей и с этим могут возникнуть проблемы, если другие используемые зависимости требуют стабильную версию.

Конечно, можно указать алиас ветки в том самом репозитории, но это не всегда срабатывает, да и Packagist любит превращать их тег, например, в 1.0.x-dev при том, что алиас задан как 1.0-dev, что делает практически невозможным их установку.

Но решение есть и очень простое - инлайновый алиас. Всё что нужно сделать - это указать dev версию той самой зависимости как стабильную и выполнить команду composer update. И зависимость будет без проблем установлена.

Главное, не забудьте её переключить перед релизом 😉
5🤯2
Состоялся первый публичный релиз Laravel Lang: Models v1.0-beta1 🔥

Проект, реализующий перевод контента в приложении с удобным хранением и использованием.

Документация будет в ближайшее время 💪

https://github.com/Laravel-Lang/models
🔥21
Иногда возникает необходимость выполнить какие-либо действия над коллекцией релейшена для использования в нескольких местах приложения.

Один из часто встречаемых вариантов - это метод keyBy, когда нужно ключи массива превратить в какое-либо значение из результата.

Метод afterQuery в Laravel 11.4+ позволяет выполнить эти действия, сохранив результат в релейшены. Таким образом, снаружи больше не будет необходимости их повторять.
3😱2🔥1
Отслеживание запросов N+1 к базе данных - это легко!

Одна из основных проблем средних и больших приложений в том, что, в какой-то момент времени разработчики перестают отслеживать множественные запросы при обращении к релейшенам.

Именно для этого существует метод Model::preventLazyLoading, который позволяет активировать их обнаружение.

Работает он просто - если при запуске приложения обнаружено обращение к релейшену коллекции, для которого не была применена жадная загрузка, такой запрос упадёт с ошибкой, сообщив об этом.

При этом, совсем не стоит бояться выгружать его на продакшен - именно для этого в его аргумент можно передать условие активации везде, кроме прода.

Таким образом, если Ваше приложение покрыто тестами, Вы на этапе их запуска узнаете об этом 🙂

https://laravel.com/docs/eloquent-relationships#preventing-lazy-loading
🔥1🤯1
The Dragon Code News
Иногда возникает необходимость выполнить какие-либо действия над коллекцией релейшена для использования в нескольких местах приложения. Один из часто встречаемых вариантов - это метод keyBy, когда нужно ключи массива превратить в какое-либо значение из результата.…
Обнаружен нюанс метода afterQuery - если в модель прокинуть вызов with с релейшенами, то он перезатирает результат.

Но и решение проблемы банально простое - нужно в модели переопределить метод setRelation. Да, костыль. Зато работает.
Переиспользуемые скоупы

Традиционно, переиспользуемые скоупы запросов всегда определялись в самой модели с помощью магического метода scopeXXX, макросов или специального класса Builder. В первых двух случаях проблема заключается в том, что они оба опираются на неявную магию, что делает (почти) невозможным получение подсказок со стороны IDE без применения специальных инструментов. Ещё хуже то, что в случае регистрации макросов, может возникнуть конфликт имён. Однако, существует и четвёртый, на мой взгляд, более эффективный подход: использование переиспользуемых скоупов (tappable scopes).

Подробнее об этом и не только способе можно прочитать здесь и здесь.
👍31