integrasi api

This commit is contained in:
ghozahimma65 2026-02-11 16:45:34 +07:00
parent d8a8ce647a
commit 0252aa5300
6 changed files with 276 additions and 34 deletions

View File

@ -0,0 +1,35 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class AuthController extends Controller
{
public function login(Request $request)
{
$credentials = $request->only('email', 'password');
if (Auth::attempt($credentials)) {
$user = Auth::user();
return response()->json([
'success' => true,
'message' => 'Login Berhasil',
'user' => $user
], 200);
}
return response()->json([
'success' => false,
'message' => 'Email atau Password salah'
], 401);
}
public function logout()
{
Auth::logout();
return response()->json(['message' => 'Berhasil Logout']);
}
}

View File

@ -0,0 +1,86 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\Anekdot;
use App\Models\HasilKarya;
use App\Models\Penjemputan;
use Illuminate\Support\Facades\Storage;
class GuruController extends Controller
{
// 1. Input Catatan Anekdot
public function storeAnekdot(Request $request)
{
$request->validate([
'siswa_id' => 'required',
'tanggal' => 'required|date',
'kejadian_teramati' => 'required',
'analisis_capaian' => 'required',
]);
// Otomatis isi guru_id dari user yang login
$data = $request->all();
$data['guru_id'] = $request->user()->id;
Anekdot::create($data);
return response()->json(['success' => true, 'message' => 'Anekdot berhasil disimpan']);
}
// 2. Input Hasil Karya (Upload Foto)
public function storeKarya(Request $request)
{
$request->validate([
'siswa_id' => 'required',
'tanggal' => 'required|date',
'foto' => 'required|image|max:5120', // Max 5MB
'analisis_capaian' => 'required',
]);
// Upload Foto
$path = null;
if ($request->hasFile('foto')) {
$path = $request->file('foto')->store('karya', 'public');
}
HasilKarya::create([
'siswa_id' => $request->siswa_id,
'guru_id' => $request->user()->id,
'tanggal' => $request->tanggal,
'foto' => $path,
'deskripsi_foto' => $request->deskripsi_foto,
'analisis_capaian' => $request->analisis_capaian,
]);
return response()->json(['success' => true, 'message' => 'Karya berhasil disimpan']);
}
// 3. Input Penjemputan (Scan QR)
public function storePenjemputan(Request $request)
{
$request->validate([
'siswa_id' => 'required',
'nama_penjemput' => 'required',
'status_hubungan' => 'required',
'foto' => 'nullable|image',
]);
$pathFoto = null;
if ($request->hasFile('foto')) {
$pathFoto = $request->file('foto')->store('penjemputan', 'public');
}
Penjemputan::create([
'siswa_id' => $request->siswa_id,
'nama_penjemput' => $request->nama_penjemput,
'status_hubungan' => $request->status_hubungan,
'foto_bukti' => $pathFoto,
'waktu_jemput' => now(),
]);
return response()->json(['success' => true, 'message' => 'Data penjemputan tercatat']);
}
}

View File

@ -0,0 +1,73 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\Anekdot;
use App\Models\HasilKarya;
use App\Models\Penjemputan;
use App\Models\Siswa;
class LaporanController extends Controller
{
// Fungsi Helper untuk Cek Akses
private function cekAksesAnak($user, $siswaId)
{
$wali = $user->waliMurid;
if (!$wali) return false;
// Cek apakah siswa ini benar anak dari wali tersebut
$isAnakSendiri = Siswa::where('id', $siswaId)->where('wali_id', $wali->id)->exists();
return $isAnakSendiri;
}
public function getAnekdot(Request $request)
{
$request->validate(['siswa_id' => 'required']);
if (!$this->cekAksesAnak($request->user(), $request->siswa_id)) {
return response()->json(['message' => 'Akses ditolak. Ini bukan data anak Anda.'], 403);
}
$data = Anekdot::where('siswa_id', $request->siswa_id)->latest()->get();
return response()->json(['success' => true, 'data' => $data]);
}
public function getKarya(Request $request)
{
$request->validate(['siswa_id' => 'required']);
if (!$this->cekAksesAnak($request->user(), $request->siswa_id)) {
return response()->json(['message' => 'Akses ditolak.'], 403);
}
$data = HasilKarya::where('siswa_id', $request->siswa_id)->latest()->get();
// Tambahkan URL lengkap foto biar bisa muncul di HP
$data->transform(function ($item) {
$item->foto_url = $item->foto ? asset('storage/' . $item->foto) : null;
return $item;
});
return response()->json(['success' => true, 'data' => $data]);
}
public function getPenjemputan(Request $request)
{
$request->validate(['siswa_id' => 'required']);
if (!$this->cekAksesAnak($request->user(), $request->siswa_id)) {
return response()->json(['message' => 'Akses ditolak.'], 403);
}
$data = Penjemputan::where('siswa_id', $request->siswa_id)->latest()->take(10)->get();
$data->transform(function ($item) {
$item->foto_url = $item->foto_bukti ? asset('storage/' . $item->foto_bukti) : null;
return $item;
});
return response()->json(['success' => true, 'data' => $data]);
}
}

