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'); $data = $this->createCollection($users, new UserAccountTransformer($request->token_name)); $response = [ 'user_accounts' => $data, 'default_url' => SITE_URL ]; return $this->response($response); } public function show() { $account = Auth::user()->account; $response = $this->createItem($account, new AccountTransformer); return $this->response($response); } }