feat(Nextcloud sync & optimize)
All checks were successful
Deploy Roxane to Preprod / deploy (push) Successful in 1m18s

This commit is contained in:
2026-01-30 15:27:23 +01:00
parent b8de637b23
commit 9649d99e15
11 changed files with 307 additions and 245 deletions

View File

@@ -2,8 +2,10 @@
namespace App\Console\Commands;
use App\Models\Member;
use App\Services\Dolibarr\DolibarrService;
use App\Services\ISPConfig\ISPConfigMailService;
use App\Services\MemberService;
use App\Services\Nextcloud\NextcloudService;
use Illuminate\Console\Command;
use Illuminate\Http\Client\ConnectionException;
@@ -19,7 +21,8 @@ class HandleExpiredMembersDolibarr extends Command
public function __construct(
protected DolibarrService $dolibarr,
protected ISPConfigMailService $mailService,
protected NextcloudService $nextcloud
protected NextcloudService $nextcloud,
protected MemberService $memberService
)
{
parent::__construct();
@@ -112,6 +115,12 @@ class HandleExpiredMembersDolibarr extends Command
]);
}
// Résilitation Roxane
$roxaneMember = Member::query()->findOrFail($member['id']);
if ($roxaneMember) {
$this->memberService->deactivateMember($roxaneMember);
}
// Désactivation mail
if ($email) {
$this->disableMailAccount($email, $dryRun);

View File

@@ -9,6 +9,7 @@ use Illuminate\Console\Command;
use Illuminate\Http\Client\ConnectionException;
use Illuminate\Support\Facades\Log;
use Symfony\Component\Console\Command\Command as CommandAlias;
use function Laravel\Prompts\progress;
class SyncNextcloudMembers extends Command
{
@@ -38,7 +39,6 @@ class SyncNextcloudMembers extends Command
: 'Synchronisation Nextcloud → Members'
);
/** index des membres par email */
$members = Member::query()
->where('email', 'like', '%@retzien.fr%')
->when($memberFilter, fn ($q) => $q->where('id', $memberFilter))
@@ -46,19 +46,27 @@ class SyncNextcloudMembers extends Command
->filter(fn (Member $m) => !empty($m->retzien_email))
->keyBy(fn (Member $m) => strtolower($m->retzien_email));
if ($members->isEmpty()) {
$this->warn('Aucun membre à synchroniser');
return CommandAlias::SUCCESS;
}
$this->info("{$members->count()} membres candidats");
$this->info("{$members->count()} membres à synchroniser");
/**Récupération des users Nextcloud */
$userIds = $this->nextcloud->listUsers();
$this->info(count($userIds) . ' comptes Nextcloud trouvés');
$progress = null;
if (!$dryRun) {
$progress = progress(
label: 'Synchronisation des membres',
steps: $members->count()
);
$progress->start();
}
$synced = 0;
foreach ($userIds as $userId) {
@@ -73,19 +81,6 @@ class SyncNextcloudMembers extends Command
$member = $members[$email];
$payload = [
'member_id' => $member->id,
'nextcloud_user_id' => $userId,
'data' => [
'email' => $email,
'quota' => $details['quota'] ?? null,
'groups' => $details['groups'] ?? [],
'enabled' => !($details['enabled'] === false),
'last_login' => $details['lastLogin'] ?? null,
'raw' => $details, // utile pour debug
],
];
if ($dryRun) {
$this->line("[DRY-RUN] {$member->id}{$userId}");
} else {
@@ -94,12 +89,15 @@ class SyncNextcloudMembers extends Command
'member_id' => $member->id,
'nextcloud_user_id' => $userId,
],
$payload
[
'data' => json_encode($details, JSON_THROW_ON_ERROR),
]
);
$progress->advance();
}
$synced++;
} catch (\Throwable $e) {
Log::error('Erreur sync Nextcloud', [
'user_id' => $userId,
@@ -108,6 +106,11 @@ class SyncNextcloudMembers extends Command
}
}
if ($progress) {
$progress->finish();
$this->newLine();
}
$this->info("Synchronisation terminée ({$synced} comptes liés)");
return CommandAlias::SUCCESS;