user model is added login/logout

This commit is contained in:
Abhishek Mali
2025-11-07 17:34:56 +05:30
parent 5b764c7597
commit 7c7ac7683a
10 changed files with 375 additions and 92 deletions

View File

@@ -0,0 +1,34 @@
<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\MarkList;
class AdminMarkListController extends Controller
{
/**
* Show all mark list entries in descending order (latest first)
*/
public function index()
{
$markList = MarkList::orderBy('id', 'desc')->get();
return view('admin.mark_list', compact('markList'));
}
/**
* Toggle status between Active and Inactive
*/
public function toggleStatus($id)
{
$mark = MarkList::findOrFail($id);
// Toggle logic
$mark->status = $mark->status === 'active' ? 'inactive' : 'active';
$mark->save();
return redirect()->back()->with('success', 'Status updated successfully!');
}
}

View File

@@ -0,0 +1,95 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models\MarkList;
use App\Models\User;
use Carbon\Carbon;
use PHPOpenSourceSaver\JWTAuth\Facades\JWTAuth;
class MarkListController extends Controller
{
/**
* Add new Mark No (entered by user)
*/
public function addmarkno(Request $request)
{
try {
// Validate input
$request->validate([
'mark_no' => 'required|string|max:255|unique:mark_list,mark_no',
'origin' => 'required|string|max:255',
'destination' => 'required|string|max:255',
]);
} catch (\Illuminate\Validation\ValidationException $e) {
// Check if the mark_no uniqueness failed
if (isset($e->validator->failed()['mark_no']['Unique'])) {
return response()->json([
'success' => false,
'message' => 'Mark No already taken by another customer.'
], 400);
}
// Default validation error
return response()->json([
'success' => false,
'message' => $e->getMessage()
], 400);
}
// Authenticate user via JWT
$user = JWTAuth::parseToken()->authenticate();
if (!$user) {
return response()->json([
'success' => false,
'message' => 'Unauthorized'
], 401);
}
// Create mark record
$mark = MarkList::create([
'mark_no' => $request->mark_no,
'origin' => $request->origin,
'destination' => $request->destination,
'customer_id' => $user->customer_id,
'customer_name' => $user->customer_name,
'company_name' => $user->company_name,
'mobile_no' => $user->mobile_no,
'date' => Carbon::now()->toDateString(),
'status' => 'active',
]);
return response()->json([
'success' => true,
'message' => 'Mark No added successfully.',
'data' => $mark
], 200);
}
/**
* Show all marks for the logged-in user
*/
public function showmarklist()
{
$user = JWTAuth::parseToken()->authenticate();
if (!$user) {
return response()->json([
'success' => false,
'message' => 'Unauthorized'
], 401);
}
$marks = MarkList::where('customer_id', $user->customer_id)
->orderBy('id', 'desc')
->get();
return response()->json([
'success' => true,
'data' => $marks
]);
}
}

View File

@@ -2,28 +2,24 @@
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class MarkList extends Model
{
protected $table = 'mark_lists';
use HasFactory;
protected $table = 'mark_list';
protected $fillable = [
'mark_no', // e.g., MARK-2025-000001
'mark_no',
'origin',
'destination',
'customer_name',
'mobile_no',
'customer_id',
'customer_name',
'company_name',
'mobile_no',
'date',
'status',
'status'
];
/**
* Relationship: each mark list belongs to a customer (user)
*/
public function customer()
{
return $this->belongsTo(User::class, 'customer_id');
}
}