/** * @param string $saml_request * * @return null * * @since 1.1.0 */ private function handle_saml_request($saml_request) { $this->saml_request_service->load_saml_request($saml_request); if (!$this->saml_request_service->is_timestamp_within_restrictions($this->wp_facade->time())) { $this->wp_facade->wp_die('Invalid Request', 400); } elseif (!$this->saml_request_service->is_valid_destination($this->wp_facade->wp_login_url())) { $this->wp_facade->wp_die('Invalid Request', 400); } elseif (!($user = $this->wp_facade->get_user_by('login', $this->saml_request_service->get_name()))) { $this->wp_facade->wp_die('Invalid Request', 400); } elseif ($this->saml_request_service->get_session_index() != $user->get("launchkey_sso_session")) { $this->wp_facade->wp_die('Invalid Request', 400); } else { $this->wp_facade->update_user_meta($user->ID, 'launchkey_authorized', 'false'); } }
/** * @dataProvider data_provider_valid_destination * * @param string $destination * @param bool $expected */ public function test_is_valid_destination($destination, $expected) { $actual = $this->service->is_valid_destination($destination); $this->assertSame($expected, $actual); }