public function postLogin(Request $request) { $this->validate($request, ['user_id' => 'required', 'password' => 'required']); $credentials = $request->only('user_id', 'password'); $redirect = $this->redirectPath(); $lock_new_users = true; $try = false; if (User::find($credentials['user_id'])) { // The user exists $try = true; } else { if ($lock_new_users) { return redirect('/locked'); } else { if (($person = Person::find($credentials['user_id'])) && DataSource::check_login($credentials['user_id'], $credentials['password'])) { // The ID exists and details are correct, but there isn't an account for it. Make one. $user = User::create(['user_id' => $credentials['user_id'], 'name' => $person->name, 'password' => \Crypt::encrypt($credentials['password']), 'is_queued' => true]); \Queue::push(new PrepareUser($user)); $redirect = '/setup'; $try = true; } } } if ($try && Auth::attempt($credentials, $request->has('remember'))) { return redirect()->intended($redirect); } return redirect($this->loginPath())->withInput($request->only('user_id', 'remember'))->withErrors(['user_id' => $this->getFailedLoginMessage()]); }
public static function update($user) { if (!$user->can_fetch()) { return []; } $keys = []; $matches = []; for ($i = 1; $i <= 4; $i++) { // if ($i == 2){ // echo self::keystone_post(self::SPORTSZONE_URL, $keys, $user); // exit;} var_dump($i); $html = new \Htmldom(); $html->load(self::keystone_post(self::SPORTSZONE_URL, $keys, $user)); $keys = static::keys($html); $id_matches = []; preg_match_all("/p_ID=(.+)}'\\);/", $html->find('img[alt="View Earlier Match"]')[0]->parent()->href, $id_matches); $id = $id_matches[1][0]; $team_name = $html->find('.ms-vb')[0]->find('b')[0]->innertext; $opponent_matches = []; preg_match_all("/<\\/a>(.+), playing/", $html->find('td[colspan="99"]')[0]->innertext, $opponent_matches); if (count($opponent_matches) > 0 && count($opponent_matches[1]) > 0) { $opponent_name = $opponent_matches[1][0]; } else { $opponent_name = ''; } $date_matches = []; preg_match_all("/<br>Week \\d+, Term \\d, (.+?)(?: - .+)?\$/", $html->find('.ms-vb')[0]->innertext, $date_matches); if (count($date_matches) > 0 && count($date_matches[1]) > 0) { $date = Carbon::createFromFormat('d/m/Y g:i A', $date_matches[1][0]); } else { continue; } $venue_matches = []; preg_match_all("/Venue Map -\\s+(.+)/", $html->find('table[cellpadding="2"]')[0]->find('th')[2]->innertext, $venue_matches); $venue = $venue_matches[1][0]; $location_matches = []; preg_match_all("/new google\\.maps\\.LatLng\\((-?\\d+.\\d+,-?\\d+.\\d+)\\);/", $html->find('table[cellpadding="2"]')[0]->find('script')[1]->innertext, $location_matches); $location = $location_matches[1][0]; $pre_comments = static::heading_body($html->find('table[cellpadding="2"]')[0], 'Pre-Game Comments'); $post_comments = static::heading_body($html->find('table[cellpadding="2"]')[1], 'Game Comments'); $team_list = Person::from_names(array_filter(explode('; ', static::heading_body($html->find('table[cellpadding="2"]')[0], 'Team List')))); $staff_list = Person::from_names(array_filter(explode('; ', static::heading_body($html->find('table[cellpadding="2"]')[1], 'Team Staff')))); $result = str_replace('<b>Result:</b> ', '', $html->find('table[cellpadding="2"]')[1]->find('td')[0]->innertext); $table = $html->find('table[width="350px"]'); $score_self = $table ? $table[0]->find('td')[0]->innertext : ''; $score_opponent = $table ? $table[0]->find('td')[2]->innertext : ''; if ($match = Match::find($id)) { $match->match_id = $id; $match->team_name = $team_name; $match->opponent_name = $opponent_name; $match->venue = $venue; $match->location = $location; $match->result = $result; $match->date = $date; $match->score_self = $score_self; $match->score_opponent = $score_opponent; $match->pre_comments = $pre_comments; $match->post_comments = $post_comments; $match->save(); } else { $match = Match::updateOrCreate(array('match_id' => $id, 'team_name' => $team_name, 'opponent_name' => $opponent_name, 'venue' => $venue, 'location' => $location, 'result' => $result, 'date' => $date, 'score_self' => $score_self, 'score_opponent' => $score_opponent, 'pre_comments' => $pre_comments, 'post_comments' => $post_comments)); } $attach = [$user->user_id => 0]; foreach ($team_list as $index => $person) { $attach[$person->person_id] = 1; } foreach ($staff_list as $index => $person) { if (!isset($attach[$person->person_id])) { $attach[$person->person_id] = 2; } else { $attach[$person->person_id] += 2; } } foreach ($attach as $user_id => $value) { if (!$match->members->contains($user_id)) { $match->members()->attach($user_id, ['is_team' => ($value & 1) == 1, 'is_staff' => ($value & 2) == 2]); } else { $match->members()->updateExistingPivot($user_id, ['is_team' => ($value & 1) == 1, 'is_staff' => ($value & 2) == 2]); } } $matches[] = $match; } }
public function person() { return Person::from_name($this->author); }