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

Crash with closures created from methods with method-only attributes #110

Open
danog opened this issue Mar 7, 2025 · 1 comment
Open

Comments

@danog
Copy link

danog commented Mar 7, 2025

Serializable Closure Version

2.0.3

PHP Version

8.4.4

Description

The following fatal error is emitted when serializing closures created from class methods with attributes that can target only methods and not functions.

PHP Fatal error:  Attribute "MyAttribute" cannot target function (allowed targets: method) in laravel-serializable-closure://#[MyAttribute()]
function (): void {
        \var_dump("hello");
    } on line 3

Steps To Reproduce

<?php

use Laravel\SerializableClosure\SerializableClosure;

require 'vendor/autoload.php';

class a {
    public function test(): void {}
}
class b extends a {
    #[\Override]
    public function test(): void {
        var_dump("hello");
    }
}

$a = new SerializableClosure((new b)->test(...));
$a = unserialize(serialize($a));

$a();
Copy link

github-actions bot commented Mar 7, 2025

Thank you for reporting this issue!

As Laravel is an open source project, we rely on the community to help us diagnose and fix issues as it is not possible to research and fix every issue reported to us via GitHub.

If possible, please make a pull request fixing the issue you have described, along with corresponding tests. All pull requests are promptly reviewed by the Laravel team.

Thank you!

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

No branches or pull requests

2 participants