mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-24 15:26:33 -06:00
708 lines
32 KiB
PHP
Executable File
708 lines
32 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* web.php
|
|
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
*
|
|
* This software may be modified and distributed under the terms of the
|
|
* Creative Commons Attribution-ShareAlike 4.0 International License.
|
|
*
|
|
* See the LICENSE file for details.
|
|
*/
|
|
|
|
declare(strict_types = 1);
|
|
|
|
|
|
/**
|
|
* These routes only work when the user is NOT logged in.
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-not-logged-in'], function () {
|
|
|
|
// Authentication Routes...
|
|
Route::get('login', 'Auth\LoginController@showLoginForm')->name('login');
|
|
Route::post('login', 'Auth\LoginController@login');
|
|
|
|
// Registration Routes...
|
|
Route::get('register', ['uses' => 'Auth\RegisterController@showRegistrationForm', 'as' => 'register']);
|
|
Route::post('register', 'Auth\RegisterController@register');
|
|
|
|
// Password Reset Routes...
|
|
Route::get('password/reset/{token}', ['uses' => 'Auth\ResetPasswordController@showResetForm', 'as' => 'password.reset']);
|
|
Route::post('password/email', 'Auth\ForgotPasswordController@sendResetLinkEmail');
|
|
Route::post('password/reset', 'Auth\ResetPasswordController@reset');
|
|
Route::get('password/reset', 'Auth\ForgotPasswordController@showLinkRequestForm');
|
|
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* For some other routes, it is only relevant that the user is authenticated.
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-simple-auth'], function () {
|
|
Route::get('error', ['uses' => 'HomeController@displayError', 'as' => 'error']);
|
|
Route::any('logout', ['uses' => 'Auth\LoginController@logout', 'as' => 'logout']);
|
|
Route::get('flush', ['uses' => 'HomeController@flush', 'as' => 'flush']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* For the two factor routes, the user must be logged in, but NOT 2FA. Account confirmation does not matter here.
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-logged-in-no-2fa', 'prefix' => 'two-factor', 'as' => 'two-factor.', 'namespace' => 'Auth'], function () {
|
|
Route::get('', ['uses' => 'TwoFactorController@index', 'as' => 'index']);
|
|
Route::get('lost', ['uses' => 'TwoFactorController@lostTwoFactor', 'as' => 'lost']);
|
|
Route::post('', ['uses' => 'TwoFactorController@postIndex', 'as' => 'post']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* For the confirmation routes, the user must be logged in, also 2FA, but his account must not be confirmed.
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-logged-in-2fa-no-activation', 'namespace' => 'Auth'], function () {
|
|
Route::get('/confirm-your-account', ['uses' => 'ConfirmationController@confirmationError', 'as' => 'confirmation_error']);
|
|
Route::get('/resend-confirmation', ['uses' => 'ConfirmationController@resendConfirmation', 'as' => 'resend_confirmation']);
|
|
Route::get('/confirmation/{code}', ['uses' => 'ConfirmationController@doConfirmation', 'as' => 'do_confirm_account']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* For all other routes, the user must be fully authenticated and have an activated account.
|
|
*/
|
|
|
|
/**
|
|
* Home Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => ['user-full-auth']], function () {
|
|
Route::get('/', ['uses' => 'HomeController@index', 'as' => 'index']);
|
|
Route::get('/flash', ['uses' => 'HomeController@testFlash', 'as' => 'test-flash']);
|
|
Route::get('/home', ['uses' => 'HomeController@index', 'as' => 'home']);
|
|
Route::post('/daterange', ['uses' => 'HomeController@dateRange', 'as' => 'daterange']);
|
|
Route::get('/routes', ['uses' => 'HomeController@routes', 'as' => 'all-routes']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Account Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'accounts', 'as' => 'accounts.'], function () {
|
|
Route::get('{what}', ['uses' => 'AccountController@index', 'as' => 'index'])->where('what', 'revenue|asset|expense');
|
|
Route::get('create/{what}', ['uses' => 'AccountController@create', 'as' => 'create'])->where('what', 'revenue|asset|expense');
|
|
Route::get('edit/{account}', ['uses' => 'AccountController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{account}', ['uses' => 'AccountController@delete', 'as' => 'delete']);
|
|
|
|
Route::get('show/{account}', ['uses' => 'AccountController@show', 'as' => 'show']);
|
|
Route::get('show/{account}/all', ['uses' => 'AccountController@showAll', 'as' => 'show.all']);
|
|
Route::get('show/{account}/{date}', ['uses' => 'AccountController@showByDate', 'as' => 'show.date']);
|
|
|
|
Route::post('store', ['uses' => 'AccountController@store', 'as' => 'store']);
|
|
Route::post('update/{account}', ['uses' => 'AccountController@update', 'as' => 'update']);
|
|
Route::post('destroy/{account}', ['uses' => 'AccountController@destroy', 'as' => 'destroy']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Attachment Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'attachments', 'as' => 'attachments.'], function () {
|
|
Route::get('edit/{attachment}', ['uses' => 'AttachmentController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{attachment}', ['uses' => 'AttachmentController@delete', 'as' => 'delete']);
|
|
Route::get('preview/{attachment}', ['uses' => 'AttachmentController@preview', 'as' => 'preview']);
|
|
Route::get('download/{attachment}', ['uses' => 'AttachmentController@download', 'as' => 'download']);
|
|
|
|
Route::post('update/{attachment}', ['uses' => 'AttachmentController@update', 'as' => 'update']);
|
|
Route::post('destroy/{attachment}', ['uses' => 'AttachmentController@destroy', 'as' => 'destroy']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Bills Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'bills', 'as' => 'bills.'], function () {
|
|
Route::get('', ['uses' => 'BillController@index', 'as' => 'index']);
|
|
Route::get('rescan/{bill}', ['uses' => 'BillController@rescan', 'as' => 'rescan']);
|
|
Route::get('create', ['uses' => 'BillController@create', 'as' => 'create']);
|
|
Route::get('edit/{bill}', ['uses' => 'BillController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{bill}', ['uses' => 'BillController@delete', 'as' => 'delete']);
|
|
Route::get('show/{bill}', ['uses' => 'BillController@show', 'as' => 'show']);
|
|
Route::post('store', ['uses' => 'BillController@store', 'as' => 'store']);
|
|
|
|
Route::post('update/{bill}', ['uses' => 'BillController@update', 'as' => 'update']);
|
|
Route::post('destroy/{bill}', ['uses' => 'BillController@destroy', 'as' => 'destroy']);
|
|
}
|
|
);
|
|
|
|
|
|
/**
|
|
* Budget Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'budgets', 'as' => 'budgets.'], function () {
|
|
Route::get('', ['uses' => 'BudgetController@index', 'as' => 'index']);
|
|
Route::get('income', ['uses' => 'BudgetController@updateIncome', 'as' => 'income']);
|
|
Route::get('create', ['uses' => 'BudgetController@create', 'as' => 'create']);
|
|
Route::get('edit/{budget}', ['uses' => 'BudgetController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{budget}', ['uses' => 'BudgetController@delete', 'as' => 'delete']);
|
|
Route::get('show/{budget}', ['uses' => 'BudgetController@show', 'as' => 'show']);
|
|
Route::get('show/{budget}/{limitrepetition}', ['uses' => 'BudgetController@showByRepetition', 'as' => 'show.repetition']);
|
|
Route::get('list/no-budget', ['uses' => 'BudgetController@noBudget', 'as' => 'no-budget']);
|
|
|
|
Route::post('income', ['uses' => 'BudgetController@postUpdateIncome', 'as' => 'income.post']);
|
|
Route::post('store', ['uses' => 'BudgetController@store', 'as' => 'store']);
|
|
Route::post('update/{budget}', ['uses' => 'BudgetController@update', 'as' => 'update']);
|
|
Route::post('destroy/{budget}', ['uses' => 'BudgetController@destroy', 'as' => 'destroy']);
|
|
Route::post('amount/{budget}', ['uses' => 'BudgetController@amount', 'as' => 'amount']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Category Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'categories', 'as' => 'categories.'], function () {
|
|
Route::get('', ['uses' => 'CategoryController@index', 'as' => 'index']);
|
|
Route::get('create', ['uses' => 'CategoryController@create', 'as' => 'create']);
|
|
Route::get('edit/{category}', ['uses' => 'CategoryController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{category}', ['uses' => 'CategoryController@delete', 'as' => 'delete']);
|
|
|
|
Route::get('show/{category}', ['uses' => 'CategoryController@show', 'as' => 'show']);
|
|
Route::get('show/{category}/{date}', ['uses' => 'CategoryController@showByDate', 'as' => 'show.date']);
|
|
Route::get('list/no-category', ['uses' => 'CategoryController@noCategory', 'as' => 'no-category']);
|
|
|
|
Route::post('store', ['uses' => 'CategoryController@store', 'as' => 'store']);
|
|
Route::post('update/{category}', ['uses' => 'CategoryController@update', 'as' => 'update']);
|
|
Route::post('destroy/{category}', ['uses' => 'CategoryController@destroy', 'as' => 'destroy']);
|
|
}
|
|
);
|
|
|
|
|
|
/**
|
|
* Currency Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'currencies', 'as' => 'currencies.'], function () {
|
|
Route::get('', ['uses' => 'CurrencyController@index', 'as' => 'index']);
|
|
Route::get('create', ['uses' => 'CurrencyController@create', 'as' => 'create']);
|
|
Route::get('edit/{currency}', ['uses' => 'CurrencyController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{currency}', ['uses' => 'CurrencyController@delete', 'as' => 'delete']);
|
|
Route::get('default/{currency}', ['uses' => 'CurrencyController@defaultCurrency', 'as' => 'default']);
|
|
|
|
Route::post('store', ['uses' => 'CurrencyController@store', 'as' => 'store']);
|
|
Route::post('update/{currency}', ['uses' => 'CurrencyController@update', 'as' => 'update']);
|
|
Route::post('destroy/{currency}', ['uses' => 'CurrencyController@destroy', 'as' => 'destroy']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Export Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'export', 'as' => 'export.'], function () {
|
|
Route::get('', ['uses' => 'ExportController@index', 'as' => 'index']);
|
|
Route::get('status/{jobKey}', ['uses' => 'ExportController@getStatus', 'as' => 'status']);
|
|
Route::get('download/{jobKey}', ['uses' => 'ExportController@download', 'as' => 'download']);
|
|
|
|
Route::post('submit', ['uses' => 'ExportController@postIndex', 'as' => 'export']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Chart\Account Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/account', 'as' => 'chart.account.'], function () {
|
|
Route::get('frontpage', ['uses' => 'AccountController@frontpage', 'as' => 'frontpage']);
|
|
Route::get('expense', ['uses' => 'AccountController@expenseAccounts', 'as' => 'expense']);
|
|
Route::get('revenue', ['uses' => 'AccountController@revenueAccounts', 'as' => 'revenue']);
|
|
Route::get('report/{accountList}/{start_date}/{end_date}', ['uses' => 'AccountController@report', 'as' => 'report']);
|
|
Route::get('all/{account}', ['uses' => 'AccountController@all', 'as' => 'all']);
|
|
Route::get('single/{account}', ['uses' => 'AccountController@single', 'as' => 'single']);
|
|
Route::get('period/{account}/{date}', ['uses' => 'AccountController@period', 'as' => 'period']);
|
|
|
|
|
|
Route::get('income-category/{account}/{start_date}/{end_date}', ['uses' => 'AccountController@incomeCategory', 'as' => 'income-category']);
|
|
Route::get('expense-category/{account}/{start_date}/{end_date}', ['uses' => 'AccountController@expenseCategory', 'as' => 'expense-category']);
|
|
Route::get('expense-budget/{account}/{start_date}/{end_date}', ['uses' => 'AccountController@expenseBudget', 'as' => 'expense-budget']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Chart\Bill Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/bill', 'as' => 'chart.bill.'], function () {
|
|
Route::get('frontpage', ['uses' => 'BillController@frontpage', 'as' => 'frontpage']);
|
|
Route::get('single/{bill}', ['uses' => 'BillController@single', 'as' => 'single']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Chart\Budget Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/budget', 'as' => 'chart.budget.'], function () {
|
|
|
|
Route::get('frontpage', ['uses' => 'BudgetController@frontpage', 'as' => 'frontpage']);
|
|
Route::get('period/0/{accountList}/{start_date}/{end_date}', ['uses' => 'BudgetController@periodNoBudget', 'as' => 'period.no-budget']);
|
|
Route::get('period/{budget}/{accountList}/{start_date}/{end_date}', ['uses' => 'BudgetController@period', 'as' => 'period']);
|
|
Route::get('budget/{budget}/{limitrepetition}', ['uses' => 'BudgetController@budgetLimit', 'as' => 'budget-limit']);
|
|
Route::get('budget/{budget}', ['uses' => 'BudgetController@budget', 'as' => 'budget']);
|
|
|
|
|
|
// these charts are used in reports (category reports):
|
|
Route::get(
|
|
'budget/expense/{accountList}/{budgetList}/{start_date}/{end_date}/{others}',
|
|
['uses' => 'BudgetReportController@budgetExpense', 'as' => 'budget-expense']
|
|
);
|
|
Route::get(
|
|
'account/expense/{accountList}/{budgetList}/{start_date}/{end_date}/{others}',
|
|
['uses' => 'BudgetReportController@accountExpense', 'as' => 'account-expense']
|
|
);
|
|
|
|
Route::get(
|
|
'operations/{accountList}/{budgetList}/{start_date}/{end_date}',
|
|
['uses' => 'BudgetReportController@mainChart', 'as' => 'main']
|
|
);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Chart\Category Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/category', 'as' => 'chart.category.'], function () {
|
|
|
|
Route::get('frontpage', ['uses' => 'CategoryController@frontpage', 'as' => 'frontpage']);
|
|
Route::get('period/{category}', ['uses' => 'CategoryController@currentPeriod', 'as' => 'current']);
|
|
Route::get('period/{category}/{date}', ['uses' => 'CategoryController@specificPeriod', 'as' => 'specific']);
|
|
Route::get('all/{category}', ['uses' => 'CategoryController@all', 'as' => 'all']);
|
|
Route::get('report-period/0/{accountList}/{start_date}/{end_date}', ['uses' => 'CategoryController@reportPeriodNoCategory', 'as' => 'period.no-category']);
|
|
Route::get('report-period/{category}/{accountList}/{start_date}/{end_date}', ['uses' => 'CategoryController@reportPeriod', 'as' => 'period']);
|
|
|
|
// these charts are used in reports (category reports):
|
|
Route::get(
|
|
'category/income/{accountList}/{categoryList}/{start_date}/{end_date}/{others}',
|
|
['uses' => 'CategoryReportController@categoryIncome', 'as' => 'category-income']
|
|
);
|
|
Route::get(
|
|
'category/expense/{accountList}/{categoryList}/{start_date}/{end_date}/{others}',
|
|
['uses' => 'CategoryReportController@categoryExpense', 'as' => 'category-expense']
|
|
);
|
|
Route::get(
|
|
'account/income/{accountList}/{categoryList}/{start_date}/{end_date}/{others}',
|
|
['uses' => 'CategoryReportController@accountIncome', 'as' => 'account-income']
|
|
);
|
|
Route::get(
|
|
'account/expense/{accountList}/{categoryList}/{start_date}/{end_date}/{others}',
|
|
['uses' => 'CategoryReportController@accountExpense', 'as' => 'account-expense']
|
|
);
|
|
|
|
Route::get(
|
|
'operations/{accountList}/{categoryList}/{start_date}/{end_date}',
|
|
['uses' => 'CategoryReportController@mainChart', 'as' => 'main']
|
|
);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Chart\PiggyBank Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/piggy-bank', 'as' => 'chart.piggy-bank.'], function () {
|
|
Route::get('{piggyBank}', ['uses' => 'PiggyBankController@history', 'as' => 'history']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Chart\Report Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Chart', 'prefix' => 'chart/report', 'as' => 'chart.report.'], function () {
|
|
Route::get('operations/{accountList}/{start_date}/{end_date}', ['uses' => 'ReportController@operations', 'as' => 'operations']);
|
|
Route::get('operations-sum/{accountList}/{start_date}/{end_date}/', ['uses' => 'ReportController@sum', 'as' => 'sum']);
|
|
Route::get('net-worth/{accountList}/{start_date}/{end_date}/', ['uses' => 'ReportController@netWorth', 'as' => 'net-worth']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Import Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'import', 'as' => 'import.'], function () {
|
|
Route::get('', ['uses' => 'ImportController@index', 'as' => 'index']);
|
|
Route::get('configure/{importJob}', ['uses' => 'ImportController@configure', 'as' => 'configure']);
|
|
Route::get('settings/{importJob}', ['uses' => 'ImportController@settings', 'as' => 'settings']);
|
|
Route::get('complete/{importJob}', ['uses' => 'ImportController@complete', 'as' => 'complete']);
|
|
Route::get('download/{importJob}', ['uses' => 'ImportController@download', 'as' => 'download']);
|
|
Route::get('status/{importJob}', ['uses' => 'ImportController@status', 'as' => 'status']);
|
|
Route::get('json/{importJob}', ['uses' => 'ImportController@json', 'as' => 'json']);
|
|
Route::get('finished/{importJob}', ['uses' => 'ImportController@finished', 'as' => 'finished']);
|
|
|
|
Route::post('upload', ['uses' => 'ImportController@upload', 'as' => 'upload']);
|
|
Route::post('configure/{importJob}', ['uses' => 'ImportController@postConfigure', 'as' => 'process-configuration']);
|
|
Route::post('settings/{importJob}', ['uses' => 'ImportController@postSettings', 'as' => 'post-settings']);
|
|
Route::post('start/{importJob}', ['uses' => 'ImportController@start', 'as' => 'start']);
|
|
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Help Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'help', 'as' => 'help.'], function () {
|
|
Route::get('{route}', ['uses' => 'HelpController@show', 'as' => 'show']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* JSON Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'json', 'as' => 'json.'], function () {
|
|
Route::get('expense-accounts', ['uses' => 'JsonController@expenseAccounts', 'as' => 'expense-accounts']);
|
|
Route::get('revenue-accounts', ['uses' => 'JsonController@revenueAccounts', 'as' => 'revenue-accounts']);
|
|
Route::get('categories', ['uses' => 'JsonController@categories', 'as' => 'categories']);
|
|
Route::get('tags', ['uses' => 'JsonController@tags', 'as' => 'tags']);
|
|
Route::get('tour', ['uses' => 'JsonController@tour', 'as' => 'tour']);
|
|
Route::get('box/in', ['uses' => 'JsonController@boxIn', 'as' => 'box.in']);
|
|
Route::get('box/out', ['uses' => 'JsonController@boxOut', 'as' => 'box.out']);
|
|
Route::get('box/bills-unpaid', ['uses' => 'JsonController@boxBillsUnpaid', 'as' => 'box.paid']);
|
|
Route::get('box/bills-paid', ['uses' => 'JsonController@boxBillsPaid', 'as' => 'box.unpaid']);
|
|
Route::get('transaction-journals/{what}', ['uses' => 'JsonController@transactionJournals', 'as' => 'transaction-journals']);
|
|
Route::get('trigger', ['uses' => 'JsonController@trigger', 'as' => 'trigger']);
|
|
Route::get('action', ['uses' => 'JsonController@action', 'as' => 'action']);
|
|
|
|
Route::post('end-tour', ['uses' => 'JsonController@endTour','as' => 'end-tour']);
|
|
|
|
}
|
|
);
|
|
|
|
|
|
/**
|
|
* NewUser Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'new-user', 'as' => 'new-user.'], function () {
|
|
Route::get('', ['uses' => 'NewUserController@index', 'as' => 'index']);
|
|
Route::post('submit', ['uses' => 'NewUserController@submit', 'as' => 'submit']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Piggy Bank Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'piggy-banks', 'as' => 'piggy-banks.'], function () {
|
|
Route::get('', ['uses' => 'PiggyBankController@index', 'as' => 'index']);
|
|
Route::get('add/{piggyBank}', ['uses' => 'PiggyBankController@add', 'as' => 'add-money']);
|
|
Route::get('remove/{piggyBank}', ['uses' => 'PiggyBankController@remove', 'as' => 'remove-money']);
|
|
Route::get('add-money/{piggyBank}', ['uses' => 'PiggyBankController@addMobile', 'as' => 'add-money-mobile']);
|
|
Route::get('remove-money/{piggyBank}', ['uses' => 'PiggyBankController@removeMobile', 'as' => 'remove-money-mobile']);
|
|
Route::get('create', ['uses' => 'PiggyBankController@create', 'as' => 'create']);
|
|
Route::get('edit/{piggyBank}', ['uses' => 'PiggyBankController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{piggyBank}', ['uses' => 'PiggyBankController@delete', 'as' => 'delete']);
|
|
Route::get('show/{piggyBank}', ['uses' => 'PiggyBankController@show', 'as' => 'show']);
|
|
Route::post('store', ['uses' => 'PiggyBankController@store', 'as' => 'store']);
|
|
Route::post('update/{piggyBank}', ['uses' => 'PiggyBankController@update', 'as' => 'update']);
|
|
Route::post('destroy/{piggyBank}', ['uses' => 'PiggyBankController@destroy', 'as' => 'destroy']);
|
|
Route::post('add/{piggyBank}', ['uses' => 'PiggyBankController@postAdd', 'as' => 'add']);
|
|
Route::post('remove/{piggyBank}', ['uses' => 'PiggyBankController@postRemove', 'as' => 'remove']);
|
|
Route::post('sort', ['uses' => 'PiggyBankController@order', 'as' => 'order']);
|
|
|
|
|
|
}
|
|
);
|
|
|
|
|
|
/**
|
|
* Preferences Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'preferences', 'as' => 'preferences.'], function () {
|
|
Route::get('', ['uses' => 'PreferencesController@index', 'as' => 'index']);
|
|
Route::get('/code', ['uses' => 'PreferencesController@code', 'as' => 'code']);
|
|
Route::get('/delete-code', ['uses' => 'PreferencesController@deleteCode', 'as' => 'delete-code']);
|
|
Route::post('', ['uses' => 'PreferencesController@postIndex', 'as' => 'update']);
|
|
Route::post('/code', ['uses' => 'PreferencesController@postCode', 'as' => 'code.store']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Profile Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'profile', 'as' => 'profile.'], function () {
|
|
|
|
Route::get('', ['uses' => 'ProfileController@index', 'as' => 'index']);
|
|
Route::get('change-password', ['uses' => 'ProfileController@changePassword', 'as' => 'change-password']);
|
|
Route::get('delete-account', ['uses' => 'ProfileController@deleteAccount', 'as' => 'delete-account']);
|
|
|
|
Route::post('delete-account', ['uses' => 'ProfileController@postDeleteAccount', 'as' => 'delete-account.post']);
|
|
Route::post('change-password', ['uses' => 'ProfileController@postChangePassword', 'as' => 'change-password.post']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'reports', 'as' => 'reports.'], function () {
|
|
|
|
Route::get('', ['uses' => 'ReportController@index', 'as' => 'index']);
|
|
Route::get('options/{reportType}', ['uses' => 'ReportController@options', 'as' => 'options']);
|
|
Route::get('default/{accountList}/{start_date}/{end_date}', ['uses' => 'ReportController@defaultReport', 'as' => 'report.default']);
|
|
Route::get('audit/{accountList}/{start_date}/{end_date}', ['uses' => 'ReportController@auditReport', 'as' => 'report.audit']);
|
|
Route::get('category/{accountList}/{categoryList}/{start_date}/{end_date}', ['uses' => 'ReportController@categoryReport', 'as' => 'report.category']);
|
|
Route::get('budget/{accountList}/{budgetList}/{start_date}/{end_date}', ['uses' => 'ReportController@budgetReport', 'as' => 'report.budget']);
|
|
|
|
Route::post('', ['uses' => 'ReportController@postIndex', 'as' => 'index.post']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Data AccountController
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Report', 'prefix' => 'report-data/account', 'as' => 'report-data.account.'], function () {
|
|
Route::get('general/{accountList}/{start_date}/{end_date}', ['uses' => 'AccountController@general', 'as' => 'general']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Data Income/Expenses Controller (called financial operations)
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Report', 'prefix' => 'report-data/operations', 'as' => 'report-data.operations.'], function () {
|
|
Route::get('operations/{accountList}/{start_date}/{end_date}', ['uses' => 'OperationsController@operations', 'as' => 'operations']);
|
|
Route::get('income/{accountList}/{start_date}/{end_date}', ['uses' => 'OperationsController@income', 'as' => 'income']);
|
|
Route::get('expenses/{accountList}/{start_date}/{end_date}', ['uses' => 'OperationsController@expenses', 'as' => 'expenses']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Data Category Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Report', 'prefix' => 'report-data/category', 'as' => 'report-data.category.'], function () {
|
|
Route::get('operations/{accountList}/{start_date}/{end_date}', ['uses' => 'CategoryController@operations', 'as' => 'operations']);
|
|
Route::get('income/{accountList}/{start_date}/{end_date}', ['uses' => 'CategoryController@income', 'as' => 'income']);
|
|
Route::get('expenses/{accountList}/{start_date}/{end_date}', ['uses' => 'CategoryController@expenses', 'as' => 'expenses']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Data Balance Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Report', 'prefix' => 'report-data/balance', 'as' => 'report-data.balance.'], function () {
|
|
|
|
Route::get('general/{accountList}/{start_date}/{end_date}', ['uses' => 'BalanceController@general', 'as' => 'general']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Data Budget Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Report', 'prefix' => 'report-data/budget', 'as' => 'report-data.budget.'], function () {
|
|
|
|
Route::get('general/{accountList}/{start_date}/{end_date}/', ['uses' => 'BudgetController@general', 'as' => 'general']);
|
|
Route::get('period/{accountList}/{start_date}/{end_date}', ['uses' => 'BudgetController@period', 'as' => 'period']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Rules Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'rules', 'as' => 'rules.'], function () {
|
|
|
|
Route::get('', ['uses' => 'RuleController@index', 'as' => 'index']);
|
|
Route::get('create/{ruleGroup}', ['uses' => 'RuleController@create', 'as' => 'create']);
|
|
Route::get('up/{rule}', ['uses' => 'RuleController@up', 'as' => 'up']);
|
|
Route::get('down/{rule}', ['uses' => 'RuleController@down', 'as' => 'down']);
|
|
Route::get('edit/{rule}', ['uses' => 'RuleController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{rule}', ['uses' => 'RuleController@delete', 'as' => 'delete']);
|
|
Route::get('test', ['uses' => 'RuleController@testTriggers', 'as' => 'test-triggers']);
|
|
|
|
Route::post('trigger/order/{rule}', ['uses' => 'RuleController@reorderRuleTriggers', 'as' => 'reorder-triggers']);
|
|
Route::post('action/order/{rule}', ['uses' => 'RuleController@reorderRuleActions', 'as' => 'reorder-actions']);
|
|
Route::post('store/{ruleGroup}', ['uses' => 'RuleController@store', 'as' => 'store']);
|
|
Route::post('update/{rule}', ['uses' => 'RuleController@update', 'as' => 'update']);
|
|
Route::post('destroy/{rule}', ['uses' => 'RuleController@destroy', 'as' => 'destroy']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Rule Groups Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'rule-groups', 'as' => 'rule-groups.'], function () {
|
|
Route::get('create', ['uses' => 'RuleGroupController@create', 'as' => 'create']);
|
|
Route::get('edit/{ruleGroup}', ['uses' => 'RuleGroupController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{ruleGroup}', ['uses' => 'RuleGroupController@delete', 'as' => 'delete']);
|
|
Route::get('up/{ruleGroup}', ['uses' => 'RuleGroupController@up', 'as' => 'up']);
|
|
Route::get('down/{ruleGroup}', ['uses' => 'RuleGroupController@down', 'as' => 'down']);
|
|
Route::get('select/{ruleGroup}', ['uses' => 'RuleGroupController@selectTransactions', 'as' => 'select-transactions']);
|
|
|
|
Route::post('store', ['uses' => 'RuleGroupController@store', 'as' => 'store']);
|
|
Route::post('update/{ruleGroup}', ['uses' => 'RuleGroupController@update', 'as' => 'update']);
|
|
Route::post('destroy/{ruleGroup}', ['uses' => 'RuleGroupController@destroy', 'as' => 'destroy']);
|
|
Route::post('execute/{ruleGroup}', ['uses' => 'RuleGroupController@execute', 'as' => 'execute']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Search Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'search', 'as' => 'search.'], function () {
|
|
Route::get('', ['uses' => 'SearchController@index', 'as' => 'index']);
|
|
|
|
}
|
|
);
|
|
|
|
|
|
/**
|
|
* Tag Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'tags', 'as' => 'tags.'], function () {
|
|
|
|
Route::get('', ['uses' => 'TagController@index', 'as' => 'index']);
|
|
Route::get('create', ['uses' => 'TagController@create', 'as' => 'create']);
|
|
Route::get('show/{tag}', ['uses' => 'TagController@show', 'as' => 'show']);
|
|
Route::get('edit/{tag}', ['uses' => 'TagController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{tag}', ['uses' => 'TagController@delete', 'as' => 'delete']);
|
|
|
|
Route::post('store', ['uses' => 'TagController@store', 'as' => 'store']);
|
|
Route::post('update/{tag}', ['uses' => 'TagController@update', 'as' => 'update']);
|
|
Route::post('destroy/{tag}', ['uses' => 'TagController@destroy', 'as' => 'destroy']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Transaction Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'prefix' => 'transactions', 'as' => 'transactions.'], function () {
|
|
Route::get('{what}', ['uses' => 'TransactionController@index', 'as' => 'index'])->where(['what' => 'withdrawal|deposit|transfers|transfer']);
|
|
Route::get('{what}/all', ['uses' => 'TransactionController@indexAll', 'as' => 'index.all'])->where(['what' => 'withdrawal|deposit|transfers|transfer']);
|
|
Route::get('{what}/{date}', ['uses' => 'TransactionController@indexByDate', 'as' => 'index.date'])->where(
|
|
['what' => 'withdrawal|deposit|transfers|transfer']
|
|
);
|
|
Route::get('show/{tj}', ['uses' => 'TransactionController@show', 'as' => 'show']);
|
|
Route::post('reorder', ['uses' => 'TransactionController@reorder', 'as' => 'reorder']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Transaction Single Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Transaction', 'prefix' => 'transactions', 'as' => 'transactions.'], function () {
|
|
Route::get('create/{what}', ['uses' => 'SingleController@create', 'as' => 'create'])->where(['what' => 'withdrawal|deposit|transfer']);
|
|
Route::get('edit/{tj}', ['uses' => 'SingleController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{tj}', ['uses' => 'SingleController@delete', 'as' => 'delete']);
|
|
Route::post('store/{what}', ['uses' => 'SingleController@store', 'as' => 'store'])->where(['what' => 'withdrawal|deposit|transfer']);
|
|
Route::post('update/{tj}', ['uses' => 'SingleController@update', 'as' => 'update']);
|
|
Route::post('destroy/{tj}', ['uses' => 'SingleController@destroy', 'as' => 'destroy']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Transaction Mass Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Transaction', 'prefix' => 'transactions/mass', 'as' => 'transactions.mass.'], function () {
|
|
Route::get('edit/{journalList}', ['uses' => 'MassController@edit', 'as' => 'edit']);
|
|
Route::get('delete/{journalList}', ['uses' => 'MassController@delete', 'as' => 'delete']);
|
|
Route::post('update', ['uses' => 'MassController@update', 'as' => 'update']);
|
|
Route::post('destroy', ['uses' => 'MassController@destroy', 'as' => 'destroy']);
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Transaction Split Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Transaction', 'prefix' => 'transactions/split', 'as' => 'transactions.split.'], function () {
|
|
Route::get('edit/{tj}', ['uses' => 'SplitController@edit', 'as' => 'edit']);
|
|
Route::post('update/{tj}', ['uses' => 'SplitController@update', 'as' => 'update']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Convert Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Transaction', 'prefix' => 'transactions/convert', 'as' => 'transactions.convert.'], function () {
|
|
Route::get('{transaction_type}/{tj}', ['uses' => 'ConvertController@index', 'as' => 'index']);
|
|
Route::post('{transaction_type}/{tj}', ['uses' => 'ConvertController@postIndex', 'as' => 'index.post']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Report Popup Controller
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'user-full-auth', 'namespace' => 'Popup', 'prefix' => 'popup', 'as' => 'popup.'], function () {
|
|
Route::get('general', ['uses' => 'ReportController@general', 'as' => 'general']);
|
|
|
|
}
|
|
);
|
|
|
|
/**
|
|
* For the admin routes, the user must be logged in and have the role of 'owner'
|
|
*/
|
|
Route::group(
|
|
['middleware' => 'admin', 'namespace' => 'Admin', 'prefix' => 'admin', 'as' => 'admin.'], function () {
|
|
|
|
// admin home
|
|
Route::get('', ['uses' => 'HomeController@index', 'as' => 'index']);
|
|
|
|
// user manager
|
|
Route::get('users', ['uses' => 'UserController@index', 'as' => 'users']);
|
|
Route::get('users/edit/{user}', ['uses' => 'UserController@edit', 'as' => 'users.edit']);
|
|
Route::get('users/show/{user}', ['uses' => 'UserController@show', 'as' => 'users.show']);
|
|
Route::post('users/update/{user}', ['uses' => 'UserController@update', 'as' => 'users.update']);
|
|
|
|
// user domain manager
|
|
Route::get('domains', ['uses' => 'DomainController@domains', 'as' => 'users.domains']);
|
|
Route::get('domains/toggle/{domain}', ['uses' => 'DomainController@toggleDomain', 'as' => 'users.domains.block-toggle']);
|
|
Route::post('domains/manual', ['uses' => 'DomainController@manual', 'as' => 'users.domains.manual']);
|
|
|
|
// FF configuration:
|
|
Route::get('configuration', ['uses' => 'ConfigurationController@index', 'as' => 'configuration.index']);
|
|
Route::post('configuration', ['uses' => 'ConfigurationController@postIndex', 'as' => 'configuration.index.post']);
|
|
|
|
}
|
|
);
|