feat: complete Epic 0 — foundation migration & infrastructure setup
Stories 0.2-0.5: rename folders→declarations (backend+frontend), configure Redis for cache/queue/sessions, add foundation database migrations (permissions, archived_at), replace DeclarationStatus enum with architecture lifecycle values, create DeclarationObserver for status transition validation and auto-archive, fix controller status transitions to respect observer rules. 93 tests pass (240 assertions). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -2,15 +2,15 @@
|
||||
|
||||
namespace App\Mail;
|
||||
|
||||
use App\Models\Folder;
|
||||
use App\Models\FolderInvitation;
|
||||
use App\Models\Declaration;
|
||||
use App\Models\DeclarationInvitation;
|
||||
use Illuminate\Bus\Queueable;
|
||||
use Illuminate\Mail\Mailable;
|
||||
use Illuminate\Mail\Mailables\Content;
|
||||
use Illuminate\Mail\Mailables\Envelope;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
|
||||
class FolderConfirmationMail extends Mailable
|
||||
class DeclarationConfirmationMail extends Mailable
|
||||
{
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
@@ -18,8 +18,8 @@ class FolderConfirmationMail extends Mailable
|
||||
* Create a new message instance.
|
||||
*/
|
||||
public function __construct(
|
||||
public Folder $folder,
|
||||
public FolderInvitation $invitation,
|
||||
public Declaration $declaration,
|
||||
public DeclarationInvitation $invitation,
|
||||
public string $body
|
||||
) {}
|
||||
|
||||
@@ -29,7 +29,7 @@ class FolderConfirmationMail extends Mailable
|
||||
public function envelope(): Envelope
|
||||
{
|
||||
return new Envelope(
|
||||
subject: 'Demande de validation - '.$this->folder->title,
|
||||
subject: 'Demande de validation - '.$this->declaration->title,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -39,9 +39,9 @@ class FolderConfirmationMail extends Mailable
|
||||
public function content(): Content
|
||||
{
|
||||
return new Content(
|
||||
markdown: 'emails.folder-confirmation',
|
||||
markdown: 'emails.declaration-confirmation',
|
||||
with: [
|
||||
'folderTitle' => $this->folder->title,
|
||||
'declarationTitle' => $this->declaration->title,
|
||||
'body' => $this->body,
|
||||
'confirmUrl' => route('client.confirm', ['token' => $this->invitation->token]),
|
||||
'refuseUrl' => route('client.refuse', ['token' => $this->invitation->token]),
|
||||
@@ -2,15 +2,15 @@
|
||||
|
||||
namespace App\Mail;
|
||||
|
||||
use App\Models\Folder;
|
||||
use App\Models\FolderInvitation;
|
||||
use App\Models\Declaration;
|
||||
use App\Models\DeclarationInvitation;
|
||||
use Illuminate\Bus\Queueable;
|
||||
use Illuminate\Mail\Mailable;
|
||||
use Illuminate\Mail\Mailables\Content;
|
||||
use Illuminate\Mail\Mailables\Envelope;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
|
||||
class FolderFileRequestMail extends Mailable
|
||||
class DeclarationFileRequestMail extends Mailable
|
||||
{
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
@@ -18,8 +18,8 @@ class FolderFileRequestMail extends Mailable
|
||||
* Create a new message instance.
|
||||
*/
|
||||
public function __construct(
|
||||
public Folder $folder,
|
||||
public FolderInvitation $invitation,
|
||||
public Declaration $declaration,
|
||||
public DeclarationInvitation $invitation,
|
||||
public string $body
|
||||
) {}
|
||||
|
||||
@@ -29,7 +29,7 @@ class FolderFileRequestMail extends Mailable
|
||||
public function envelope(): Envelope
|
||||
{
|
||||
return new Envelope(
|
||||
subject: 'Documents complémentaires demandés - '.$this->folder->title,
|
||||
subject: 'Documents complémentaires demandés - '.$this->declaration->title,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -39,9 +39,9 @@ class FolderFileRequestMail extends Mailable
|
||||
public function content(): Content
|
||||
{
|
||||
return new Content(
|
||||
markdown: 'emails.folder-file-request',
|
||||
markdown: 'emails.declaration-file-request',
|
||||
with: [
|
||||
'folderTitle' => $this->folder->title,
|
||||
'declarationTitle' => $this->declaration->title,
|
||||
'body' => $this->body,
|
||||
'uploadUrl' => route('client.upload', ['token' => $this->invitation->token]),
|
||||
'expiresAt' => $this->invitation->expires_at->format('d/m/Y à H:i'),
|
||||
@@ -2,15 +2,15 @@
|
||||
|
||||
namespace App\Mail;
|
||||
|
||||
use App\Models\Folder;
|
||||
use App\Models\FolderInvitation;
|
||||
use App\Models\Declaration;
|
||||
use App\Models\DeclarationInvitation;
|
||||
use Illuminate\Bus\Queueable;
|
||||
use Illuminate\Mail\Mailable;
|
||||
use Illuminate\Mail\Mailables\Content;
|
||||
use Illuminate\Mail\Mailables\Envelope;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
|
||||
class FolderInviteMail extends Mailable
|
||||
class DeclarationInviteMail extends Mailable
|
||||
{
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
@@ -18,8 +18,8 @@ class FolderInviteMail extends Mailable
|
||||
* Create a new message instance.
|
||||
*/
|
||||
public function __construct(
|
||||
public Folder $folder,
|
||||
public FolderInvitation $invitation
|
||||
public Declaration $declaration,
|
||||
public DeclarationInvitation $invitation
|
||||
) {}
|
||||
|
||||
/**
|
||||
@@ -28,7 +28,7 @@ class FolderInviteMail extends Mailable
|
||||
public function envelope(): Envelope
|
||||
{
|
||||
return new Envelope(
|
||||
subject: 'Dépôt de documents - '.$this->folder->title,
|
||||
subject: 'Dépôt de documents - '.$this->declaration->title,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -38,9 +38,9 @@ class FolderInviteMail extends Mailable
|
||||
public function content(): Content
|
||||
{
|
||||
return new Content(
|
||||
markdown: 'emails.folder-invite',
|
||||
markdown: 'emails.declaration-invite',
|
||||
with: [
|
||||
'folderTitle' => $this->folder->title,
|
||||
'declarationTitle' => $this->declaration->title,
|
||||
'uploadUrl' => route('client.upload', ['token' => $this->invitation->token]),
|
||||
'expiresAt' => $this->invitation->expires_at->format('d/m/Y à H:i'),
|
||||
]
|
||||
@@ -2,15 +2,15 @@
|
||||
|
||||
namespace App\Mail;
|
||||
|
||||
use App\Models\Folder;
|
||||
use App\Models\FolderInvitation;
|
||||
use App\Models\Declaration;
|
||||
use App\Models\DeclarationInvitation;
|
||||
use Illuminate\Bus\Queueable;
|
||||
use Illuminate\Mail\Mailable;
|
||||
use Illuminate\Mail\Mailables\Content;
|
||||
use Illuminate\Mail\Mailables\Envelope;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
|
||||
class FolderSituationMail extends Mailable
|
||||
class DeclarationSituationMail extends Mailable
|
||||
{
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
@@ -18,8 +18,8 @@ class FolderSituationMail extends Mailable
|
||||
* Create a new message instance.
|
||||
*/
|
||||
public function __construct(
|
||||
public Folder $folder,
|
||||
public FolderInvitation $invitation,
|
||||
public Declaration $declaration,
|
||||
public DeclarationInvitation $invitation,
|
||||
public string $body
|
||||
) {}
|
||||
|
||||
@@ -29,7 +29,7 @@ class FolderSituationMail extends Mailable
|
||||
public function envelope(): Envelope
|
||||
{
|
||||
return new Envelope(
|
||||
subject: 'Situation mise à jour - '.$this->folder->title,
|
||||
subject: 'Situation mise à jour - '.$this->declaration->title,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -39,9 +39,9 @@ class FolderSituationMail extends Mailable
|
||||
public function content(): Content
|
||||
{
|
||||
return new Content(
|
||||
markdown: 'emails.folder-situation',
|
||||
markdown: 'emails.declaration-situation',
|
||||
with: [
|
||||
'folderTitle' => $this->folder->title,
|
||||
'declarationTitle' => $this->declaration->title,
|
||||
'body' => $this->body,
|
||||
'uploadUrl' => route('client.upload', ['token' => $this->invitation->token]),
|
||||
'expiresAt' => $this->invitation->expires_at->format('d/m/Y à H:i'),
|
||||
@@ -2,24 +2,24 @@
|
||||
|
||||
namespace App\Mail;
|
||||
|
||||
use App\Models\Folder;
|
||||
use App\Models\Declaration;
|
||||
use Illuminate\Bus\Queueable;
|
||||
use Illuminate\Mail\Mailable;
|
||||
use Illuminate\Mail\Mailables\Content;
|
||||
use Illuminate\Mail\Mailables\Envelope;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
|
||||
class FolderTextMessageMail extends Mailable
|
||||
class DeclarationTextMessageMail extends Mailable
|
||||
{
|
||||
use Queueable, SerializesModels;
|
||||
|
||||
/**
|
||||
* Create a new message instance.
|
||||
*
|
||||
* @param string|null $token When set, recipient is client (use token-based URL). When null, recipient is comptable (use folders.show).
|
||||
* @param string|null $token When set, recipient is client (use token-based URL). When null, recipient is comptable (use declarations.show).
|
||||
*/
|
||||
public function __construct(
|
||||
public Folder $folder,
|
||||
public Declaration $declaration,
|
||||
public string $body,
|
||||
public ?string $token = null
|
||||
) {}
|
||||
@@ -30,7 +30,7 @@ class FolderTextMessageMail extends Mailable
|
||||
public function envelope(): Envelope
|
||||
{
|
||||
return new Envelope(
|
||||
subject: 'Nouveau message - '.$this->folder->title,
|
||||
subject: 'Nouveau message - '.$this->declaration->title,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -41,12 +41,12 @@ class FolderTextMessageMail extends Mailable
|
||||
{
|
||||
$messagesUrl = $this->token
|
||||
? route('client.upload', ['token' => $this->token])
|
||||
: route('folders.show', ['folder' => $this->folder]).'?tab=messages';
|
||||
: route('declarations.show', ['declaration' => $this->declaration]).'?tab=messages';
|
||||
|
||||
return new Content(
|
||||
markdown: 'emails.folder-text-message',
|
||||
markdown: 'emails.declaration-text-message',
|
||||
with: [
|
||||
'folderTitle' => $this->folder->title,
|
||||
'declarationTitle' => $this->declaration->title,
|
||||
'body' => $this->body,
|
||||
'messagesUrl' => $messagesUrl,
|
||||
]
|
||||
Reference in New Issue
Block a user