conn = $conn; $this->table = $table; $this->hasher = $hasher; } /** * Retrieve a user by their unique identifier. * * @param mixed $identifier * * @return \Illuminate\Contracts\Auth\Authenticatable|null */ public function retrieveById($identifier) { $this->setDefaultDatabase($identifier); $user = $this->conn->table($this->table)->find($identifier); return $this->getGenericUser($user); } /** * Retrieve a user by their unique identifier and "remember me" token. * * @param mixed $identifier * @param string $token * * @return \Illuminate\Contracts\Auth\Authenticatable|null */ public function retrieveByToken($identifier, $token) { $this->setDefaultDatabase($identifier, false, $token); $user = $this->conn->table($this->table) ->where('id', $identifier) ->where('remember_token', $token) ->first(); return $this->getGenericUser($user); } /** * Update the "remember me" token for the given user in storage. * * @param \Illuminate\Contracts\Auth\Authenticatable $user * @param string $token * * @return void */ public function updateRememberToken(UserContract $user, $token) { $this->conn->table($this->table) ->where('id', $user->getAuthIdentifier()) ->update(['remember_token' => $token]); } /** * Retrieve a user by the given credentials. * * @param array $credentials * * @return \Illuminate\Contracts\Auth\Authenticatable|null */ public function retrieveByCredentials(array $credentials) { /* * We use the email address to determine which serveer to link up. */ foreach ($credentials as $key => $value) { if (Str::contains($key, 'email')) { $this->setDefaultDatabase(false, $value, false); } } /** * | Build query. */ $query = $this->conn->table($this->table); foreach ($credentials as $key => $value) { if (!Str::contains($key, 'password')) { $query->where($key, $value); } } // Now we are ready to execute the query to see if we have an user matching // the given credentials. If not, we will just return nulls and indicate // that there are no matching users for these given credential arrays. $user = $query->first(); return $this->getGenericUser($user); } /** * Get the generic user. * * @param mixed $user * * @return \Illuminate\Auth\GenericUser|null */ protected function getGenericUser($user) { if (!is_null($user)) { return new GenericUser((array) $user); } } /** * Validate a user against the given credentials. * * @param \Illuminate\Contracts\Auth\Authenticatable $user * @param array $credentials * * @return bool */ public function validateCredentials(UserContract $user, array $credentials) { return $this->hasher->check( $credentials['password'], $user->getAuthPassword() ); } /** * @param (int) $id * @param string $username * @param string $token * * @return void */ private function setDefaultDatabase($id = false, $username = false, $token = false) : void { $databases = ['db-ninja-1', 'db-ninja-2']; foreach ($databases as $database) { $this->setDB($database); $query = $this->conn->table('users'); if ($id) { $query->where('id', '=', $id); } if ($token) { $query->where('token', '=', $token); } if ($username) { $query->where('email', '=', $username); } $user = $query->get(); // Log::error(print_r($user,1)); // Log::error($database); if (count($user) >= 1) { break; } } } private function setDB($database) { /** Get the database name we want to switch to*/ $db_name = config('database.connections.'.$database.'.database'); //$db_host = config("database.connections.".$database.".db_host"); /* This will set the default configuration for the request / session?*/ config(['database.default' => $database]); /* Set the connection to complete the user authentication */ //$this->conn = app('db')->connection(config("database.connections.database." . $database . "." . $db_name)); $this->conn = app('db')->connection(config('database.connections.database.'.$database)); } }