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 $user = Auth::user(); $this->accountRepo->createTokens($user, $request->token_name); $users = $this->accountRepo->findUsers($user, 'account.account_tokens'); $data = $this->createCollection($users, new UserAccountTransformer($user->account, $request->token_name)); $response = [ 'user_accounts' => $data ]; return $this->response($response); } public function show() { $account = Auth::user()->account; $account->loadAllData(); $account = $this->createItem($account, new AccountTransformer); $response = [ 'account' => $account ]; return $this->response($response); } public function getStaticData() { $data = []; $cachedTables = unserialize(CACHED_TABLES); foreach ($cachedTables as $name => $class) { $data[$name] = Cache::get($name); } return $this->response($data); } }