refactor: add regex validation for 'nama', 'alamat', and 'deskripsi' fields in AdminRequest, FotoRequest, and ProfilRequest

This commit is contained in:
LailaWulandarii 2026-02-07 15:41:29 +07:00
parent f5be1cf1db
commit a7f433961d
3 changed files with 17 additions and 9 deletions

View File

@ -20,12 +20,12 @@ public function rules(): array
$adminId = $this->route('id'); $adminId = $this->route('id');
return [ return [
'nama' => 'required|string|min:5|max:100', 'nama' => 'required|string|min:3|max:100|regex:/^[a-zA-Z\s]+$/',
'username' => 'required|string|alpha_num|max:10|unique:users,username,' . $adminId . ',id_user', 'username' => 'required|string|alpha_num|max:10|unique:users,username,' . $adminId . ',id_user',
'email' => 'required|email:dns|unique:users,email,' . $adminId . ',id_user', 'email' => 'required|email:dns|unique:users,email,' . $adminId . ',id_user',
'no_wa' => 'required|numeric|digits_between:10,15', 'no_wa' => 'required|numeric|digits_between:10,15',
'role' => 'required|in:admin_foto,admin_buket', 'role' => 'required|in:admin_foto,admin_buket',
'alamat' => 'required|string|max:200', 'alamat' => 'required|string|max:200|regex:/^[a-zA-Z0-9\s\.,:"-]+$/',
]; ];
} }
@ -39,8 +39,11 @@ public function messages(): array
'numeric' => ':attribute harus berupa angka.', 'numeric' => ':attribute harus berupa angka.',
'digits_between' => ':attribute harus berjumlah antara :min sampai :max digit.', 'digits_between' => ':attribute harus berjumlah antara :min sampai :max digit.',
'email' => 'Format :attribute tidak valid.', 'email' => 'Format :attribute tidak valid.',
'alpha_dash' => ':attribute hanya boleh berisi huruf, angka, serta simbol - dan _', 'regex' => ':attribute hanya boleh berisi huruf, angka, spasi, titik, koma, tanda hubung dan tanda petik dua.',
'in' => ':attribute yang dipilih tidak sesuai pilihan yang tersedia.', 'in' => ':attribute yang dipilih tidak sesuai pilihan yang tersedia.',
'nama.regex' => 'Nama hanya boleh berisi huruf dan spasi.',
'username.alpha_num' => 'Username hanya boleh berisi huruf dan angka.',
'alamat.regex' => 'Alamat hanya boleh berisi huruf, angka, spasi, titik, koma, tanda hubung, dan tanda petik dua.',
]; ];
} }

View File

@ -16,11 +16,10 @@ public function authorize(): bool
public function rules(): array public function rules(): array
{ {
return [ return [
'nama' => 'required|string|min:3|max:100', 'nama' => 'required|string|min:3|max:100|regex:/^[a-zA-Z0-9\s\.,:"-]+$/',
'harga' => 'required|numeric|min:0', 'harga' => 'required|numeric|min:0',
'durasi' => 'required|integer|min:0', 'durasi' => 'required|integer|min:0',
'deskripsi' => 'required|string|min:10', 'deskripsi' => 'required|string|min:10|regex:/^[a-zA-Z0-9\s\.,:"-]+$/',
// Foto wajib saat Tambah (POST), opsional saat Edit (PUT)
'foto' => $this->isMethod('post') 'foto' => $this->isMethod('post')
? 'required|image|mimes:jpeg,png,jpg|max:2048' ? 'required|image|mimes:jpeg,png,jpg|max:2048'
: 'nullable|image|mimes:jpeg,png,jpg|max:2048', : 'nullable|image|mimes:jpeg,png,jpg|max:2048',

View File

@ -20,11 +20,11 @@ public function rules(): array
$userId = Auth::id(); $userId = Auth::id();
//tambah validasi //tambah validasi
return [ return [
'nama' => 'required|string|max:100', 'nama' => 'required|string|min:3|max:100|regex:/^[a-zA-Z\s]+$/',
'username' => 'required|string|alpha_num|max:10|unique:users,username,' . $userId . ',id_user', 'username' => 'required|string|alpha_num|max:10|unique:users,username,' . $userId . ',id_user',
'email' => 'required|email|unique:users,email,' . $userId . ',id_user', 'email' => 'required|email|unique:users,email,' . $userId . ',id_user',
'no_wa' => 'nullable|numeric', 'no_wa' => 'nullable|numeric|digits_between:10,15',
'alamat' => 'nullable|string|max:200', 'alamat' => 'nullable|string|max:200|regex:/^[a-zA-Z0-9\s\.,:"-]+$/',
]; ];
} }
@ -35,6 +35,12 @@ public function messages(): array
'unique' => ':attribute sudah digunakan.', 'unique' => ':attribute sudah digunakan.',
'numeric' => ':attribute harus berupa angka.', 'numeric' => ':attribute harus berupa angka.',
'email' => 'Format :attribute tidak valid.', 'email' => 'Format :attribute tidak valid.',
'digits_between' => ':attribute harus berjumlah antara 10 sampai 15 digit.',
'min' => ':attribute minimal harus berisi :min karakter.',
'max' => ':attribute maksimal hanya boleh :max karakter.',
'nama.regex' => 'Nama hanya boleh berisi huruf dan spasi.',
'username.alpha_num' => 'Username hanya boleh berisi huruf dan angka.',
'alamat.regex' => 'Alamat hanya boleh berisi huruf, angka, spasi, titik, koma, tanda hubung, dan tanda petik dua.',
]; ];
} }