integrasi api
This commit is contained in:
parent
d8a8ce647a
commit
0252aa5300
|
|
@ -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']);
|
||||
}
|
||||
}
|
||||
|
|
@ -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']);
|
||||
}
|
||||
}
|
||||
|
|
@ -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]);
|
||||
}
|
||||
}
|
||||
|
|
@ -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.'],
|
||||
]
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
|
@ -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
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
|
@ -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']);
|
||||
});
|
||||
Loading…
Reference in New Issue