-
Notifications
You must be signed in to change notification settings - Fork 11.2k
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
[5.8] Allow belongsToMany to take Model/Pivot class name as a second parameter #27774
Conversation
I don't understand why. The current code is perfectly fine, isn't it? Only to save a few lines? |
@mfn it's useful for someone who uses Pivot models, especially with custom intermediate table names. As I have noted the old behavior is not changed and there is no breaking change introduced. Pivot class is an extension of a Model class, and until now setting I hope I have cleared your doubts that it's not just to save a few lines (even so Code Less. Do More.) edit $pivotClass = CustomerProfile::class;
return $this->belongsToMany(Profile::class, (new $pivotClass)->getTable())->using($pivotClass); |
return $object->getTable(); | ||
} | ||
|
||
return $class; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What's a scenario where this line (212
) is reached?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Line (212
) is reached when a given table name can't be resolved as an instance of a Model class, so in all other cases it just fallback to the old behavior.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So for the rare case that a table name coincidentally is also a valid class name?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My code checks if the given table name is a valid class name but also extends Model / Pivot class. The only rare case I could think of could be when user has a Pivot class named "customers_profiles " without a namespace and uses "customers_profiles" string as a second parameter for belongsToMany:
// note: no namespace used
class customers_profiles extends Pivot
{
protected $table = 'customers_profiles';
}
......
return $this->belongsToMany(Profile::class, 'customers_profiles')
In this case, my code will see that's the valid Pivot class, will try to load Pivot model and take table name through getTable() method.
dd((new customers_profiles)->getTable());
// gives back "customers_profiles" string,
// or
// auto-generated value "customers_profile" when user has not defined $table attribute
All other cases I could think of should fallback to an old behavior.
I think the following very rare case should not be an issue. Let me know if I missed something.
Thanks.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
p.s. I have slightly adjusted the code flow / naming.
Thanks, makes sense to me 👍 |
@linaspasv it would make more chance of being accepted if the PR contains a test as well. |
Overview
The motivation behind this RP is to allow a non-hardcoded intermediate table name assignments in belongsToMany relationship. The proposed PR does not alter old behavior but improves and provides more integrity for people using Pivot models.
Example
Example of current usage (hardcoded):
Example of current usage (dynamic):
Example of (possible) usage after PR (improved behavior does not require to define Pivot through using):