accountRepo = $accountRepo; } public function login(Request $request) { if ( ! env(API_SECRET) || $request->api_secret !== env(API_SECRET)) { sleep(ERROR_DELAY); return 'Invalid secret'; } if (Auth::attempt(['email' => $request->email, 'password' => $request->password])) { return $this->processLogin($request); } else { sleep(ERROR_DELAY); return 'Invalid credentials'; } } private function processLogin(Request $request) { // Create a new token only if one does not already exist $this->accountRepo->createTokens(Auth::user(), $request->token_name); $users = $this->accountRepo->findUsers(Auth::user(), 'account.account_tokens'); $resource = new Collection($users, new UserAccountTransformer($request->token_name)); return $this->returnData($resource, 'user_accounts'); } public function show($accountKey) { $account = $this->accountRepo->findByKey($accountKey); $resource = new Item($account, new AccountTransformer); return $this->returnData($resource); } }