View File

@ -0,0 +1,20 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
class PengumumanController extends Controller
{
public function index()
{
// Sementara kita return array kosong dulu atau contoh data
return response()->json([
'success' => true,
'data' => [
['judul' => 'Libur Nasional', 'isi' => 'Besok sekolah libur ya bunda.'],
]
]);
}
}

View File

@ -0,0 +1,21 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Models\Siswa;
use Illuminate\Http\Request;
class SiswaController extends Controller
{
public function index()
{
// Mengambil semua data siswa beserta data walinya
$siswa = Siswa::with(['wali_murid', 'kelompok'])->get();
return response()->json([
'success' => true,
'data' => $siswa
]);
}
}

View File

@ -1,45 +1,52 @@
<?php
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Route;
use App\Http\Controllers\AuthController;
use App\Http\Controllers\Admin\KelasController;
use App\Http\Controllers\Admin\GuruController;
use App\Http\Controllers\Admin\WaliMuridController;
use App\Http\Controllers\Admin\SiswaController;
use App\Http\Controllers\Api\PerkembanganController as ApiPerkembangan;
Route::post('/login', [AuthController::class, 'login']);
// Panggil Controller Khusus API (Bukan Admin!)
use App\Http\Controllers\Api\AuthController;
use App\Http\Controllers\Api\SiswaController;
use App\Http\Controllers\Api\PengumumanController;
use App\Http\Controllers\Api\LaporanController;
use App\Http\Controllers\Api\GuruController;
/*
|--------------------------------------------------------------------------
| API Routes (Jembatan Android)
|--------------------------------------------------------------------------
*/
// ==========================================
// 1. PINTU MASUK (PUBLIC)
// ==========================================
Route::post('/login', [AuthController::class, 'login']); // Login Guru & Wali
Route::get('/pengumuman', [PengumumanController::class, 'index']); // Info Sekolah
// --- KHUSUS WALI MURID (Lihat Data) ---
// Wali melihat daftar anaknya
Route::get('/siswa-saya', [SiswaController::class, 'index']);
// ==========================================
// 2. AREA TERKUNCI (BUTUH TOKEN)
// ==========================================
Route::middleware('auth:sanctum')->group(function () {
// --- UMUM ---
Route::post('/logout', [AuthController::class, 'logout']);
Route::get('/test', function () {
return response()->json(['message' => 'API works!']);
Route::get('/user', function (Request $request) {
return $request->user(); // Cek siapa yang login
});
// pilih salah satu (saya sarankan pakai apiResource biar singkat)
Route::apiResource('kelas', KelasController::class);
Route::apiResource('guru', GuruController::class)->names([
'index' => 'api.guru.index',
'show' => 'api.guru.show',
'store' => 'api.guru.store',
'update' => 'api.guru.update',
'destroy' => 'api.guru.destroy',
]);
Route::apiResource('wali', WaliMuridController::class)->names([
'index' => 'api.wali-murid.index',
'show' => 'api.wali.show',
'store' => 'api.wali.store',
'update' => 'api.wali.update',
'destroy' => 'api.wali.destroy',
]);
Route::apiResource('siswa', SiswaController::class)->names([
'index' => 'api.siswa.index',
'show' => 'api.siswa.show',
'store' => 'api.siswa.store',
'update' => 'api.siswa.update',
'destroy' => 'api.siswa.destroy',
]);
// Wali melihat laporan (Wajib kirim ?siswa_id=1 di URL)
Route::get('/anekdot', [LaporanController::class, 'getAnekdot']);
Route::get('/karya', [LaporanController::class, 'getKarya']);
Route::get('/penjemputan', [LaporanController::class, 'getPenjemputan']);
// --- KHUSUS GURU (Input Data) ---
// Nanti kalau Guru login di HP untuk input data:
Route::post('/guru/anekdot', [GuruController::class, 'storeAnekdot']);
Route::post('/guru/karya', [GuruController::class, 'storeKarya']);
Route::post('/guru/penjemputan', [GuruController::class, 'storePenjemputan']);
});