json([ 'success' => 'crater-self-hosted' ]); })->name('ping'); // Version 1 endpoints // -------------------------------------- Route::prefix('/v1')->group(function () { // App version // ---------------------------------- Route::get('/app/version', AppVersionController::class); // Authentication & Password Reset //---------------------------------- Route::group(['prefix' => 'auth'], function () { Route::post('login', [AuthController::class, 'login']); Route::post('logout', [AuthController::class, 'logout'])->middleware('auth:sanctum'); // Send reset password mail Route::post('password/email', [ForgotPasswordController::class, 'sendResetLinkEmail'])->middleware("throttle:10,2");; // handle reset password form process Route::post('reset/password', [ResetPasswordController::class, 'reset']); }); // Countries //---------------------------------- Route::get('/countries', CountriesController::class); // Onboarding //---------------------------------- Route::middleware(['redirect-if-installed'])->group(function () { Route::get('/onboarding/wizard-step', [OnboardingWizardController::class, 'getStep']); Route::post('/onboarding/wizard-step', [OnboardingWizardController::class, 'updateStep']); Route::get('/onboarding/requirements', [RequirementsController::class, 'requirements']); Route::get('/onboarding/permissions', [PermissionsController::class, 'permissions']); Route::post('/onboarding/database/config', [DatabaseConfigurationController::class, 'saveDatabaseEnvironment']); Route::get('/onboarding/database/config', [DatabaseConfigurationController::class, 'getDatabaseEnvironment']); Route::post('/onboarding/finish', FinishController::class); }); Route::middleware(['auth:sanctum', 'admin'])->group(function () { // Bootstrap //---------------------------------- Route::get('/bootstrap', BootstrapController::class); // Dashboard //---------------------------------- Route::get('/dashboard', DashboardController::class); // Search users //---------------------------------- Route::get('/search', SearchController::class); // MISC //---------------------------------- Route::get('/currencies', CurrenciesController::class); Route::get('/timezones', TimezonesController::class); Route::get('/date/formats', DateFormatsController::class); Route::get('/fiscal/years', FiscalYearsController::class); Route::get('/languages', LanguagesController::class); Route::get('/next-number', NextNumberController::class); // Self Update //---------------------------------- Route::get('/check/update', CheckVersionController::class); Route::post('/update/download', DownloadUpdateController::class); Route::post('/update/unzip', UnzipUpdateController::class); Route::post('/update/copy', CopyFilesController::class); Route::post('/update/delete', DeleteFilesController::class); Route::post('/update/migrate', MigrateUpdateController::class); Route::post('/update/finish', FinishUpdateController::class); // Customers //---------------------------------- Route::post('/customers/delete', [CustomersController::class, 'delete']); Route::get('customers/{customer}/stats', CustomerStatsController::class); Route::resource('customers', CustomersController::class); // Items //---------------------------------- Route::post('/items/delete', [ItemsController::class, 'delete']); Route::resource('items', ItemsController::class); Route::resource('units', UnitsController::class); // Invoices //------------------------------------------------- Route::post('/invoices/{invoice}/send', SendInvoiceController::class); Route::post('/invoices/{invoice}/clone', CloneInvoiceController::class); Route::post('/invoices/{invoice}/status', ChangeInvoiceStatusController::class); Route::post('/invoices/delete', [InvoicesController::class, 'delete']); Route::get('/invoices/templates', InvoiceTemplatesController::class); Route::apiResource('invoices', InvoicesController::class); // Estimates //------------------------------------------------- Route::post('/estimates/{estimate}/send', SendEstimateController::class); Route::post('/estimates/{estimate}/status', ChangeEstimateStatusController::class); Route::post('/estimates/{estimate}/convert-to-invoice', ConvertEstimateController::class); Route::get('/estimates/templates', EstimateTemplatesController::class); Route::post('/estimates/delete', [EstimatesController::class, 'delete']); Route::apiResource('estimates', EstimatesController::class); // Expenses //---------------------------------- Route::get('/expenses/{expense}/show/receipt', ShowReceiptController::class); Route::post('/expenses/{expense}/upload/receipts', UploadReceiptController::class); Route::post('/expenses/delete', [ExpensesController::class, 'delete']); Route::apiResource('expenses', ExpensesController::class); Route::apiResource('categories', ExpenseCategoriesController::class); // Payments //---------------------------------- Route::post('/payments/{payment}/send', SendPaymentController::class); Route::post('/payments/delete', [PaymentsController::class, 'delete']); Route::apiResource('payments', PaymentsController::class); Route::apiResource('payment-methods', PaymentMethodsController::class); // Custom fields //---------------------------------- Route::resource('custom-fields', CustomFieldsController::class); // Backup & Disk //---------------------------------- Route::apiResource('backups', BackupsController::class); Route::apiResource('/disks', DiskController::class); Route::get('download-backup', DownloadBackupController::class); Route::get('/disk/drivers', [DiskController::class, 'getDiskDrivers']); // Settings //---------------------------------- Route::get('/me', [CompanyController::class, 'getUser']); Route::put('/me', [CompanyController::class, 'updateProfile']); Route::get('/me/settings', GetUserSettingsController::class); Route::put('/me/settings', UpdateUserSettingsController::class); Route::post('/me/upload-avatar', [CompanyController::class, 'uploadAvatar']); Route::put('/company', [CompanyController::class, 'updateCompany']); Route::post('/company/upload-logo', [CompanyController::class, 'uploadCompanyLogo']); Route::get('/company/settings', GetCompanySettingsController::class); Route::post('/company/settings', UpdateCompanySettingsController::class); // Mails //---------------------------------- Route::get('/mail/drivers', [MailConfigurationController::class, 'getMailDrivers']); Route::get('/mail/config', [MailConfigurationController::class, 'getMailEnvironment']); Route::post('/mail/config', [MailConfigurationController::class, 'saveMailEnvironment']); Route::post('/mail/test', [MailConfigurationController::class, 'testEmailConfig']); Route::apiResource('notes', NotesController::class); // Tax Types //---------------------------------- Route::apiResource('tax-types', TaxTypesController::class); // Users //---------------------------------- Route::post('/users/delete', [UsersController::class, 'delete']); Route::apiResource('/users', UsersController::class); }); });