feat: register dynamic mailers in AppServiceProvider, remove single-azure methods from SettingsController

This commit is contained in:
Ghassan Yusuf 2026-05-26 12:26:02 +03:00
parent 8d336466f4
commit db5272dd1d
2 changed files with 14 additions and 77 deletions

View File

@ -5,9 +5,7 @@ namespace App\Http\Controllers;
use App\Models\Setting; use App\Models\Setting;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Mail;
use Illuminate\View\View; use Illuminate\View\View;
use PromoSeven\AzureMailer\Graph\TokenManager;
use PromoSeven\UltraMessage\Facades\UltraMessage; use PromoSeven\UltraMessage\Facades\UltraMessage;
use PromoSeven\UltraMessage\UltraMessageException; use PromoSeven\UltraMessage\UltraMessageException;
@ -23,15 +21,7 @@ class SettingsController extends Controller
'webhook_path' => Setting::get('ultramsg_webhook_path', 'ultra-message/webhook'), 'webhook_path' => Setting::get('ultramsg_webhook_path', 'ultra-message/webhook'),
]; ];
$azureSettings = [ return view('settings.integrations', compact('whatsappSettings'));
'enabled' => Setting::get('azure_mail_enabled', false),
'tenant_id' => Setting::get('azure_mail_tenant_id', ''),
'client_id' => Setting::get('azure_mail_client_id', ''),
'client_secret' => Setting::get('azure_mail_client_secret', ''),
'from_address' => Setting::get('azure_mail_from_address', ''),
];
return view('settings.integrations', compact('whatsappSettings', 'azureSettings'));
} }
public function updateWhatsapp(Request $request): JsonResponse public function updateWhatsapp(Request $request): JsonResponse
@ -52,62 +42,6 @@ class SettingsController extends Controller
return response()->json(['success' => true]); return response()->json(['success' => true]);
} }
public function updateAzureMail(Request $request): JsonResponse
{
$request->validate([
'tenant_id' => ['required', 'string', 'max:100'],
'client_id' => ['required', 'string', 'max:100'],
'client_secret' => ['required', 'string', 'max:500'],
'from_address' => ['required', 'email', 'max:255'],
]);
Setting::set('azure_mail_enabled', $request->input('enabled') === '1' ? '1' : '0');
Setting::set('azure_mail_tenant_id', $request->tenant_id);
Setting::set('azure_mail_client_id', $request->client_id);
Setting::set('azure_mail_client_secret', $request->client_secret);
Setting::set('azure_mail_from_address', $request->from_address);
return response()->json(['success' => true]);
}
public function testAzureMailConnection(): JsonResponse
{
try {
$config = [
'tenant_id' => Setting::get('azure_mail_tenant_id', ''),
'client_id' => Setting::get('azure_mail_client_id', ''),
'client_secret' => Setting::get('azure_mail_client_secret', ''),
];
$tokenManager = new TokenManager($config);
$tokenManager->getToken();
return response()->json(['success' => true]);
} catch (\Exception $e) {
return response()->json(['success' => false, 'message' => $e->getMessage()]);
}
}
public function sendTestEmail(Request $request): JsonResponse
{
$request->validate([
'to' => ['required', 'email', 'max:255'],
'subject' => ['required', 'string', 'max:255'],
]);
try {
$to = $request->to;
$subject = $request->subject;
Mail::mailer('azure')->raw(
'This is a test email from SteelERP.',
function ($message) use ($to, $subject) {
$message->to($to)->subject($subject);
}
);
return response()->json(['success' => true]);
} catch (\Exception $e) {
return response()->json(['success' => false, 'message' => $e->getMessage()]);
}
}
public function testWhatsappConnection(): JsonResponse public function testWhatsappConnection(): JsonResponse
{ {
try { try {

View File

@ -2,23 +2,16 @@
namespace App\Providers; namespace App\Providers;
use App\Models\MailAccount;
use App\Models\Setting; use App\Models\Setting;
use Illuminate\Mail\MailManager;
use Illuminate\Support\ServiceProvider; use Illuminate\Support\ServiceProvider;
use PromoSeven\UltraMessage\Facades\UltraMessage; use PromoSeven\UltraMessage\Facades\UltraMessage;
class AppServiceProvider extends ServiceProvider class AppServiceProvider extends ServiceProvider
{ {
/** public function register(): void {}
* Register any application services.
*/
public function register(): void
{
//
}
/**
* Bootstrap any application services.
*/
public function boot(): void public function boot(): void
{ {
UltraMessage::configUsing(function () { UltraMessage::configUsing(function () {
@ -31,5 +24,15 @@ class AppServiceProvider extends ServiceProvider
'enabled' => (bool) Setting::get('ultramsg_enabled', config('ultra-message.enabled', true)), 'enabled' => (bool) Setting::get('ultramsg_enabled', config('ultra-message.enabled', true)),
]; ];
}); });
$this->callAfterResolving(MailManager::class, function (MailManager $manager) {
try {
foreach (MailAccount::all() as $account) {
$manager->extend($account->name, fn () => $account->buildTransport());
}
} catch (\Exception) {
// DB not ready on fresh install — skip silently
}
});
} }
} }