2016-03-12 07:18:28 -06:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* UserRepository.php
|
2016-04-01 09:44:46 -05:00
|
|
|
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
2016-03-12 07:18:28 -06:00
|
|
|
*
|
2016-10-04 23:52:15 -05:00
|
|
|
* 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.
|
2016-03-12 07:18:28 -06:00
|
|
|
*/
|
|
|
|
|
2016-05-20 05:41:23 -05:00
|
|
|
declare(strict_types = 1);
|
|
|
|
|
2016-03-12 07:18:28 -06:00
|
|
|
namespace FireflyIII\Repositories\User;
|
|
|
|
|
|
|
|
|
2016-11-07 11:49:35 -06:00
|
|
|
use FireflyConfig;
|
2016-10-15 00:11:53 -05:00
|
|
|
use FireflyIII\Models\BudgetLimit;
|
2016-03-12 07:18:28 -06:00
|
|
|
use FireflyIII\Models\Role;
|
|
|
|
use FireflyIII\User;
|
2016-04-03 00:07:17 -05:00
|
|
|
use Illuminate\Support\Collection;
|
2016-10-15 00:11:53 -05:00
|
|
|
use Preferences;
|
2016-03-12 07:18:28 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class UserRepository
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Repositories\User
|
|
|
|
*/
|
|
|
|
class UserRepository implements UserRepositoryInterface
|
|
|
|
{
|
|
|
|
|
2016-04-03 00:07:17 -05:00
|
|
|
/**
|
|
|
|
* @return Collection
|
|
|
|
*/
|
|
|
|
public function all(): Collection
|
|
|
|
{
|
|
|
|
return User::orderBy('id', 'DESC')->get(['users.*']);
|
|
|
|
}
|
|
|
|
|
2016-03-12 07:18:28 -06:00
|
|
|
/**
|
|
|
|
* @param User $user
|
|
|
|
* @param string $role
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function attachRole(User $user, string $role): bool
|
|
|
|
{
|
|
|
|
$admin = Role::where('name', 'owner')->first();
|
|
|
|
$user->attachRole($admin);
|
2016-03-28 12:50:24 -05:00
|
|
|
$user->save();
|
2016-03-12 07:18:28 -06:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function count(): int
|
|
|
|
{
|
2016-04-26 01:09:10 -05:00
|
|
|
return $this->all()->count();
|
2016-03-12 07:18:28 -06:00
|
|
|
}
|
2016-10-15 00:11:53 -05:00
|
|
|
|
2016-10-20 12:10:43 -05:00
|
|
|
/**
|
|
|
|
* @param int $userId
|
|
|
|
*
|
|
|
|
* @return User
|
|
|
|
*/
|
|
|
|
public function find(int $userId): User
|
|
|
|
{
|
|
|
|
$user = User::find($userId);
|
|
|
|
if (!is_null($user)) {
|
|
|
|
return $user;
|
|
|
|
}
|
|
|
|
|
|
|
|
return new User;
|
|
|
|
}
|
|
|
|
|
2016-10-15 00:11:53 -05:00
|
|
|
/**
|
|
|
|
* Return basic user information.
|
|
|
|
*
|
|
|
|
* @param User $user
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getUserData(User $user): array
|
|
|
|
{
|
|
|
|
$return = [];
|
|
|
|
|
|
|
|
// two factor:
|
|
|
|
$is2faEnabled = Preferences::getForUser($user, 'twoFactorAuthEnabled', false)->data;
|
|
|
|
$has2faSecret = !is_null(Preferences::getForUser($user, 'twoFactorAuthSecret'));
|
|
|
|
$return['has_2fa'] = false;
|
|
|
|
if ($is2faEnabled && $has2faSecret) {
|
|
|
|
$return['has_2fa'] = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// is user activated?
|
2016-11-07 11:49:35 -06:00
|
|
|
$mustConfirmAccount = FireflyConfig::get('must_confirm_account', config('firefly.configuration.must_confirm_account'))->data;
|
2016-10-15 00:11:53 -05:00
|
|
|
$isConfirmed = Preferences::getForUser($user, 'user_confirmed', false)->data;
|
|
|
|
$return['is_activated'] = true;
|
2016-11-07 11:49:35 -06:00
|
|
|
if ($isConfirmed === false && $mustConfirmAccount === true) {
|
2016-10-15 00:11:53 -05:00
|
|
|
$return['is_activated'] = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$return['is_admin'] = $user->hasRole('owner');
|
|
|
|
$return['blocked'] = intval($user->blocked) === 1;
|
|
|
|
$return['blocked_code'] = $user->blocked_code;
|
|
|
|
$return['accounts'] = $user->accounts()->count();
|
|
|
|
$return['journals'] = $user->transactionJournals()->count();
|
|
|
|
$return['transactions'] = $user->transactions()->count();
|
|
|
|
$return['attachments'] = $user->attachments()->count();
|
|
|
|
$return['attachments_size'] = $user->attachments()->sum('size');
|
|
|
|
$return['bills'] = $user->bills()->count();
|
|
|
|
$return['categories'] = $user->categories()->count();
|
|
|
|
$return['budgets'] = $user->budgets()->count();
|
2016-11-28 13:38:03 -06:00
|
|
|
$return['budgets_with_limits'] = BudgetLimit::distinct()
|
2016-12-04 11:02:19 -06:00
|
|
|
->leftJoin('budgets', 'budgets.id', '=', 'budget_limits.budget_id')
|
|
|
|
->where('amount', '>', 0)
|
|
|
|
->whereNull('budgets.deleted_at')
|
|
|
|
->where('budgets.user_id', $user->id)->get(['budget_limits.budget_id'])->count();
|
2016-10-15 00:11:53 -05:00
|
|
|
$return['export_jobs'] = $user->exportJobs()->count();
|
|
|
|
$return['export_jobs_success'] = $user->exportJobs()->where('status', 'export_downloaded')->count();
|
|
|
|
$return['import_jobs'] = $user->exportJobs()->count();
|
|
|
|
$return['import_jobs_success'] = $user->exportJobs()->where('status', 'import_complete')->count();
|
|
|
|
$return['rule_groups'] = $user->ruleGroups()->count();
|
|
|
|
$return['rules'] = $user->rules()->count();
|
|
|
|
$return['tags'] = $user->tags()->count();
|
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
2016-03-14 14:38:23 -05:00
|
|
|
}
|