mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2024-12-26 08:51:12 -06:00
New middleware
This commit is contained in:
parent
d439dceac1
commit
a14544398b
@ -12,43 +12,6 @@ use FireflyIII\Models\TransactionCurrency;
|
|||||||
use FireflyIII\Models\TransactionJournal;
|
use FireflyIII\Models\TransactionJournal;
|
||||||
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||||
|
|
||||||
|
|
||||||
// models
|
|
||||||
Route::bind(
|
|
||||||
'account',
|
|
||||||
function ($value) {
|
|
||||||
if (Auth::check()) {
|
|
||||||
$object = Account::leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id')
|
|
||||||
->where('account_types.editable', 1)
|
|
||||||
->where('accounts.id', $value)
|
|
||||||
->where('user_id', Auth::user()->id)
|
|
||||||
->first(['accounts.*']);
|
|
||||||
if ($object) {
|
|
||||||
return $object;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new NotFoundHttpException;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
// accounts
|
|
||||||
Route::bind(
|
|
||||||
'accountList',
|
|
||||||
function ($value) {
|
|
||||||
if (Auth::check()) {
|
|
||||||
$ids = explode(',', $value);
|
|
||||||
/** @var \Illuminate\Support\Collection $object */
|
|
||||||
$object = Account::leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id')
|
|
||||||
->where('account_types.editable', 1)
|
|
||||||
->whereIn('accounts.id', $ids)
|
|
||||||
->where('user_id', Auth::user()->id)
|
|
||||||
->get(['accounts.*']);
|
|
||||||
if ($object->count() > 0) {
|
|
||||||
return $object;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new NotFoundHttpException;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
// budget list
|
// budget list
|
||||||
Route::bind(
|
Route::bind(
|
||||||
'budgetList',
|
'budgetList',
|
||||||
@ -98,44 +61,6 @@ Route::bind(
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
// Date
|
|
||||||
Route::bind(
|
|
||||||
'start_date',
|
|
||||||
function ($value) {
|
|
||||||
if (Auth::check()) {
|
|
||||||
|
|
||||||
try {
|
|
||||||
$date = new Carbon($value);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
Log::error('Could not parse date "' . $value . '" for user #' . Auth::user()->id);
|
|
||||||
throw new NotFoundHttpException;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $date;
|
|
||||||
}
|
|
||||||
throw new NotFoundHttpException;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
// Date
|
|
||||||
Route::bind(
|
|
||||||
'end_date',
|
|
||||||
function ($value) {
|
|
||||||
if (Auth::check()) {
|
|
||||||
|
|
||||||
try {
|
|
||||||
$date = new Carbon($value);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
Log::error('Could not parse date "' . $value . '" for user #' . Auth::user()->id);
|
|
||||||
throw new NotFoundHttpException;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $date;
|
|
||||||
}
|
|
||||||
throw new NotFoundHttpException;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
Route::bind(
|
Route::bind(
|
||||||
'tj', function ($value) {
|
'tj', function ($value) {
|
||||||
if (Auth::check()) {
|
if (Auth::check()) {
|
||||||
|
@ -1,41 +1,39 @@
|
|||||||
<?php namespace FireflyIII\Models;
|
<?php namespace FireflyIII\Models;
|
||||||
|
|
||||||
use Carbon\Carbon;
|
use Auth;
|
||||||
use Crypt;
|
use Crypt;
|
||||||
use FireflyIII\User;
|
|
||||||
use Illuminate\Database\Eloquent\Builder as EloquentBuilder;
|
use Illuminate\Database\Eloquent\Builder as EloquentBuilder;
|
||||||
use Illuminate\Database\Eloquent\Collection;
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||||
use Illuminate\Database\Query\Builder;
|
|
||||||
use Illuminate\Database\Query\JoinClause;
|
use Illuminate\Database\Query\JoinClause;
|
||||||
|
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||||
use Watson\Validating\ValidatingTrait;
|
use Watson\Validating\ValidatingTrait;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* FireflyIII\Models\Account
|
* FireflyIII\Models\Account
|
||||||
*
|
*
|
||||||
* @property integer $id
|
* @property integer $id
|
||||||
* @property \Carbon\Carbon $created_at
|
* @property \Carbon\Carbon $created_at
|
||||||
* @property \Carbon\Carbon $updated_at
|
* @property \Carbon\Carbon $updated_at
|
||||||
* @property \Carbon\Carbon $deleted_at
|
* @property \Carbon\Carbon $deleted_at
|
||||||
* @property integer $user_id
|
* @property integer $user_id
|
||||||
* @property integer $account_type_id
|
* @property integer $account_type_id
|
||||||
* @property string $name
|
* @property string $name
|
||||||
* @property boolean $active
|
* @property boolean $active
|
||||||
* @property boolean $encrypted
|
* @property boolean $encrypted
|
||||||
* @property float $virtual_balance
|
* @property float $virtual_balance
|
||||||
* @property string $iban
|
* @property string $iban
|
||||||
* @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\AccountMeta[] $accountMeta
|
* @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\AccountMeta[] $accountMeta
|
||||||
* @property-read \FireflyIII\Models\AccountType $accountType
|
* @property-read \FireflyIII\Models\AccountType $accountType
|
||||||
* @property-read mixed $name_for_editform
|
* @property-read mixed $name_for_editform
|
||||||
* @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\PiggyBank[] $piggyBanks
|
* @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\PiggyBank[] $piggyBanks
|
||||||
* @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Transaction[] $transactions
|
* @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Transaction[] $transactions
|
||||||
* @property-read \FireflyIII\User $user
|
* @property-read \FireflyIII\User $user
|
||||||
* @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Account accountTypeIn($types)
|
* @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Account accountTypeIn($types)
|
||||||
* @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Account hasMetaValue($name, $value)
|
* @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Account hasMetaValue($name, $value)
|
||||||
* @property string $startBalance
|
* @property string $startBalance
|
||||||
* @property string $endBalance
|
* @property string $endBalance
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
class Account extends Model
|
class Account extends Model
|
||||||
@ -296,4 +294,14 @@ class Account extends Model
|
|||||||
return $this->belongsTo('FireflyIII\User');
|
return $this->belongsTo('FireflyIII\User');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function routeBinder(Account $value)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (Auth::check()) {
|
||||||
|
if ($value->user_id == Auth::user()->id) {
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new NotFoundHttpException;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
50
app/Support/Binder/AccountList.php
Normal file
50
app/Support/Binder/AccountList.php
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* AccountList.php
|
||||||
|
* Copyright (C) 2016 Sander Dorigo
|
||||||
|
*
|
||||||
|
* This software may be modified and distributed under the terms
|
||||||
|
* of the MIT license. See the LICENSE file for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
namespace FireflyIII\Support\Binder;
|
||||||
|
|
||||||
|
|
||||||
|
use Auth;
|
||||||
|
use FireflyIII\Models\Account;
|
||||||
|
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class AccountList
|
||||||
|
*
|
||||||
|
* @package FireflyIII\Support\Binder
|
||||||
|
*/
|
||||||
|
class AccountList implements BinderInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $value
|
||||||
|
* @param $route
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public static function routeBinder($value, $route)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (Auth::check()) {
|
||||||
|
|
||||||
|
$ids = explode(',', $value);
|
||||||
|
/** @var \Illuminate\Support\Collection $object */
|
||||||
|
$object = Account::leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id')
|
||||||
|
->where('account_types.editable', 1)
|
||||||
|
->whereIn('accounts.id', $ids)
|
||||||
|
->where('user_id', Auth::user()->id)
|
||||||
|
->get(['accounts.*']);
|
||||||
|
if ($object->count() > 0) {
|
||||||
|
return $object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new NotFoundHttpException;
|
||||||
|
}
|
||||||
|
}
|
27
app/Support/Binder/BinderInterface.php
Normal file
27
app/Support/Binder/BinderInterface.php
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* BinderInterface.php
|
||||||
|
* Copyright (C) 2016 Sander Dorigo
|
||||||
|
*
|
||||||
|
* This software may be modified and distributed under the terms
|
||||||
|
* of the MIT license. See the LICENSE file for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace FireflyIII\Support\Binder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface BinderInterface
|
||||||
|
*
|
||||||
|
* @package FireflyIII\Support\Binder
|
||||||
|
*/
|
||||||
|
interface BinderInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param $value
|
||||||
|
* @param $route
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public static function routeBinder($value, $route);
|
||||||
|
|
||||||
|
}
|
43
app/Support/Binder/Date.php
Normal file
43
app/Support/Binder/Date.php
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Date.php
|
||||||
|
* Copyright (C) 2016 Sander Dorigo
|
||||||
|
*
|
||||||
|
* This software may be modified and distributed under the terms
|
||||||
|
* of the MIT license. See the LICENSE file for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace FireflyIII\Support\Binder;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use Exception;
|
||||||
|
use Log;
|
||||||
|
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Date
|
||||||
|
*
|
||||||
|
* @package FireflyIII\Support\Binder
|
||||||
|
*/
|
||||||
|
class Date implements BinderInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $value
|
||||||
|
* @param $route
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public static function routeBinder($value, $route)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$date = new Carbon($value);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
Log::error('Could not parse date "' . $value . '" for user #' . Auth::user()->id);
|
||||||
|
throw new NotFoundHttpException;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $date;
|
||||||
|
}
|
||||||
|
}
|
32
app/Support/Domain.php
Normal file
32
app/Support/Domain.php
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Domain.php
|
||||||
|
* Copyright (C) 2016 Sander Dorigo
|
||||||
|
*
|
||||||
|
* This software may be modified and distributed under the terms
|
||||||
|
* of the MIT license. See the LICENSE file for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace FireflyIII\Support;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Domain
|
||||||
|
*
|
||||||
|
* @package FireflyIII\Support
|
||||||
|
*/
|
||||||
|
class Domain
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function getBindables()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'account' => 'FireflyIII\Models\Account',
|
||||||
|
'accountList' => 'FireflyIII\Support\Binder\AccountList',
|
||||||
|
'start_date' => 'FireflyIII\Support\Binder\Date',
|
||||||
|
'end_date' => 'FireflyIII\Support\Binder\Date',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user