Започаткую рубрику #бидло_промпт_інженірінг
Якщо впізнали себе і маєте подібний досвід - кидайте скріншотики в коментарі 😁
Якщо впізнали себе і маєте подібний досвід - кидайте скріншотики в коментарі 😁
😁9👍2
KRUHLYK 🇺🇦
Ну що, продовжуємо працювати з інтеграцією платіжного сервісу WayForPay в життя розробників. Бібліотека для .NET вже навіть має перші скачування. Це мотивує. Але, ми ж тут з вами на ларці пишемо. Тому, вирішив розімʼятись та створити пакет під ларку для…
Пофіксив багу з генерацією HTML для форми віджета. Оновлюйтесь, якщо встигли встановити, звісно 😆
👍3
Ну що, хто просив пакет під ларку для Monobank? 😉
Встановлюйте на ваші e-commerce і майте шекелі через Монобанк!😺
Ловіть, встановлюйте, пишіть Issues, все як положено!
https://github.com/AratKruglik/monobank-acquiring-laravel
Встановлюйте на ваші e-commerce і майте шекелі через Монобанк!
Ловіть, встановлюйте, пишіть Issues, все як положено!
https://github.com/AratKruglik/monobank-acquiring-laravel
Please open Telegram to view this post
VIEW IN TELEGRAM
GitHub
GitHub - AratKruglik/monobank-acquiring-laravel
Contribute to AratKruglik/monobank-acquiring-laravel development by creating an account on GitHub.
🔥16
Якщо працюєте з Livewire, то коротка новина.
Відбувся реліз Livewire 4
https://github.com/livewire/livewire/releases/tag/v4.0.0
Відбувся реліз Livewire 4
https://github.com/livewire/livewire/releases/tag/v4.0.0
GitHub
Release v4.0.0 · livewire/livewire
⚡ Livewire 4.0
Livewire 4.0 is finally here.
This release represents a massive step forward for Livewire, bringing powerful new features, improved developer experience, and a more solid foundation ...
Livewire 4.0 is finally here.
This release represents a massive step forward for Livewire, bringing powerful new features, improved developer experience, and a more solid foundation ...
🔥6❤2👏1
Вау! Дуже класна презентаха. Слідуйте інструкціям і гортайте сторінки. Дуже топ! Інформативно та зрозуміло.
https://yermilov.github.io/pragmatic-vibe-clauding-ua
https://yermilov.github.io/pragmatic-vibe-clauding-ua
🔥5
Не пройшов і рік, як наш проєкт нарешті майже мігранув на Laravel 12.
Мені скоро огляд 13ї дарки робити, а тут слоупок паті в реалі.
А шо у вас? Всі на останній ларці в проєктах у себе?
Смачної кавусі і боже збав вас сьогодні шось деплоїти. Світла нема, інтернету дефіцит, а ви ще дебажити зібрались. Ну майте совість!
Мені скоро огляд 13ї дарки робити, а тут слоупок паті в реалі.
А шо у вас? Всі на останній ларці в проєктах у себе?
Смачної кавусі і боже збав вас сьогодні шось деплоїти. Світла нема, інтернету дефіцит, а ви ще дебажити зібрались. Ну майте совість!
👍7
#laratip
Laravel Validation Hack: Коли `required_if` вже не стягує
Знаєте ці моменти, коли валідація форми перетворюється на спробу розгадати ієрогліфи? Коли у вас є поле, яке стає обов'язковим тільки якщо "зірки зійшлися", а клієнт вибрав тип аккаунту "Platinum Business Plus"?
Звісно, можна напхати
Суть методу
Аналіз кейсів зі скріна:
1. Ізольована логіка: Правило
2. Групова валідація: Можна передати масив полів
3. Complex Logic: В замикання приходить об'єкт
Senior Tips
Form Requests: Не пишіть валідатор у контролері. Використовуйте
DX та типи: У Symfony ми б городили
Legacy: Якщо бачите в проєкті
Такий підхід робить валідацію декларативною та легшою для тестування.
Laravel Validation Hack: Коли `required_if` вже не стягує
Знаєте ці моменти, коли валідація форми перетворюється на спробу розгадати ієрогліфи? Коли у вас є поле, яке стає обов'язковим тільки якщо "зірки зійшлися", а клієнт вибрав тип аккаунту "Platinum Business Plus"?
Звісно, можна напхати
required_if:type,customer, але що як умова складніша? Ось тут на сцену виходить метод sometimes().Суть методу
sometimes() дозволяє додавати правила валідації лише за умови, що переданий колбек поверне true. Це набагато гнучкіше за стандартні required_with чи required_unless, оскільки ви працюєте з чистим PHP всередині замикання.Аналіз кейсів зі скріна:
1. Ізольована логіка: Правило
required|email активується лише для типу customer. Це чистіше за довгі рядки валідації, особливо коли логіка виходить за межі простої перевірки "рівно/не рівно".2. Групова валідація: Можна передати масив полів
['phone', 'address']. Це ідеально для ситуацій, коли вибір однієї опції (наприклад, способу доставки) робить обов'язковим цілий блок даних.3. Complex Logic: В замикання приходить об'єкт
$input (екземпляр Fluent). Тут можна будувати складні ланцюжки: перевіряти вкладені параметри, бізнес-ліміти чи навіть робити запити до БД. На скріні бачимо комбінацію типу аккаунту та фінансового порогу — реалізувати таке через стандартні string-правила майже неможливо.Senior Tips
Form Requests: Не пишіть валідатор у контролері. Використовуйте
FormRequest та метод withValidator($validator). Саме там цим правилам і місце, щоб тримати контролер суто для координації потоку.DX та типи: У Symfony ми б городили
FormEvents::PRE_SUBMIT або складні Callback констрейнти. Laravel дає лаконічний інтерфейс, але пам'ятайте про читабельність — якщо умова в sometimes() займає 20 рядків, краще винести її в окремий приватний метод.Legacy: Якщо бачите в проєкті
if ($request->has(...)) { $rules['field'] = ... } — це прямий кандидат на рефакторинг через sometimes().Такий підхід робить валідацію декларативною та легшою для тестування.
🔥9❤2👍1
#laratip
Custom Validation Rules: від костилів до елегантних рішень
Коли вбудованих
1. Inline-валідація (Closures) Підходить для унікальної логіки "тут і зараз".
Плюс: Швидко, не засмічує структуру проєкту.
Мінус: Важко тестувати окремо, копіпаст — гріх. У замикання прокидається
2. Rule Objects (Artisan make:rule) Це вже дорослий підхід. Але зверніть увагу: на скрині старий підхід з
Senior Tips:
Якщо логіка валідації потребує запитів до БД — виносьте в Rule-клас.
Використовуйте
Для складних DTO та Domain-Driven Design валідацію краще тримати ближче до шару Application, а не тільки в Request-класах.
Що по коду на скрині?
Приклад з
Валідувати кейс юзернейма — специфічний кейс, зазвичай ми просто робимо
Custom Validation Rules: від костилів до елегантних рішень
Коли вбудованих
required, string або exists стає замало, у нас є два шляхи. Вибір залежить від того, чи збираєтесь ви перевикористовувати цю логіку.1. Inline-валідація (Closures) Підходить для унікальної логіки "тут і зараз".
Плюс: Швидко, не засмічує структуру проєкту.
Мінус: Важко тестувати окремо, копіпаст — гріх. У замикання прокидається
$fail. Якщо викликали — валідація не пройшла.2. Rule Objects (Artisan make:rule) Це вже дорослий підхід. Але зверніть увагу: на скрині старий підхід з
passes() та message(). У сучасних версіях Laravel ми використовуємо один метод validate(string $attribute, mixed $value, Closure $fail): void.Senior Tips:
Якщо логіка валідації потребує запитів до БД — виносьте в Rule-клас.
Використовуйте
Rule::macro, якщо хочете додати метод у загальний білдер валідатора.Для складних DTO та Domain-Driven Design валідацію краще тримати ближче до шару Application, а не тільки в Request-класах.
Що по коду на скрині?
Приклад з
strtoupper — ок для демо, але в реалі враховуйте локалізацію та мультибайтові рядки (mb_strtoupper). Валідувати кейс юзернейма — специфічний кейс, зазвичай ми просто робимо
$request->merge() або валідуємо через Regex.👍3🔥3
This media is not supported in your browser
VIEW IN TELEGRAM
Я пушу не протестований код в пʼятницю.
Девопс, який вночі на чергуванні:
Девопс, який вночі на чергуванні:
🤣14
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥19