mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 21:16:47 +00:00 
			
		
		
		
	Unknown user warning.
This commit is contained in:
		| @@ -25,9 +25,12 @@ namespace FireflyIII\Http\Controllers\Auth; | ||||
| 
 | ||||
| use Cookie; | ||||
| use FireflyIII\Events\ActuallyLoggedIn; | ||||
| use FireflyIII\Events\Security\UnknownUserAttemptedLogin; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| use FireflyIII\Notifications\Notifiables\OwnerNotifiable; | ||||
| use FireflyIII\Providers\RouteServiceProvider; | ||||
| use FireflyIII\Repositories\User\UserRepositoryInterface; | ||||
| use Illuminate\Contracts\Foundation\Application; | ||||
| use Illuminate\Contracts\View\Factory; | ||||
| use Illuminate\Contracts\View\View; | ||||
| @@ -57,6 +60,7 @@ class LoginController extends Controller | ||||
|      * Where to redirect users after login. | ||||
|      */ | ||||
|     protected string $redirectTo = RouteServiceProvider::HOME; | ||||
|     private UserRepositoryInterface $repository; | ||||
| 
 | ||||
|     private string $username; | ||||
| 
 | ||||
| @@ -68,6 +72,7 @@ class LoginController extends Controller | ||||
|         parent::__construct(); | ||||
|         $this->username = 'email'; | ||||
|         $this->middleware('guest')->except('logout'); | ||||
|         $this->repository = app(UserRepositoryInterface::class); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @@ -122,6 +127,11 @@ class LoginController extends Controller | ||||
|             return $this->sendLoginResponse($request); | ||||
|         } | ||||
|         app('log')->warning('Login attempt failed.'); | ||||
|         $username = (string) $request->get($this->username()); | ||||
|         if(null === $this->repository->findByEmail($username)) { | ||||
|             // send event to owner.
 | ||||
|             event(new UnknownUserAttemptedLogin($username)); | ||||
|         } | ||||
| 
 | ||||
|         // Copied directly from AuthenticatesUsers, but with logging added:
 | ||||
|         // If the login attempt was unsuccessful we will increment the number of attempts
 | ||||
|   | ||||
| @@ -25,7 +25,6 @@ namespace FireflyIII\Http\Controllers; | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use Carbon\Exceptions\InvalidFormatException; | ||||
| use FireflyIII\Events\NewVersionAvailable; | ||||
| use FireflyIII\Events\RequestedVersionCheckStatus; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Helpers\Collector\GroupCollectorInterface; | ||||
| @@ -63,8 +62,8 @@ class HomeController extends Controller | ||||
|      */ | ||||
|     public function dateRange(Request $request): JsonResponse | ||||
|     { | ||||
|         $stringStart   = ''; | ||||
|         $stringEnd     = ''; | ||||
|         $stringStart = ''; | ||||
|         $stringEnd   = ''; | ||||
| 
 | ||||
|         try { | ||||
|             $stringStart = e((string) $request->get('start')); | ||||
| @@ -99,7 +98,7 @@ class HomeController extends Controller | ||||
|             app('log')->debug('Range is now marked as "custom".'); | ||||
|         } | ||||
| 
 | ||||
|         $diff          = $start->diffInDays($end, true) + 1; | ||||
|         $diff = $start->diffInDays($end, true) + 1; | ||||
| 
 | ||||
|         if ($diff > 366) { | ||||
|             $request->session()->flash('warning', (string) trans('firefly.warning_much_data', ['days' => (int) $diff])); | ||||
| @@ -154,13 +153,13 @@ class HomeController extends Controller | ||||
|         } | ||||
| 
 | ||||
|         /** @var Carbon $start */ | ||||
|         $start          = session('start', today(config('app.timezone'))->startOfMonth()); | ||||
|         $start = session('start', today(config('app.timezone'))->startOfMonth()); | ||||
| 
 | ||||
|         /** @var Carbon $end */ | ||||
|         $end            = session('end', today(config('app.timezone'))->endOfMonth()); | ||||
|         $accounts       = $repository->getAccountsById($frontpageArray); | ||||
|         $today          = today(config('app.timezone')); | ||||
|         $accounts       = $accounts->sortBy('order'); // sort frontpage accounts by order
 | ||||
|         $end      = session('end', today(config('app.timezone'))->endOfMonth()); | ||||
|         $accounts = $repository->getAccountsById($frontpageArray); | ||||
|         $today    = today(config('app.timezone')); | ||||
|         $accounts = $accounts->sortBy('order'); // sort frontpage accounts by order
 | ||||
| 
 | ||||
|         app('log')->debug('Frontpage accounts are ', $frontpageArray); | ||||
| 
 | ||||
| @@ -170,14 +169,14 @@ class HomeController extends Controller | ||||
|         // collect groups for each transaction.
 | ||||
|         foreach ($accounts as $account) { | ||||
|             /** @var GroupCollectorInterface $collector */ | ||||
|             $collector      = app(GroupCollectorInterface::class); | ||||
|             $collector = app(GroupCollectorInterface::class); | ||||
|             $collector->setAccounts(new Collection([$account]))->withAccountInformation()->setRange($start, $end)->setLimit(10)->setPage(1); | ||||
|             $set            = $collector->getExtractedJournals(); | ||||
|             $transactions[] = ['transactions' => $set, 'account' => $account]; | ||||
|         } | ||||
| 
 | ||||
|         /** @var User $user */ | ||||
|         $user           = auth()->user(); | ||||
|         $user = auth()->user(); | ||||
|         event(new RequestedVersionCheckStatus($user)); | ||||
| 
 | ||||
|         return view('index', compact('count', 'subTitle', 'transactions', 'billCount', 'start', 'end', 'today', 'pageTitle')); | ||||
| @@ -188,11 +187,11 @@ class HomeController extends Controller | ||||
|         $subTitle  = (string) trans('firefly.welcome_back'); | ||||
|         $pageTitle = (string) trans('firefly.main_dashboard_page_title'); | ||||
| 
 | ||||
|         $start     = session('start', today(config('app.timezone'))->startOfMonth()); | ||||
|         $end       = session('end', today(config('app.timezone'))->endOfMonth()); | ||||
|         $start = session('start', today(config('app.timezone'))->startOfMonth()); | ||||
|         $end   = session('end', today(config('app.timezone'))->endOfMonth()); | ||||
| 
 | ||||
|         /** @var User $user */ | ||||
|         $user      = auth()->user(); | ||||
|         $user = auth()->user(); | ||||
|         event(new RequestedVersionCheckStatus($user)); | ||||
| 
 | ||||
|         return view('index', compact('subTitle', 'start', 'end', 'pageTitle')); | ||||
|   | ||||
| @@ -111,9 +111,10 @@ class PreferencesController extends Controller | ||||
| 
 | ||||
|         // notification preferences (single value for each):
 | ||||
|         $notifications         = []; | ||||
|         die('fix the reference to the available notifications.'); | ||||
|         foreach (config('firefly.available_notifications') as $notification) { | ||||
|             $notifications[$notification] = app('preferences')->get(sprintf('notification_%s', $notification), true)->data; | ||||
|         foreach (config('notifications.notifications.user') as $key => $info) { | ||||
|             if($info['enabled']) { | ||||
|                 $notifications[$key] = app('preferences')->get(sprintf('notification_%s', $key), true)->data; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         ksort($languages); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user