after voyage package installation with this command :
php artisan voyager:install
I needed to create admin user with this command :
php artisan voyager:admin your@email.com --create
and then entering the name and the password
The problem is after entering the username and the password it's returning this error
General error: 1364 Field 'employee_name' doesn't have a default value (SQL: insert into
employee
(
and I have already a database but with different naming convention for example: the users table I call it employee and the name field called employee_name
My question is , is there any way to map the expected fields in voyager with my actual fields in my database because I can't change them ?
Thanks in advance .
Since you altered the normal structure of the User model and will likely run into similar issues with other packages that try to add users, you could create a boot() method in the user model to set this->employee_name to this->name and then unset this->name so that when records from other packages try to use the name attribute you correct it to the employee_name attribute.
This is off the top of my head based on memory so it may involve a bit more 'logic' but I think if you look into the boot method you will see that you can do this type of thing. I have used it to autofill columns with dynamically based values.
HTH
When you're executing this command, Voyager creates a new user for you using the mass assignment feature.
So, add $fillable
to the User
model:
protected $fillable = ['name', 'email', 'password'];
General error: 1364 Field 'employee_name' doesn't have a default value
You can set default value to null in your database this solves the problem
Use Mutator to refer any attempt to add data to 'name' column to 'employee_name'.
For your case:
App\\User.php
public function setNameAttribute($value)
{
$this->attributes['employee_name'] = $value;
}
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.