Write Only Business Logic: Eliminate Boilerplate
https://dariuszgafka.medium.com/write-only-business-logic-eliminate-boilerplate-c88ba70394a1
https://redd.it/1mvqsw1
@r_php
https://dariuszgafka.medium.com/write-only-business-logic-eliminate-boilerplate-c88ba70394a1
https://redd.it/1mvqsw1
@r_php
Medium
Write Only Business Logic: Eliminate Boilerplate
When did we accept as normal that 60–70% of code we write is orchestration and boilerplate?
Visual Studio Code handling of collection objects containing specific types of objects
I'm working with laravel's collections iterable objects of Illuminate\\Database\\Eloquent\\Collection which contain models. I have a function that returns a set of particular models of a particular type only, and I thought that I could use php docblocks to have vscode correctly understand what is stored in the collection, but I seem to not be getting quite what is advertised. This is the type of method definition I'm referring to:
Then elsewhere in my code, I might do:
Instead of the IDE recognizing order as an Order object at the line noted, it sees it merely as an object of \Illuminate\Database\Eloquent\Model.
On the other hand, if I change my docblock to be thus:
Then things work as expected. The IDE recognizes that $order is not just a model but is an Order model specifically.
Anyone run into this and know how I can tweak my docblock so that the IDE is better aware of the collection contents at calling locations? I'm using the usual extensions in VSCode including PHP Intelephense (licensed).
https://redd.it/1mvw2o2
@r_php
I'm working with laravel's collections iterable objects of Illuminate\\Database\\Eloquent\\Collection which contain models. I have a function that returns a set of particular models of a particular type only, and I thought that I could use php docblocks to have vscode correctly understand what is stored in the collection, but I seem to not be getting quite what is advertised. This is the type of method definition I'm referring to:
/**
* @return \Illuminate\Database\Eloquent\Collection<App\Models\Order>
*/
function getOrders(): Collection
{
return Order::get();
}
Then elsewhere in my code, I might do:
$orders = getOrders();
foreach ($orders as $order) {
// At this line, my IDE should recognize that $order is an object of the App\Models\Order class
}
Instead of the IDE recognizing order as an Order object at the line noted, it sees it merely as an object of \Illuminate\Database\Eloquent\Model.
On the other hand, if I change my docblock to be thus:
/**
* @return \App\Models\Order[]
*/
Then things work as expected. The IDE recognizes that $order is not just a model but is an Order model specifically.
Anyone run into this and know how I can tweak my docblock so that the IDE is better aware of the collection contents at calling locations? I'm using the usual extensions in VSCode including PHP Intelephense (licensed).
https://redd.it/1mvw2o2
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
How do you find Laravel Cloud performance so far?
So I've been building my new app, and I shipped it on Cloud.
Since I wanted to avoid JS framework, it's using Blade and Alpine Ajax. Most pages are under < 20kb and the biggest one is 120kb.
Nightwatch tells me that the duration of the requests are between 1.71ms and 1.71s.
While I have those metrics, switching from one page to another feels really slow - Chrome tells me that a page loads between 1 - 2s. I think I've optimized the s**t ouf of the queries, added cache almost everywhere, and the biggest page has 9 queries which run in less than 30ms. Perhaps I could do something else, but I wouldn't know what - this is not the topic of this post though.
I would like to know if others in the community who doesn't rely on Vue or React have this perceived notion of slowness as well. Thanks community!
https://redd.it/1mvxbvg
@r_php
So I've been building my new app, and I shipped it on Cloud.
Since I wanted to avoid JS framework, it's using Blade and Alpine Ajax. Most pages are under < 20kb and the biggest one is 120kb.
Nightwatch tells me that the duration of the requests are between 1.71ms and 1.71s.
While I have those metrics, switching from one page to another feels really slow - Chrome tells me that a page loads between 1 - 2s. I think I've optimized the s**t ouf of the queries, added cache almost everywhere, and the biggest page has 9 queries which run in less than 30ms. Perhaps I could do something else, but I wouldn't know what - this is not the topic of this post though.
I would like to know if others in the community who doesn't rely on Vue or React have this perceived notion of slowness as well. Thanks community!
https://redd.it/1mvxbvg
@r_php
Reddit
From the laravel community on Reddit
Explore this post and more from the laravel community
deploy a php solution on customer's server
hi,
one customer, want to host the developed php solution on their server - they have use-only license.
how can i protect the source code on that server?
what i am looking for is a way to prevent them to change the code and for us to be able to prevent them for further usage if for example the payments stop.
thanks.
https://redd.it/1mw4gn1
@r_php
hi,
one customer, want to host the developed php solution on their server - they have use-only license.
how can i protect the source code on that server?
what i am looking for is a way to prevent them to change the code and for us to be able to prevent them for further usage if for example the payments stop.
thanks.
https://redd.it/1mw4gn1
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
"Lambo PHP devs" what are you using?
Hi all,
I heard often phrases like "node js devs are unemployed and php devs drive lambos".
What are these lambo php devs using most of the time? Vanilla php? Wordpress? Drupal? Laravel? Symfony?
https://redd.it/1mw6zxx
@r_php
Hi all,
I heard often phrases like "node js devs are unemployed and php devs drive lambos".
What are these lambo php devs using most of the time? Vanilla php? Wordpress? Drupal? Laravel? Symfony?
https://redd.it/1mw6zxx
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
Video interview: PHP in 2025 with core dev Gina Banyard and contributor Larry Garfield
https://youtu.be/Sjf4jXh2GJA
https://redd.it/1mw84cs
@r_php
https://youtu.be/Sjf4jXh2GJA
https://redd.it/1mw84cs
@r_php
YouTube
PHP in 2025 with core dev Gina Banyard and contributor Larry Garfield
0:00 - Intro
1:08 - Motivation to work on PHP
1:54 - Modern PHP
3:12 - JIT
5:02 - Non web server uses
6:23 - Personal work on PHP
8:24 - Governance
9:29 - Funding
12:02 - Future directions
14:36 - Cleaning up
15:56 - Closing thoughts
1:08 - Motivation to work on PHP
1:54 - Modern PHP
3:12 - JIT
5:02 - Non web server uses
6:23 - Personal work on PHP
8:24 - Governance
9:29 - Funding
12:02 - Future directions
14:36 - Cleaning up
15:56 - Closing thoughts
Has anyone integrated Dodo Payments with Laravel?
I’m trying to integrate Dodo Payments into my Laravel 12 project.
I installed their PHP SDK but I’m running into a syntax error (@ related) when I try to use it. I couldn’t find any Laravel-specific tutorial or video for Dodo Payments integration—only general PHP or Node.js examples.
👉 Has anyone here successfully integrated Dodo Payments with Laravel?
Did you use their PHP SDK directly or a Laravel package?
Any example code, blog, or tutorial you can point me to?
How did you handle subnoscriptions and webhooks in Laravel?
Any help (or even just pointing me to the right resources) would be super appreciated.
https://redd.it/1mwe8k2
@r_php
I’m trying to integrate Dodo Payments into my Laravel 12 project.
I installed their PHP SDK but I’m running into a syntax error (@ related) when I try to use it. I couldn’t find any Laravel-specific tutorial or video for Dodo Payments integration—only general PHP or Node.js examples.
👉 Has anyone here successfully integrated Dodo Payments with Laravel?
Did you use their PHP SDK directly or a Laravel package?
Any example code, blog, or tutorial you can point me to?
How did you handle subnoscriptions and webhooks in Laravel?
Any help (or even just pointing me to the right resources) would be super appreciated.
https://redd.it/1mwe8k2
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
Keycloak + Symfony (KnpU OAuth2Client) users getting logged out after ~30–60 minutes despite long session settings
I'm integrating Keycloak with a Symfony app using
---
### Environment
Symfony 7
KnpU OAuth2ClientBundle
Keycloak (latest, running in Docker)
---
### Symfony `security.yaml` (relevant parts)
```yaml
firewalls:
main:
lazy: true
provider: app_user_provider
custom_authenticator:
- App\Security\AdminFormAuthenticator
- App\Security\KeycloakAuthenticator
entry_point: App\Security\AdminFormAuthenticator
logout:
path: app_logout
target: app_home
remember_me:
secret: '%kernel.secret%'
lifetime: 2592000 # 30 days
path: /
always_remember_me: true
```
I also store the refresh token in session and use it to refresh the access token when needed:
```php
if (!$request->query->has('code') && $session->has('refresh_token')) {
$accessToken = $this->refreshAccessToken($client, $session->get('refresh_token'));
} else {
$accessToken = $this->fetchAccessToken($client);
}
```
---
### Keycloak session/token settings
SSO Session Idle: 30 days
SSO Session Max: 10 days
Client Session Idle: 30 days
Client Session Max: 10 minutes (?? maybe suspicious?)
Offline Session Idle: 30 days
Access Token Lifespan: 15 days
Refresh Token lifespan: refresh disabled (default)
Login timeout: 30 minutes
Screenshots from KC settings:
- [Image 1](https://i.sstatic.net/fzTV9bz6.png)
- [Image 2](https://i.sstatic.net/la6nYY9F.png)
- [Image 3](https://i.sstatic.net/9QQTJbCK.png)
---
### The problem
Despite these "long" settings, sessions actually expire and users get logged out after about 30–60 minutes. Reports from users match what I've also experienced.
It looks like either:
Keycloak is expiring client sessions early (e.g. because of the 10 min Client Session Max?), or
Symfony is not persisting/refreshing tokens properly, or
My
---
### My question
What is the likely cause of users being logged out after 30–60 minutes?
Is this due to Keycloak's Client Session Max = 10 minutes overriding the longer SSO Session Idle/Max?
Do I need to explicitly enable refresh tokens in Keycloak and adjust their lifespan?
Is my Symfony `remember_me` irrelevant here because OAuth2 tokens control session duration?
What's the recommended setup so Keycloak + Symfony sessions last ~days or weeks, not 30 minutes?
Any insight into how these Keycloak session settings interact with Symfony's session + refresh token logic would be appreciated.
https://redd.it/1mx0u6r
@r_php
I'm integrating Keycloak with a Symfony app using
knpuniversity/oauth2-client-bundle and a custom authenticator. The flow works fine, but my users (and myself) are getting logged out after about 30–60 minutes, even though I've configured long session lifetimes in Keycloak and Symfony.---
### Environment
Symfony 7
KnpU OAuth2ClientBundle
Keycloak (latest, running in Docker)
---
### Symfony `security.yaml` (relevant parts)
```yaml
firewalls:
main:
lazy: true
provider: app_user_provider
custom_authenticator:
- App\Security\AdminFormAuthenticator
- App\Security\KeycloakAuthenticator
entry_point: App\Security\AdminFormAuthenticator
logout:
path: app_logout
target: app_home
remember_me:
secret: '%kernel.secret%'
lifetime: 2592000 # 30 days
path: /
always_remember_me: true
```
I also store the refresh token in session and use it to refresh the access token when needed:
```php
if (!$request->query->has('code') && $session->has('refresh_token')) {
$accessToken = $this->refreshAccessToken($client, $session->get('refresh_token'));
} else {
$accessToken = $this->fetchAccessToken($client);
}
```
---
### Keycloak session/token settings
SSO Session Idle: 30 days
SSO Session Max: 10 days
Client Session Idle: 30 days
Client Session Max: 10 minutes (?? maybe suspicious?)
Offline Session Idle: 30 days
Access Token Lifespan: 15 days
Refresh Token lifespan: refresh disabled (default)
Login timeout: 30 minutes
Screenshots from KC settings:
- [Image 1](https://i.sstatic.net/fzTV9bz6.png)
- [Image 2](https://i.sstatic.net/la6nYY9F.png)
- [Image 3](https://i.sstatic.net/9QQTJbCK.png)
---
### The problem
Despite these "long" settings, sessions actually expire and users get logged out after about 30–60 minutes. Reports from users match what I've also experienced.
It looks like either:
Keycloak is expiring client sessions early (e.g. because of the 10 min Client Session Max?), or
Symfony is not persisting/refreshing tokens properly, or
My
remember_me config doesn’t interact correctly with OAuth2.---
### My question
What is the likely cause of users being logged out after 30–60 minutes?
Is this due to Keycloak's Client Session Max = 10 minutes overriding the longer SSO Session Idle/Max?
Do I need to explicitly enable refresh tokens in Keycloak and adjust their lifespan?
Is my Symfony `remember_me` irrelevant here because OAuth2 tokens control session duration?
What's the recommended setup so Keycloak + Symfony sessions last ~days or weeks, not 30 minutes?
Any insight into how these Keycloak session settings interact with Symfony's session + refresh token logic would be appreciated.
https://redd.it/1mx0u6r
@r_php
With PHP8.5 we'll get Error Backtraces V2 on Fatal Errors
https://wiki.php.net/rfc/error_backtraces_v2
https://redd.it/1mx1q54
@r_php
https://wiki.php.net/rfc/error_backtraces_v2
https://redd.it/1mx1q54
@r_php
By simply configuring the .env file, a simple and safe Blue-Green Deployment is instantly set up for the Laravel sample
https://github.com/patternhelloworld/docker-blue-green-runner
https://redd.it/1mxcryw
@r_php
https://github.com/patternhelloworld/docker-blue-green-runner
https://redd.it/1mxcryw
@r_php
GitHub
GitHub - patternhelloworld/docker-blue-green-runner: By simply configuring the .env file, a safe isomorphic Blue-Green Deployment…
By simply configuring the .env file, a safe isomorphic Blue-Green Deployment is instantly set up. - patternhelloworld/docker-blue-green-runner
Facade Maker
Speed up facade creation in Laravel with Facade Maker.
Generate facades and services instantly, keeping your app structure clean and consistent.
Try it here: https://laravel-hub.com/package/facade-maker
https://redd.it/1mxcke4
@r_php
Speed up facade creation in Laravel with Facade Maker.
Generate facades and services instantly, keeping your app structure clean and consistent.
Try it here: https://laravel-hub.com/package/facade-maker
https://redd.it/1mxcke4
@r_php
Laravel Hub
facade-maker - Laravel Hub
A Laravel Package that helps you create facade architecture.
VSCode setup recommended extensions
Hi everyone,
I'm currently working/learning PHP in my work place and I'm looking at the setup or VSCode extension for PHP. What are the essential extension for PHP in VSCode? Also, I'm beginner in PHP in general so I appreciate any suggestion. The project is in PHP Laravel though I think it doesn't matter. Thank you in advance .
https://redd.it/1mxi09q
@r_php
Hi everyone,
I'm currently working/learning PHP in my work place and I'm looking at the setup or VSCode extension for PHP. What are the essential extension for PHP in VSCode? Also, I'm beginner in PHP in general so I appreciate any suggestion. The project is in PHP Laravel though I think it doesn't matter. Thank you in advance .
https://redd.it/1mxi09q
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
$SESSION array does not work from a subdomain.
Hi, everybody!
I have the following situation. A web page is in a subdirectory of my domain:
[`https://myowndomain.com/app`](https://myowndomain.com/app)
And it works fine.
Now, a subdomain was made in another domain that points to the previously mentioned web page:
`https://app.farawaydom.com -> https://myowndomain.com/app`
Works fine except that the $\SESSION array is null when accessed from app.farawaydom.com .
Is there any solution to this issue?
Thank you in advance.
https://redd.it/1mxn4fv
@r_php
Hi, everybody!
I have the following situation. A web page is in a subdirectory of my domain:
[`https://myowndomain.com/app`](https://myowndomain.com/app)
And it works fine.
Now, a subdomain was made in another domain that points to the previously mentioned web page:
`https://app.farawaydom.com -> https://myowndomain.com/app`
Works fine except that the $\SESSION array is null when accessed from app.farawaydom.com .
Is there any solution to this issue?
Thank you in advance.
https://redd.it/1mxn4fv
@r_php
PHP Performance Benchmarking
Hi There,
I'm looking for multiple studies regarding PHP performance in scenarios of CPU model difference of Intel VS AMD
I want to find on which specific scenarios - which would serve better.
Are there any studies conducting such tests to see if there are any actual difference in reality?
https://redd.it/1mxxxfx
@r_php
Hi There,
I'm looking for multiple studies regarding PHP performance in scenarios of CPU model difference of Intel VS AMD
I want to find on which specific scenarios - which would serve better.
Are there any studies conducting such tests to see if there are any actual difference in reality?
https://redd.it/1mxxxfx
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
Pretend - Impersonate users with ease
https://github.com/horlerdipo/pretend
https://redd.it/1mxxpl0
@r_php
https://github.com/horlerdipo/pretend
https://redd.it/1mxxpl0
@r_php
GitHub
GitHub - Horlerdipo/pretend: A simple package to impersonate users when building APIs with Laravel Sanctum, allowing administrators…
A simple package to impersonate users when building APIs with Laravel Sanctum, allowing administrators to generate temporary tokens and act on behalf of other users without using sessions. - Horler...
I've published my first PHP app as a Docker image
I've just published the Docker image I asked some advice about here a few days ago.
https://www.reddit.com/r/PHP/comments/1mq53si/best\_strategies\_to\_distribute\_a\_php\_app\_in\_a/
First of all, I would like to thank all those who commented the post. I received many useful tips which helped me to build the image. So which decisions did I make?
1. No Composer in the image. The Dockerfile runs the Composer commands during the build process, and do not include Composer in the final image. As a result, the image starts very fast, even at the first run.
2. Run Composer in a separate stage, then copy the vendor dir and other useful files to the final image. Another advice received here. I hope this way no unexpected files are included in the image.
What I think I could have done.
1. Use FrankenPHP. It it simpler to setup than Nginx Unit, but it costs an extra 30Mb or more in the final image.
2. Run Composer after the build. I feel a little bit uncomfortable about including the vendor dir in the image. A composer.lock file and the appropriate Composer commands executed in the container entry point provide the same result, without any notable security issue, afaik. Maybe I care too much about the Packagist stats of those open source packages, and not enough about the container immutability.
3. Use a makefile or another tool for advance configuration. It could have made sense for a more complex setup, but the requirements here are simple enough to be tackled with a few cli commands.
The resulting image is available here: https://hub.docker.com/r/lagdo/jaxon-dbadmin, and the Dockerfile is here: https://github.com/lagdo/dbadmin-app/tree/main/docker.
I'll explain what the application is in a next post.
Thanks again for all your contributions.
https://redd.it/1my2rld
@r_php
I've just published the Docker image I asked some advice about here a few days ago.
https://www.reddit.com/r/PHP/comments/1mq53si/best\_strategies\_to\_distribute\_a\_php\_app\_in\_a/
First of all, I would like to thank all those who commented the post. I received many useful tips which helped me to build the image. So which decisions did I make?
1. No Composer in the image. The Dockerfile runs the Composer commands during the build process, and do not include Composer in the final image. As a result, the image starts very fast, even at the first run.
2. Run Composer in a separate stage, then copy the vendor dir and other useful files to the final image. Another advice received here. I hope this way no unexpected files are included in the image.
What I think I could have done.
1. Use FrankenPHP. It it simpler to setup than Nginx Unit, but it costs an extra 30Mb or more in the final image.
2. Run Composer after the build. I feel a little bit uncomfortable about including the vendor dir in the image. A composer.lock file and the appropriate Composer commands executed in the container entry point provide the same result, without any notable security issue, afaik. Maybe I care too much about the Packagist stats of those open source packages, and not enough about the container immutability.
3. Use a makefile or another tool for advance configuration. It could have made sense for a more complex setup, but the requirements here are simple enough to be tackled with a few cli commands.
The resulting image is available here: https://hub.docker.com/r/lagdo/jaxon-dbadmin, and the Dockerfile is here: https://github.com/lagdo/dbadmin-app/tree/main/docker.
I'll explain what the application is in a next post.
Thanks again for all your contributions.
https://redd.it/1my2rld
@r_php
Reddit
From the PHP community on Reddit
Explore this post and more from the PHP community
Laisser la production en mode dev
Bonjour
Je fais ce post suite à un projet communautaire pour un serveur minecraft qui est une plateforme de vente d'objets en symfony.
Lors du passage en production (le premier de toute ma vie), j'ai eu de très nombreux problèmes notamment liés au mapping et au versioning des images.
Depuis, même après 6 heures de debug le problème est le suivant:
Si le projet est en mode dev, aucune erreur et les couleurs custom de tailwind sont bien appliquées.
si le projet est en mode prod, les images ne chargent plus et les couleurs de tailwind sont toutes remplacées par un bleu clair par défaut.
Quels sont les risques à laisser l'application en mode dev même pour les utilisateurs? Il n'y a aucune donnée sensible ni aucune manipulation d'argent, donc j'hésite vraiment à utiliser cette solution bien qu'elle relève de la facilité.
Je suis à l'écoute de vos solutions / avis
https://redd.it/1my4g7a
@r_php
Bonjour
Je fais ce post suite à un projet communautaire pour un serveur minecraft qui est une plateforme de vente d'objets en symfony.
Lors du passage en production (le premier de toute ma vie), j'ai eu de très nombreux problèmes notamment liés au mapping et au versioning des images.
Depuis, même après 6 heures de debug le problème est le suivant:
Si le projet est en mode dev, aucune erreur et les couleurs custom de tailwind sont bien appliquées.
si le projet est en mode prod, les images ne chargent plus et les couleurs de tailwind sont toutes remplacées par un bleu clair par défaut.
Quels sont les risques à laisser l'application en mode dev même pour les utilisateurs? Il n'y a aucune donnée sensible ni aucune manipulation d'argent, donc j'hésite vraiment à utiliser cette solution bien qu'elle relève de la facilité.
Je suis à l'écoute de vos solutions / avis
https://redd.it/1my4g7a
@r_php
Reddit
From the symfony community on Reddit
Explore this post and more from the symfony community