refactor controllers to use form requests for validation
This commit is contained in:
@@ -14,7 +14,7 @@ zien — inclusief slimme automatisering, logging en Telegram-notificaties voor
|
|||||||
|
|
||||||
## 🧰 Techniek & Stack
|
## 🧰 Techniek & Stack
|
||||||
|
|
||||||
- **Framework:** Laravel 11
|
- **Framework:** Laravel 12
|
||||||
- **Frontend:** Tailwind CSS, Blade
|
- **Frontend:** Tailwind CSS, Blade
|
||||||
- **DevOps-integraties:** Telegram alerts, Healthchecks, custom logging
|
- **DevOps-integraties:** Telegram alerts, Healthchecks, custom logging
|
||||||
- **CI/CD-ready:** Ondersteuning voor deploy hooks en jobs
|
- **CI/CD-ready:** Ondersteuning voor deploy hooks en jobs
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
namespace App\Http\Controllers;
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Requests\EducationRequest;
|
||||||
use App\Models\Education;
|
use App\Models\Education;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
@@ -19,22 +20,11 @@ class EducationController extends Controller
|
|||||||
return view('educations.create');
|
return view('educations.create');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function store(Request $request)
|
public function store(EducationRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->validate([
|
$education = Education::create($request->validated());
|
||||||
'opleiding' => 'required|string|max:255',
|
|
||||||
'instituut' => 'required|string|max:255',
|
|
||||||
'startdatum' => 'required|date',
|
|
||||||
'einddatum' => 'nullable|date|after_or_equal:startdatum',
|
|
||||||
'beschrijving' => 'nullable|string',
|
|
||||||
'afbeelding' => 'nullable|image|max:2048',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$education = Education::create($data);
|
$this->handleImageUpload($request, $education);
|
||||||
|
|
||||||
if ($request->hasFile('afbeelding')) {
|
|
||||||
$education->addMediaFromRequest('afbeelding')->toMediaCollection('image');
|
|
||||||
}
|
|
||||||
|
|
||||||
return redirect()->route('educations.index')->with('success', 'Opleiding toegevoegd.');
|
return redirect()->route('educations.index')->with('success', 'Opleiding toegevoegd.');
|
||||||
}
|
}
|
||||||
@@ -49,32 +39,31 @@ class EducationController extends Controller
|
|||||||
return view('educations.edit', compact('education'));
|
return view('educations.edit', compact('education'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update(Request $request, Education $education)
|
public function update(EducationRequest $request, Education $education)
|
||||||
{
|
{
|
||||||
$data = $request->validate([
|
$education->update($request->validated());
|
||||||
'opleiding' => 'required|string|max:255',
|
|
||||||
'instituut' => 'required|string|max:255',
|
|
||||||
'startdatum' => 'required|date',
|
|
||||||
'einddatum' => 'nullable|date|after_or_equal:startdatum',
|
|
||||||
'beschrijving' => 'nullable|string',
|
|
||||||
'afbeelding' => 'nullable|image|max:2048',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$education->update($data);
|
$this->handleImageUpload($request, $education, true);
|
||||||
|
|
||||||
if ($request->hasFile('afbeelding')) {
|
|
||||||
$education->clearMediaCollection('image');
|
|
||||||
|
|
||||||
$education->addMediaFromRequest('afbeelding')->toMediaCollection('image');
|
|
||||||
}
|
|
||||||
|
|
||||||
return redirect()->route('educations.index')->with('success', 'Opleiding bijgewerkt.');
|
return redirect()->route('educations.index')->with('success', 'Opleiding bijgewerkt.');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function destroy(Education $education)
|
public function destroy(Education $education)
|
||||||
{
|
{
|
||||||
|
$education->clearMediaCollection('image');
|
||||||
$education->delete();
|
$education->delete();
|
||||||
|
|
||||||
return redirect()->route('educations.index')->with('success', 'Opleiding verwijderd.');
|
return redirect()->route('educations.index')->with('success', 'Opleiding verwijderd.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function handleImageUpload(Request $request, Education $education, bool $replace = false): void
|
||||||
|
{
|
||||||
|
if ($request->hasFile('afbeelding')) {
|
||||||
|
if ($replace) {
|
||||||
|
$education->clearMediaCollection('image');
|
||||||
|
}
|
||||||
|
|
||||||
|
$education->addMediaFromRequest('afbeelding')->toMediaCollection('image');
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ namespace App\Http\Controllers;
|
|||||||
|
|
||||||
use App\Models\Personalia;
|
use App\Models\Personalia;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use App\Http\Requests\PersonaliaRequest;
|
||||||
|
|
||||||
class PersonaliaController extends Controller
|
class PersonaliaController extends Controller
|
||||||
{
|
{
|
||||||
@@ -19,14 +20,9 @@ class PersonaliaController extends Controller
|
|||||||
return view('personalia.create');
|
return view('personalia.create');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function store(Request $request)
|
public function store(PersonaliaRequest $request)
|
||||||
{
|
{
|
||||||
$validated = $request->validate([
|
$validated = $request->validated();
|
||||||
'key' => 'required|string|max:255',
|
|
||||||
'value' => 'required|string|max:255',
|
|
||||||
'hidden' => 'nullable|boolean',
|
|
||||||
'icon' => 'nullable|string|max:255',
|
|
||||||
]);
|
|
||||||
|
|
||||||
Personalia::create([
|
Personalia::create([
|
||||||
...$validated,
|
...$validated,
|
||||||
@@ -44,18 +40,12 @@ class PersonaliaController extends Controller
|
|||||||
|
|
||||||
public function update(Request $request, Personalia $personalium)
|
public function update(Request $request, Personalia $personalium)
|
||||||
{
|
{
|
||||||
$validated = $request->validate([
|
$validated = $request->validated();
|
||||||
'key' => 'required|string|max:255',
|
|
||||||
'value' => 'required|string|max:255',
|
|
||||||
'hidden' => 'nullable|boolean',
|
|
||||||
'icon' => 'nullable|string|max:255',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$personalium->update([
|
$personalium->update([
|
||||||
...$validated,
|
...$validated,
|
||||||
'hidden' => $request->boolean('hidden'),
|
'hidden' => $request->boolean('hidden'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
return redirect()->route('personalia.index')->with('success', 'Persoonlijk item bijgewerkt.');
|
return redirect()->route('personalia.index')->with('success', 'Persoonlijk item bijgewerkt.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4,43 +4,25 @@ namespace App\Http\Controllers;
|
|||||||
|
|
||||||
use App\Models\Skill;
|
use App\Models\Skill;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use App\Http\Requests\SkillRequest;
|
||||||
|
|
||||||
|
|
||||||
class SkillController extends Controller
|
class SkillController extends Controller
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Display a listing of the resource.
|
|
||||||
*/
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$skills = Skill::latest()->get();
|
$skills = Skill::latest()->get();
|
||||||
|
|
||||||
return view('skills.index', compact('skills'));
|
return view('skills.index', compact('skills'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Show the form for creating a new resource.
|
|
||||||
*/
|
|
||||||
public function create()
|
public function create()
|
||||||
{
|
{
|
||||||
return view('skills.create');
|
return view('skills.create');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public function store(SkillRequest $request)
|
||||||
* Store a newly created resource in storage.
|
|
||||||
*/
|
|
||||||
public function store(Request $request)
|
|
||||||
{
|
{
|
||||||
|
$skill = Skill::create($request->validated());
|
||||||
$validated = $request->validate([
|
|
||||||
'title' => 'required|string|max:255',
|
|
||||||
'description' => 'nullable|string',
|
|
||||||
'rating' => 'required|numeric|min:1|max:10',
|
|
||||||
'image' => 'nullable|image|max:2048',
|
|
||||||
'type' => 'required|in:rating,tag,other',
|
|
||||||
|
|
||||||
]);
|
|
||||||
|
|
||||||
$skill = Skill::create($validated);
|
|
||||||
|
|
||||||
if ($request->hasFile('image')) {
|
if ($request->hasFile('image')) {
|
||||||
$skill->addMediaFromRequest('image')->toMediaCollection('image', 'public');
|
$skill->addMediaFromRequest('image')->toMediaCollection('image', 'public');
|
||||||
@@ -49,37 +31,19 @@ class SkillController extends Controller
|
|||||||
return redirect()->route('skills.index')->with('success', 'Vaardigheid toegevoegd.');
|
return redirect()->route('skills.index')->with('success', 'Vaardigheid toegevoegd.');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Display the specified resource.
|
|
||||||
*/
|
|
||||||
public function show(Skill $skill)
|
public function show(Skill $skill)
|
||||||
{
|
{
|
||||||
return view('skills.show', compact('skill'));
|
return view('skills.show', compact('skill'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Show the form for editing the specified resource.
|
|
||||||
*/
|
|
||||||
public function edit(Skill $skill)
|
public function edit(Skill $skill)
|
||||||
{
|
{
|
||||||
return view('skills.edit', compact('skill'));
|
return view('skills.edit', compact('skill'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public function update(SkillRequest $request, Skill $skill)
|
||||||
* Update the specified resource in storage.
|
|
||||||
*/
|
|
||||||
public function update(Request $request, Skill $skill)
|
|
||||||
{
|
{
|
||||||
$validated = $request->validate([
|
$skill->update($request->validated());
|
||||||
'title' => 'required|string|max:255',
|
|
||||||
'description' => 'nullable|string',
|
|
||||||
'rating' => 'required|numeric|min:1|max:10',
|
|
||||||
'image' => 'nullable|image|max:2048',
|
|
||||||
'type' => 'required|in:rating,tag,other',
|
|
||||||
|
|
||||||
]);
|
|
||||||
|
|
||||||
$skill->update($validated);
|
|
||||||
|
|
||||||
if ($request->hasFile('image')) {
|
if ($request->hasFile('image')) {
|
||||||
$skill->clearMediaCollection('image');
|
$skill->clearMediaCollection('image');
|
||||||
@@ -89,9 +53,6 @@ class SkillController extends Controller
|
|||||||
return redirect()->route('skills.index')->with('success', 'Vaardigheid bijgewerkt.');
|
return redirect()->route('skills.index')->with('success', 'Vaardigheid bijgewerkt.');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove the specified resource from storage.
|
|
||||||
*/
|
|
||||||
public function destroy(Skill $skill)
|
public function destroy(Skill $skill)
|
||||||
{
|
{
|
||||||
$skill->clearMediaCollection('image');
|
$skill->clearMediaCollection('image');
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ namespace App\Http\Controllers;
|
|||||||
|
|
||||||
use App\Models\WorkExperience;
|
use App\Models\WorkExperience;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use App\Http\Requests\WorkExperienceRequest;
|
||||||
|
|
||||||
|
|
||||||
class WorkExperienceController extends Controller
|
class WorkExperienceController extends Controller
|
||||||
{
|
{
|
||||||
@@ -19,18 +21,9 @@ class WorkExperienceController extends Controller
|
|||||||
return view('work_experiences.create');
|
return view('work_experiences.create');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function store(Request $request)
|
public function store(WorkExperienceRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->validate([
|
$experience = WorkExperience::create($request->validated());
|
||||||
'werkgever' => 'required|string|max:255',
|
|
||||||
'functie' => 'required|string|max:255',
|
|
||||||
'startdatum' => 'required|date',
|
|
||||||
'einddatum' => 'nullable|date|after_or_equal:startdatum',
|
|
||||||
'beschrijving' => 'nullable|string',
|
|
||||||
'afbeelding' => 'nullable|image|max:2048',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$experience = WorkExperience::create($data);
|
|
||||||
|
|
||||||
if ($request->hasFile('afbeelding')) {
|
if ($request->hasFile('afbeelding')) {
|
||||||
$experience->addMediaFromRequest('afbeelding')->toMediaCollection('image');
|
$experience->addMediaFromRequest('afbeelding')->toMediaCollection('image');
|
||||||
@@ -49,18 +42,9 @@ class WorkExperienceController extends Controller
|
|||||||
return view('work_experiences.edit', compact('workExperience'));
|
return view('work_experiences.edit', compact('workExperience'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update(Request $request, WorkExperience $workExperience)
|
public function update(WorkExperienceRequest $request, WorkExperience $workExperience)
|
||||||
{
|
{
|
||||||
$data = $request->validate([
|
$workExperience->update($request->validated());
|
||||||
'werkgever' => 'required|string|max:255',
|
|
||||||
'functie' => 'required|string|max:255',
|
|
||||||
'startdatum' => 'required|date',
|
|
||||||
'einddatum' => 'nullable|date|after_or_equal:startdatum',
|
|
||||||
'beschrijving' => 'nullable|string',
|
|
||||||
'afbeelding' => 'nullable|image|max:2048',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$workExperience->update($data);
|
|
||||||
|
|
||||||
if ($request->hasFile('afbeelding')) {
|
if ($request->hasFile('afbeelding')) {
|
||||||
$workExperience->clearMediaCollection('image');
|
$workExperience->clearMediaCollection('image');
|
||||||
@@ -72,6 +56,7 @@ class WorkExperienceController extends Controller
|
|||||||
|
|
||||||
public function destroy(WorkExperience $workExperience)
|
public function destroy(WorkExperience $workExperience)
|
||||||
{
|
{
|
||||||
|
$workExperience->clearMediaCollection('image');
|
||||||
$workExperience->delete();
|
$workExperience->delete();
|
||||||
|
|
||||||
return redirect()->route('work-experiences.index')->with('success', 'Ervaring verwijderd.');
|
return redirect()->route('work-experiences.index')->with('success', 'Ervaring verwijderd.');
|
||||||
|
|||||||
49
app/Http/Requests/EducationRequest.php
Normal file
49
app/Http/Requests/EducationRequest.php
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Requests;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class EducationRequest extends FormRequest
|
||||||
|
{
|
||||||
|
public function authorize(): bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'opleiding' => ['required', 'string', 'max:255'],
|
||||||
|
'instituut' => ['required', 'string', 'max:255'],
|
||||||
|
'startdatum' => ['required', 'date'],
|
||||||
|
'einddatum' => ['nullable', 'date', 'after_or_equal:startdatum'],
|
||||||
|
'beschrijving' => ['nullable', 'string'],
|
||||||
|
'afbeelding' => ['nullable', 'image', 'max:2048'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function messages(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'opleiding.required' => 'De naam van de opleiding is verplicht.',
|
||||||
|
'opleiding.string' => 'De opleiding moet een geldige tekst zijn.',
|
||||||
|
'opleiding.max' => 'De opleiding mag maximaal 255 tekens bevatten.',
|
||||||
|
|
||||||
|
'instituut.required' => 'Het instituut is verplicht.',
|
||||||
|
'instituut.string' => 'Het instituut moet een geldige tekst zijn.',
|
||||||
|
'instituut.max' => 'Het instituut mag maximaal 255 tekens bevatten.',
|
||||||
|
|
||||||
|
'startdatum.required' => 'De startdatum is verplicht.',
|
||||||
|
'startdatum.date' => 'De startdatum moet een geldige datum zijn.',
|
||||||
|
|
||||||
|
'einddatum.date' => 'De einddatum moet een geldige datum zijn.',
|
||||||
|
'einddatum.after_or_equal' => 'De einddatum mag niet vóór de startdatum liggen.',
|
||||||
|
|
||||||
|
'beschrijving.string' => 'De beschrijving moet een geldige tekst zijn.',
|
||||||
|
|
||||||
|
'afbeelding.image' => 'De geüploade afbeelding moet een geldig afbeeldingsbestand zijn.',
|
||||||
|
'afbeelding.max' => 'De afbeelding mag niet groter zijn dan 2MB.',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
32
app/Http/Requests/PersonaliaRequest.php
Normal file
32
app/Http/Requests/PersonaliaRequest.php
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Requests;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class PersonaliaRequest extends FormRequest
|
||||||
|
{
|
||||||
|
public function authorize(): bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'key' => ['required', 'string', 'max:255'],
|
||||||
|
'value' => ['required', 'string', 'max:255'],
|
||||||
|
'hidden' => ['nullable', 'boolean'],
|
||||||
|
'icon' => ['nullable', 'string', 'max:255'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function messages(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'key.required' => 'Een sleutel is verplicht.',
|
||||||
|
'value.required' => 'Een waarde is verplicht.',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
33
app/Http/Requests/SkillRequest.php
Normal file
33
app/Http/Requests/SkillRequest.php
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Requests;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class SkillRequest extends FormRequest
|
||||||
|
{
|
||||||
|
public function authorize(): bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'title' => ['required', 'string', 'max:255'],
|
||||||
|
'description' => ['nullable', 'string'],
|
||||||
|
'rating' => ['required', 'numeric', 'min:1', 'max:10'],
|
||||||
|
'image' => ['nullable', 'image', 'max:2048'],
|
||||||
|
'type' => ['required', 'in:rating,tag,other'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
public function messages(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'title.required' => 'Een titel is verplicht.',
|
||||||
|
'rating.required' => 'Geef een beoordeling tussen 1 en 10.',
|
||||||
|
'type.in' => 'Het type moet rating, tag of other zijn.',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
49
app/Http/Requests/WorkExperienceRequest.php
Normal file
49
app/Http/Requests/WorkExperienceRequest.php
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Requests;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class WorkExperienceRequest extends FormRequest
|
||||||
|
{
|
||||||
|
public function authorize(): bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'werkgever' => ['required', 'string', 'max:255'],
|
||||||
|
'functie' => ['required', 'string', 'max:255'],
|
||||||
|
'startdatum' => ['required', 'date'],
|
||||||
|
'einddatum' => ['nullable', 'date', 'after_or_equal:startdatum'],
|
||||||
|
'beschrijving' => ['nullable', 'string'],
|
||||||
|
'afbeelding' => ['nullable', 'image', 'max:2048'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function messages(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'werkgever.required' => 'De naam van de werkgever is verplicht.',
|
||||||
|
'werkgever.string' => 'De werkgever moet een geldige tekst zijn.',
|
||||||
|
'werkgever.max' => 'De werkgever mag maximaal 255 tekens bevatten.',
|
||||||
|
|
||||||
|
'functie.required' => 'De functietitel is verplicht.',
|
||||||
|
'functie.string' => 'De functie moet een geldige tekst zijn.',
|
||||||
|
'functie.max' => 'De functie mag maximaal 255 tekens bevatten.',
|
||||||
|
|
||||||
|
'startdatum.required' => 'De startdatum is verplicht.',
|
||||||
|
'startdatum.date' => 'De startdatum moet een geldige datum zijn.',
|
||||||
|
|
||||||
|
'einddatum.date' => 'De einddatum moet een geldige datum zijn.',
|
||||||
|
'einddatum.after_or_equal' => 'De einddatum mag niet vóór de startdatum liggen.',
|
||||||
|
|
||||||
|
'beschrijving.string' => 'De beschrijving moet een geldige tekst zijn.',
|
||||||
|
|
||||||
|
'afbeelding.image' => 'De afbeelding moet een geldig afbeeldingsbestand zijn.',
|
||||||
|
'afbeelding.max' => 'De afbeelding mag niet groter zijn dan 2MB.',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -36,7 +36,7 @@ Naam: {$this->personalia->value}
|
|||||||
IP: {$this->ip}
|
IP: {$this->ip}
|
||||||
User Agent: `{$this->userAgent}`
|
User Agent: `{$this->userAgent}`
|
||||||
|
|
||||||
📅 Tijdstip: *{$this->personalia->updated_at->format('d-m-Y H:i')}*
|
📅 Tijdstip: *{now()->format('d-m-Y H:i')}*
|
||||||
TEXT;
|
TEXT;
|
||||||
|
|
||||||
Http::post('https://api.telegram.org/bot'.config('services.telegram.bot_token').'/sendMessage', [
|
Http::post('https://api.telegram.org/bot'.config('services.telegram.bot_token').'/sendMessage', [
|
||||||
|
|||||||
@@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
namespace App\Models;
|
namespace App\Models;
|
||||||
|
|
||||||
// use Illuminate\Contracts\Auth\MustVerifyEmail;
|
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
use Illuminate\Foundation\Auth\User as Authenticatable;
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
||||||
use Illuminate\Notifications\Notifiable;
|
use Illuminate\Notifications\Notifiable;
|
||||||
@@ -12,32 +11,17 @@ class User extends Authenticatable
|
|||||||
/** @use HasFactory<\Database\Factories\UserFactory> */
|
/** @use HasFactory<\Database\Factories\UserFactory> */
|
||||||
use HasFactory, Notifiable;
|
use HasFactory, Notifiable;
|
||||||
|
|
||||||
/**
|
|
||||||
* The attributes that are mass assignable.
|
|
||||||
*
|
|
||||||
* @var list<string>
|
|
||||||
*/
|
|
||||||
protected $fillable = [
|
protected $fillable = [
|
||||||
'name',
|
'name',
|
||||||
'email',
|
'email',
|
||||||
'password',
|
'password',
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
|
||||||
* The attributes that should be hidden for serialization.
|
|
||||||
*
|
|
||||||
* @var list<string>
|
|
||||||
*/
|
|
||||||
protected $hidden = [
|
protected $hidden = [
|
||||||
'password',
|
'password',
|
||||||
'remember_token',
|
'remember_token',
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the attributes that should be cast.
|
|
||||||
*
|
|
||||||
* @return array<string, string>
|
|
||||||
*/
|
|
||||||
protected function casts(): array
|
protected function casts(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
|||||||
@@ -27,6 +27,4 @@ class WorkExperience extends Model implements HasMedia
|
|||||||
{
|
{
|
||||||
return $this->image() ? $this->image()->getUrl() : null;
|
return $this->image() ? $this->image()->getUrl() : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Als je mediaconversies of image handling wil: hier kun je die later toevoegen
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user