Add email connections to ticketing settings
This commit is contained in:
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace Dashboard\Ticketing\Http\Controllers;
|
||||
|
||||
use Dashboard\Ticketing\Models\EmailConnection;
|
||||
use Dashboard\Ticketing\Models\PriorityLevel;
|
||||
use Dashboard\Ticketing\Models\TicketingAgentAccess;
|
||||
use Dashboard\Ticketing\Models\TicketingGroup;
|
||||
@@ -95,11 +96,16 @@ class TicketingSettingsController extends Controller
|
||||
->orderBy('name')
|
||||
->get();
|
||||
|
||||
$emailConnections = $isBootstrap
|
||||
? collect()
|
||||
: EmailConnection::whereIn('group_id', $myGroupIds)->get();
|
||||
|
||||
return Inertia::render('Ticketing/Settings', [
|
||||
'groups' => $groups,
|
||||
'agents' => $agents,
|
||||
'priorities' => $priorities,
|
||||
'projects' => $projects,
|
||||
'emailConnections' => $emailConnections,
|
||||
'myGroupIds' => $myGroupIds,
|
||||
'isBootstrap' => $isBootstrap,
|
||||
'isSiteAdmin' => $this->isSiteAdmin(),
|
||||
@@ -323,4 +329,65 @@ class TicketingSettingsController extends Controller
|
||||
|
||||
return back()->with('success', 'Project removed.');
|
||||
}
|
||||
|
||||
public function storeEmailConnection(Request $request)
|
||||
{
|
||||
$this->requireAgentAccess();
|
||||
|
||||
$validated = $request->validate([
|
||||
'group_id' => 'required|exists:ticketing_groups,id',
|
||||
'type' => 'required|in:gmail,imap',
|
||||
'active' => 'boolean',
|
||||
'config.host' => 'nullable|string|max:255',
|
||||
'config.port' => 'nullable|integer',
|
||||
'config.username' => 'nullable|string|max:255',
|
||||
'config.password' => 'nullable|string|max:500',
|
||||
'config.encryption' => 'nullable|in:ssl,tls,none',
|
||||
'config.mailbox' => 'nullable|string|max:255',
|
||||
]);
|
||||
|
||||
$this->requireManagerAccess($validated['group_id']);
|
||||
|
||||
EmailConnection::create([
|
||||
'group_id' => $validated['group_id'],
|
||||
'type' => $validated['type'],
|
||||
'active' => $request->boolean('active', true),
|
||||
'config' => $request->input('config', []),
|
||||
]);
|
||||
|
||||
return back()->with('success', 'Email connection saved.');
|
||||
}
|
||||
|
||||
public function updateEmailConnection(Request $request, EmailConnection $connection)
|
||||
{
|
||||
$this->requireAgentAccess();
|
||||
$this->requireManagerAccess($connection->group_id);
|
||||
|
||||
$request->validate([
|
||||
'type' => 'required|in:gmail,imap',
|
||||
'active' => 'boolean',
|
||||
'config.host' => 'nullable|string|max:255',
|
||||
'config.port' => 'nullable|integer',
|
||||
'config.username' => 'nullable|string|max:255',
|
||||
'config.password' => 'nullable|string|max:500',
|
||||
'config.encryption' => 'nullable|in:ssl,tls,none',
|
||||
'config.mailbox' => 'nullable|string|max:255',
|
||||
]);
|
||||
|
||||
$connection->update([
|
||||
'type' => $request->type,
|
||||
'active' => $request->boolean('active', true),
|
||||
'config' => $request->input('config', $connection->config),
|
||||
]);
|
||||
|
||||
return back()->with('success', 'Email connection updated.');
|
||||
}
|
||||
|
||||
public function destroyEmailConnection(EmailConnection $connection)
|
||||
{
|
||||
$this->requireAgentAccess();
|
||||
$this->requireManagerAccess($connection->group_id);
|
||||
$connection->delete();
|
||||
return back()->with('success', 'Email connection removed.');
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user