73 lines
2.0 KiB
PHP
73 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Settings;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\Webhook;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\JsonResponse;
|
|
|
|
class WebhookController extends Controller
|
|
{
|
|
public function index(): JsonResponse
|
|
{
|
|
$webhooks = Webhook::where('user_id', auth()->id())->get();
|
|
return response()->json($webhooks);
|
|
}
|
|
|
|
public function store(Request $request): JsonResponse
|
|
{
|
|
$request->validate([
|
|
'module' => 'required|in:New User,New Appointment',
|
|
'method' => 'required|in:GET,POST',
|
|
'url' => 'required|url',
|
|
]);
|
|
|
|
$webhook = Webhook::create([
|
|
'user_id' => auth()->id(),
|
|
'module' => $request->module,
|
|
'method' => $request->method,
|
|
'url' => $request->url,
|
|
]);
|
|
|
|
return response()->json([
|
|
'webhook' => $webhook,
|
|
'message' => __('Webhook created successfully')
|
|
]);
|
|
}
|
|
|
|
public function update(Request $request, Webhook $webhook): JsonResponse
|
|
{
|
|
if ($webhook->user_id !== auth()->id()) {
|
|
return response()->json(['message' => 'Unauthorized'], 403);
|
|
}
|
|
|
|
$request->validate([
|
|
'module' => 'required|in:New User,New Appointment',
|
|
'method' => 'required|in:GET,POST',
|
|
'url' => 'required|url',
|
|
]);
|
|
|
|
$webhook->update([
|
|
'module' => $request->module,
|
|
'method' => $request->method,
|
|
'url' => $request->url,
|
|
]);
|
|
|
|
return response()->json([
|
|
'webhook' => $webhook,
|
|
'message' => __('Webhook updated successfully')
|
|
]);
|
|
}
|
|
|
|
public function destroy(Webhook $webhook): JsonResponse
|
|
{
|
|
if ($webhook->user_id !== auth()->id()) {
|
|
return response()->json(['message' => 'Unauthorized'], 403);
|
|
}
|
|
|
|
$webhook->delete();
|
|
|
|
return response()->json(['message' => __('Webhook deleted successfully')]);
|
|
}
|
|
} |