Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add middleware to web to save session #1710

Merged
merged 1 commit into from
Dec 23, 2024
Merged

Add middleware to web to save session #1710

merged 1 commit into from
Dec 23, 2024

Conversation

barryvdh
Copy link
Owner

The Web middlewaregoup contains the SaveSession middleware, which closes the session. This makes it impossible (as far as I can tell) to save to the session, eg. for redirects.

This will add the middleware to both the regular and the normal group. It will still only boot once and inject once because of the checks, but this should make redirects work again, without any of the workarounds. (#1666 #1662 #1657 #1613 #1591 #1574 #1573) and fixes #1704

@barryvdh barryvdh merged commit af53eda into master Dec 23, 2024
33 checks passed
@shawe
Copy link

shawe commented Dec 26, 2024

It doesn't seem enough for the case where I detected it.

My test case is this:

<?php

namespace App\Http\Requests;

use Barryvdh\Debugbar\Facades\Debugbar;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Support\Facades\Log;

class FormRequestValidation extends FormRequest
{
    protected function failedValidation(Validator $validator)
    {
        // Add a message to the Laravel Debugbar
        Debugbar::addMessage($validator->errors()->toArray(), 'Validation failed');
        // Add a message to the Laravel Log
        Log::debug('Validation failed: ' . json_encode($validator->errors()->toArray(), JSON_PRETTY_PRINT));

        // Call the default behavior (throws ValidationException)
        parent::failedValidation($validator);
    }
}

This must show the list of errors when a form is not validated here, but it's not showed.

image

@barryvdh
Copy link
Owner Author

Does the dropdown menu not show up on the right side?

@shawe
Copy link

shawe commented Dec 26, 2024

Does the dropdown menu not show up on the right side?

Yes, and it is in the last request, which should have and display an addMessage capturing the form validation errors.

This may be a very particular problem using Livewire, as it intercepts a thrown exception. I can't remember any other circumstances where I encountered the same problem without using Livewire, so I'll try to see if this fixes it in that case when I remember.

@barryvdh
Copy link
Owner Author

In a redirect, it shows the latest request as last, so you should see the log messages on the first. is that the cases with this PR, or do you not see them at all?

@shawe
Copy link

shawe commented Dec 26, 2024

In a redirect, it shows the latest request as last, so you should see the log messages on the first. is that the cases with this PR, or do you not see them at all?

In this case there is no redirection, the debugbar was showing the last request without problems, the problem it's apparently only with added messages from any type. I have tabs with no data disabled, so there are fewer visible options because they are empty.

@barryvdh
Copy link
Owner Author

Is this livewire? Or why is there no redirect?

@shawe
Copy link

shawe commented Dec 26, 2024

Is this livewire? Or why is there no redirect?

Yes, I say you here:

Does the dropdown menu not show up on the right side?

Yes, and it is in the last request, which should have and display an addMessage capturing the form validation errors.

This may be a very particular problem using Livewire, as it intercepts a thrown exception. I can't remember any other circumstances where I encountered the same problem without using Livewire, so I'll try to see if this fixes it in that case when I remember.

@eusonlito
Copy link

eusonlito commented Dec 30, 2024

@barryvdh this commit introduces a bug when the application does not have a web middleware.

After upgrading your package to v3.14.10, I encounter the following:

> @php artisan optimize:clear --ansi

   InvalidArgumentException 

  The [web] middleware group has not been defined.

  at vendor/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php:408
    404▕      */
    405▕     public function appendMiddlewareToGroup($group, $middleware)
    406▕     {
    407▕         if (! isset($this->middlewareGroups[$group])) {
  ➜ 408▕             throw new InvalidArgumentException("The [{$group}] middleware group has not been defined.");
    409▕         }
    410▕ 
    411▕         if (array_search($middleware, $this->middlewareGroups[$group]) === false) {
    412▕             $this->middlewareGroups[$group][] = $middleware;

      +9 vendor frames 

  10  [internal]:0
      Illuminate\Foundation\Application::Illuminate\Foundation\{closure}()
      +5 vendor frames 

  16  artisan:35
      Illuminate\Foundation\Console\Kernel::handle()

@barryvdh
Copy link
Owner Author

Are you on the dev version?

@barryvdh barryvdh mentioned this pull request Dec 30, 2024
@barryvdh
Copy link
Owner Author

Can you try to update? I've made a fix

@barryvdh barryvdh deleted the feat-web-middleware branch December 30, 2024 09:30
@eusonlito
Copy link

@barryvdh fixed. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

A lot of issues with not working addMessage in stale state and never solved
3 participants