| Conditions | 3 |
| Paths | 3 |
| Total Lines | 11 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 10 | public function hasFeature($featureName) |
||
| 11 | { |
||
| 12 | $model = FeatureModel::where('name', '=', $featureName)->first(); |
||
| 13 | |||
| 14 | if ((bool) $model->is_enabled === true) { |
||
| 15 | return true; |
||
| 16 | } |
||
| 17 | |||
| 18 | $feature = $this->features()->where('name', '=', $featureName)->first(); |
||
| 19 | return ($feature) ? true : false; |
||
| 20 | } |
||
| 21 | |||
| 27 |
This check looks for methods that are used by a trait but not required by it.
To illustrate, let’s look at the following code example
The trait
Idableprovides a methodequalsIdthat in turn relies on the methodgetId(). If this method does not exist on a class mixing in this trait, the method will fail.Adding the
getId()as an abstract method to the trait will make sure it is available.