mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-18 18:54:07 +00:00
Add company invitation system (backend)
New feature allowing company owners/admins to invite users by email with a specific company-scoped role. Database: - New company_invitations table (company_id, email, role_id, token, status, invited_by, expires_at) Backend: - CompanyInvitation model with pending/forUser scopes - InvitationService: invite, accept, decline, getPendingForUser - CompanyInvitationMail with markdown email template - InvitationController (company-scoped): list, send, cancel invitations - InvitationResponseController (user-scoped): pending, accept, decline - BootstrapController returns pending_invitations in response - CompanyMiddleware handles zero-company users gracefully Tests: 9 feature tests covering invite, accept, decline, cancel, expire, duplicate prevention, and bootstrap integration.
This commit is contained in:
@@ -27,6 +27,7 @@ use App\Http\Controllers\Company\Expense\ExpensesController;
|
||||
use App\Http\Controllers\Company\General\BootstrapController;
|
||||
use App\Http\Controllers\Company\General\ConfigController;
|
||||
use App\Http\Controllers\Company\General\FormatsController;
|
||||
use App\Http\Controllers\Company\General\InvitationResponseController;
|
||||
use App\Http\Controllers\Company\General\NotesController;
|
||||
use App\Http\Controllers\Company\General\SearchController;
|
||||
use App\Http\Controllers\Company\General\SerialNumberController;
|
||||
@@ -43,6 +44,7 @@ use App\Http\Controllers\Company\Role\RolesController;
|
||||
use App\Http\Controllers\Company\Settings\CompanyController;
|
||||
use App\Http\Controllers\Company\Settings\CompanyMailConfigurationController;
|
||||
use App\Http\Controllers\Company\Settings\CompanySettingsController;
|
||||
use App\Http\Controllers\Company\Settings\InvitationController;
|
||||
use App\Http\Controllers\Company\Settings\TaxTypesController;
|
||||
use App\Http\Controllers\Company\Settings\UserProfileController;
|
||||
use App\Http\Controllers\Company\Users\UsersController;
|
||||
@@ -171,6 +173,13 @@ Route::prefix('/v1')->group(function () {
|
||||
|
||||
Route::get('/bootstrap', BootstrapController::class);
|
||||
|
||||
// Invitations (user-scoped — respond to invitations)
|
||||
// ----------------------------------
|
||||
|
||||
Route::get('/invitations/pending', [InvitationResponseController::class, 'pending']);
|
||||
Route::post('/invitations/{invitation:token}/accept', [InvitationResponseController::class, 'accept']);
|
||||
Route::post('/invitations/{invitation:token}/decline', [InvitationResponseController::class, 'decline']);
|
||||
|
||||
// Currencies
|
||||
// ----------------------------------
|
||||
|
||||
@@ -216,6 +225,11 @@ Route::prefix('/v1')->group(function () {
|
||||
|
||||
Route::get('/current-company', [BootstrapController::class, 'currentCompany']);
|
||||
|
||||
// Company Invitations (company-scoped — send invitations)
|
||||
// ----------------------------------
|
||||
|
||||
Route::apiResource('company-invitations', InvitationController::class)->only(['index', 'store', 'destroy']);
|
||||
|
||||
// Customers
|
||||
// ----------------------------------
|
||||
|
||||
|
||||
Reference in New Issue
Block a user