Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Laravel is returning 0 for model id on production server ( Forge )

Tags:

php

laravel

I have a strange scenario where Laravel is returning a 0 for the ID. This works locally and I've also confirmed the model saves and returns the ID correctly in another function. Why is the ID always 0? ( The model always saves successfully ).

The ID column is auto-incrementing.

//MODEL

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);
}
}

//Controller

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]);
}

//Output of the dump

    array:15 [
  "to" => "58"
  "name" => "joe"
  "email" => "[email protected]"
  "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
]
like image 976
jhodgson4 Avatar asked Oct 16 '25 20:10

jhodgson4


1 Answers

It was a issue with telescope. As said in the comments, this was the issue: https://github.com/laravel/telescope/issues/289

It looks like it is now fixed, btw.

like image 100
Gonzalo De-Spirito Avatar answered Oct 18 '25 11:10

Gonzalo De-Spirito



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!