Add Update Profile
This commit is contained in:
@@ -7,6 +7,7 @@ use App\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Modules\Linksehat\Transformers\UserProfileResource;
|
||||
use Validator;
|
||||
|
||||
class AuthController extends Controller
|
||||
@@ -103,7 +104,7 @@ class AuthController extends Controller
|
||||
|
||||
return response([
|
||||
'message' => 'Selamat Datang',
|
||||
'user' => $user,
|
||||
'user' => UserProfileResource::make($user),
|
||||
'token' => $user->createToken('app')->plainTextToken
|
||||
]);
|
||||
}
|
||||
@@ -156,7 +157,7 @@ class AuthController extends Controller
|
||||
]);
|
||||
|
||||
$user = User::where((filter_var($request->phone_or_email, FILTER_VALIDATE_EMAIL) ? 'email' : 'phone'), $request->phone_or_email)->first();
|
||||
|
||||
|
||||
if ($user) {
|
||||
return response()->json([
|
||||
'message' => 'OTP Anda',
|
||||
|
||||
137
Modules/Linksehat/Http/Controllers/Api/ProfileController.php
Normal file
137
Modules/Linksehat/Http/Controllers/Api/ProfileController.php
Normal file
@@ -0,0 +1,137 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Linksehat\Http\Controllers\Api;
|
||||
|
||||
use App\Models\User;
|
||||
use Illuminate\Contracts\Support\Renderable;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller;
|
||||
use Modules\Linksehat\Transformers\UserProfileResource;
|
||||
|
||||
class ProfileController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
$user = auth()->user();
|
||||
$user->load('person');
|
||||
|
||||
return response()->json([
|
||||
'user' => UserProfileResource::make($user)
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
return view('linksehat::create');
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
* @param Request $request
|
||||
* @return Renderable
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the specified resource.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
return view('linksehat::show');
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
return view('linksehat::edit');
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
* @param Request $request
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function update(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'nik' => 'numeric',
|
||||
'name_prefix' => '',
|
||||
'name' => '',
|
||||
'name_suffix' => '',
|
||||
'gender' => 'in:P,L',
|
||||
'birth_date' => 'sometimes:date',
|
||||
// 'is_deceased' => '',
|
||||
'deceased_at' => 'sometimes:date',
|
||||
'marital_status' => 'in:S,M,C',
|
||||
'preferred_lang' => 'in:id,en'
|
||||
]);
|
||||
|
||||
$user = auth()->user();
|
||||
if ($user->person) { // Update Profile
|
||||
$user->person->fill($request->only([
|
||||
'nik', 'name_prefix', 'name', 'name_suffix', 'gender', 'birth_date', 'deceased_at', 'marital_status'
|
||||
]))->save();
|
||||
|
||||
if ($request->has('preferred_lang')) {
|
||||
$user->metas()->updateOrCreate([
|
||||
'type' => 'preferred_lang'
|
||||
], [
|
||||
'system' => 'default',
|
||||
'type' => 'preferred_lang',
|
||||
'value' => $request->preferred_lang,
|
||||
]);
|
||||
}
|
||||
} else { // Create If Not Exist
|
||||
$newPerson = array_merge(
|
||||
$request->only([
|
||||
'nik', 'name_prefix', 'name', 'name_suffix', 'gender', 'birth_date', 'deceased_at', 'marital_status'
|
||||
]),
|
||||
['user_owner_id' => $user->id]
|
||||
);
|
||||
$newPerson = $user->person()->create($newPerson);
|
||||
$user->person_id = $newPerson->id;
|
||||
$user->save();
|
||||
|
||||
if ($request->has('preferred_lang')) {
|
||||
$user->metas()->updateOrCreate([
|
||||
'type' => 'preferred_lang'
|
||||
], [
|
||||
'system' => 'default',
|
||||
'type' => 'preferred_lang',
|
||||
'value' => $request->preferred_lang,
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
$user = User::find($user->id); // ReLoad User Data
|
||||
return response()->json(UserProfileResource::make($user));
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
||||
@@ -4,6 +4,7 @@ use Illuminate\Http\Request;
|
||||
use Modules\Linksehat\Http\Controllers\Api\AuthController;
|
||||
use Modules\Linksehat\Http\Controllers\Api\DoctorController;
|
||||
use Modules\Linksehat\Http\Controllers\Api\HospitalController;
|
||||
use Modules\Linksehat\Http\Controllers\Api\ProfileController;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
@@ -15,7 +16,7 @@ use Modules\Linksehat\Http\Controllers\Api\HospitalController;
|
||||
| is assigned the "api" middleware group. Enjoy building your API!
|
||||
|
|
||||
*/
|
||||
Route::domain('api.linksehat.dev')->prefix('linksehat')->group(function () {
|
||||
Route::prefix('linksehat')->group(function () {
|
||||
|
||||
Route::post('otp-request', [AuthController::class, 'otpRequest']);
|
||||
Route::post('mock-otp', [AuthController::class, 'mockOtp']);
|
||||
@@ -33,7 +34,13 @@ Route::domain('api.linksehat.dev')->prefix('linksehat')->group(function () {
|
||||
Route::get('doctors/{id}', [DoctorController::class, 'show']);
|
||||
Route::get('doctors/{id}/schedule', [DoctorController::class, 'schedule']);
|
||||
|
||||
Route::middleware('auth:api')->get('/linksehat', function (Request $request) {
|
||||
return $request->user();
|
||||
// Route::middleware('auth:api')->get('/linksehat', function (Request $request) {
|
||||
// return $request->user();
|
||||
// });
|
||||
|
||||
|
||||
Route::middleware('auth:sanctum')->group(function () {
|
||||
Route::get('profile', [ProfileController::class, 'index'])->name('profile');
|
||||
Route::post('profile', [ProfileController::class, 'update'])->name('profile.update');
|
||||
});
|
||||
});
|
||||
36
Modules/Linksehat/Transformers/UserProfileResource.php
Normal file
36
Modules/Linksehat/Transformers/UserProfileResource.php
Normal file
@@ -0,0 +1,36 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Linksehat\Transformers;
|
||||
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class UserProfileResource extends JsonResource
|
||||
{
|
||||
/**
|
||||
* Transform the resource into an array.
|
||||
*
|
||||
* @param \Illuminate\Http\Request
|
||||
* @return array
|
||||
*/
|
||||
public function toArray($request)
|
||||
{
|
||||
return [
|
||||
'id' => $this->id,
|
||||
'email' => $this->email,
|
||||
'phone' => $this->phone,
|
||||
'email_verified_at' => $this->email_verified_at,
|
||||
'nik' => $this->person->nik ?? null,
|
||||
'name_prefix' => $this->person->name_prefix ?? null,
|
||||
'name' => $this->person->name ?? null,
|
||||
'name_suffix' => $this->person->name_suffix ?? null,
|
||||
'full_name' => $this->person->full_name ?? null,
|
||||
'gender' => $this->person->gender ?? null,
|
||||
'birth_date' => $this->person->birth_date ?? null,
|
||||
'age' => $this->person->age ?? null,
|
||||
'is_deceased' => $this->person->is_deceased ?? null,
|
||||
'deceased_at' => $this->person->deceased_at ?? null,
|
||||
'marital_status' => $this->person->marital_status ?? null,
|
||||
'preferred_lang' => $this->meta->preferred_lang ?? 'id',
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -12,6 +12,7 @@ class Person extends Model
|
||||
protected $table = 'persons';
|
||||
|
||||
protected $fillable = [
|
||||
'owner_user_id',
|
||||
'nik',
|
||||
'name_prefix',
|
||||
'name',
|
||||
@@ -46,4 +47,9 @@ class Person extends Model
|
||||
{
|
||||
return $this->morphMany(Meta::class, 'metaable');
|
||||
}
|
||||
|
||||
public function owner()
|
||||
{
|
||||
return $this->belongsTo(User::class, 'owner_user_id');
|
||||
}
|
||||
}
|
||||
|
||||
@@ -18,12 +18,13 @@ class User extends Authenticatable
|
||||
* @var array<int, string>
|
||||
*/
|
||||
protected $fillable = [
|
||||
'person_id',
|
||||
'name',
|
||||
'email',
|
||||
'password',
|
||||
'phone',
|
||||
'otp',
|
||||
'otp_created_at'
|
||||
'otp_created_at',
|
||||
];
|
||||
|
||||
/**
|
||||
@@ -46,8 +47,32 @@ class User extends Authenticatable
|
||||
'otp_created_at' => 'datetime'
|
||||
];
|
||||
|
||||
public $appends = [
|
||||
'meta'
|
||||
];
|
||||
|
||||
public function getMetaAttribute()
|
||||
{
|
||||
$orgMeta = [];
|
||||
foreach ($this->metas as $meta) {
|
||||
$orgMeta[$meta->type] = $meta->value;
|
||||
}
|
||||
|
||||
return (object) $orgMeta;
|
||||
}
|
||||
|
||||
public function managedCorporates()
|
||||
{
|
||||
return $this->belongsToMany(Corporate::class, 'corporate_manager', 'user_id', 'corporate_id');
|
||||
}
|
||||
|
||||
public function metas()
|
||||
{
|
||||
return $this->morphMany(Meta::class, 'metaable');
|
||||
}
|
||||
|
||||
public function person()
|
||||
{
|
||||
return $this->belongsTo(Person::class, 'person_id');
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,40 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
return new class extends Migration
|
||||
{
|
||||
/**
|
||||
* Run the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function up()
|
||||
{
|
||||
Schema::table('users', function (Blueprint $table) {
|
||||
$table->foreignId('person_id')->nullable()->after('id');
|
||||
});
|
||||
|
||||
Schema::table('persons', function (Blueprint $table) {
|
||||
$table->foreignId('owner_user_id')->nullable()->after('id');
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Reverse the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function down()
|
||||
{
|
||||
Schema::table('users', function (Blueprint $table) {
|
||||
$table->dropColumn('person_id');
|
||||
});
|
||||
|
||||
Schema::table('persons', function (Blueprint $table) {
|
||||
$table->dropColumn('owner_user_id');
|
||||
});
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user