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
|
<?php
|
||||||
|
|
||||||
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Support\Facades\Route;
|
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 () {
|
Route::middleware('auth:sanctum')->group(function () {
|
||||||
|
|
||||||
|
// --- UMUM ---
|
||||||
Route::post('/logout', [AuthController::class, 'logout']);
|
Route::post('/logout', [AuthController::class, 'logout']);
|
||||||
|
Route::get('/user', function (Request $request) {
|
||||||
Route::get('/test', function () {
|
return $request->user(); // Cek siapa yang login
|
||||||
return response()->json(['message' => 'API works!']);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// pilih salah satu (saya sarankan pakai apiResource biar singkat)
|
|
||||||
Route::apiResource('kelas', KelasController::class);
|
// Wali melihat laporan (Wajib kirim ?siswa_id=1 di URL)
|
||||||
Route::apiResource('guru', GuruController::class)->names([
|
Route::get('/anekdot', [LaporanController::class, 'getAnekdot']);
|
||||||
'index' => 'api.guru.index',
|
Route::get('/karya', [LaporanController::class, 'getKarya']);
|
||||||
'show' => 'api.guru.show',
|
Route::get('/penjemputan', [LaporanController::class, 'getPenjemputan']);
|
||||||
'store' => 'api.guru.store',
|
|
||||||
'update' => 'api.guru.update',
|
|
||||||
'destroy' => 'api.guru.destroy',
|
// --- KHUSUS GURU (Input Data) ---
|
||||||
]);
|
// Nanti kalau Guru login di HP untuk input data:
|
||||||
Route::apiResource('wali', WaliMuridController::class)->names([
|
Route::post('/guru/anekdot', [GuruController::class, 'storeAnekdot']);
|
||||||
'index' => 'api.wali-murid.index',
|
Route::post('/guru/karya', [GuruController::class, 'storeKarya']);
|
||||||
'show' => 'api.wali.show',
|
Route::post('/guru/penjemputan', [GuruController::class, 'storePenjemputan']);
|
||||||
'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',
|
|
||||||
]);
|
|
||||||
});
|
});
|
||||||
Loading…
Reference in New Issue