Laravel возвращает 0 для идентификатора модели на рабочем сервере (Forge) - PullRequest
0 голосов
/ 04 ноября 2018

У меня странный сценарий, когда Laravel возвращает 0 для идентификатора. Это работает локально, и я также подтвердил, что модель правильно сохраняет и возвращает идентификатор в другой функции. Почему идентификатор всегда 0? (Модель всегда успешно сохраняет).

Столбец ID автоматически увеличивается.

// * MODEL 1005 *

class Email extends Model
{
public $fillable = ['to', 'from', 'relates_to', 'name', 'email',
 'subject', 'greeting','attachment',
'body', 'module_id', 'sign_off', 'course_id' ];

protected $casts = ['attachment'=>'integer'];

protected $dates = ['sent_at'];

public function scopeMine($query, $user)
{
    return $query->where('from', $user);
}
}

// Контроллер

public function storeAndSend(Request $request)
{
    $validatedData = $request->validate([
        'subject' => 'sometimes|required|string',
        'greeting' => 'required',
        'body' => 'required',
        'sign_off' => 'required',
        'email' => 'required|email',
        'module_id' => 'required',
        'name' => 'required|string'
    ]);

    //save Email   
    $email = new \App\Email;
    $email->to = $request->has('user') ? $request->user : 0;
    $email->name = $request->name;
    $email->email = $request->email;
    $email->relates_to = $request->has('entity') ? $request->entity : null;
    $email->from   = $request->user()->id;
    $email->subject = $request->subject;
    $email->greeting = $request->greeting;
    $email->attachment = $request->attachment ?? null;
    $email->body = $request->body;
    $email->sign_off = $request->sign_off;
    $email->course_id = $request->course_id;
    $email->module_id = $request->module_id ?? null;

    $email->save();
    dd($email->toArray()); // $email->id = 0

    //get to
    dispatch(new \App\Jobs\SendCourse($email->id));

    return response()->json(['success'=>true]);
}

// Вывод дампа

    array:15 [
  "to" => "58"
  "name" => "joe"
  "email" => "joe@boobo.com"
  "relates_to" => "App\User"
  "from" => 1
  "subject" => "test"
  "greeting" => "Hello"
  "attachment" => null
  "body" => "<p>test</p>"
  "sign_off" => "Catch you later"
  "course_id" => 27
  "module_id" => -1
  "updated_at" => "2018-11-04 14:00:59"
  "created_at" => "2018-11-04 14:00:59"
  "id" => 0
]

1 Ответ

0 голосов
/ 13 ноября 2018

Это была проблема с телескопом. Как сказано в комментариях, это была проблема: https://github.com/laravel/telescope/issues/289

Похоже, что теперь это исправлено, кстати.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...