Laravel 5.1 и Cashier не взаимодействуют с $user должным образом

Когда я регистрирую нового пользователя, методы Cashier отлично работают для регистрации этого пользователя. Например, у меня есть это в моей модели пользователя:

public static function registerUser()
{
$user = new User;
$stripeToken = Input::get('stripeToken');
$user->subscription('yearly')->create($stripeToken);
$user->save();
}

У меня также есть метод «повторной подписки» в моей модели пользователя, который использует аналогичные методы кассира:

public static function resubscribe(){
    $email = Input::get('email');
    $user = DB::table('users')->where('email', '=', $email)->first();
    if ($user->everSubscribed()) {
        $credentials = Input::only(['email', 'password']);
        $stripeToken = Input::get('stripeToken');
        $user->subscription('monthly')->resume($stripeToken);
        $user->save(); 
     }
}

и я получаю следующую ошибку: «Вызов неопределенного метода stdClass::everSubscribed()».

Если я удаляю это условие, я получаю следующую ошибку: «FatalErrorException в строке 124 User.php: вызов неопределенного метода stdClass::subscription()»

Если я заменю эти строки кода:

$email = Input::get('email');
$user = DB::table('users')->where('email', '=', $email)->first();

с этим:

$user = new User;

Тогда я не получаю ошибок, но, конечно, я не хочу создавать нового пользователя, я хочу переподписать своего старого пользователя. У меня это отлично работало в Laravel 4.2 с почти идентичным кодом. Спасибо за любую помощь!


person    schedule 08.08.2015    source источник


Ответы (1)


Вам нужно использовать Eloquent вместо Query Builder:

$user = User::where('email', '=', $email)->first();

Построитель запросов DB::table('users')->where('email', '=', $email)->first() возвращает объект stdClass, а не экземпляр вашей модели пользователя.

person Ben Claar    schedule 08.08.2015