void split_string(::utility::string_t& source, const ::utility::string_t& delim, std::list<::utility::string_t>& ret) { ret.clear(); if (delim.empty() || source.empty()) { ret.push_back(source); return ; } size_t last = 0; size_t index = source.find(delim, last); while (index!=std::string::npos) { ret.push_back(source.substr(last, index - last)); last = index + delim.size(); index = source.find(delim, last); } if(index - last > 0) { ret.push_back(source.substr(last, index - last)); } }
// NOTE: This test also covers token_from_verifier(). TEST_FIXTURE(oauth1_server_setup, oauth1_token_from_redirected_uri) { m_server.server()->next_request().then([](test_request *request) { const utility::string_t header_authorization(request->m_headers[header_names::authorization]); // Verify temporary token prefix. const utility::string_t prefix(U("OAuth oauth_version=\"1.0\", oauth_consumer_key=\"test_key\", oauth_token=\"xyzzy\", oauth_signature_method=\"HMAC-SHA1\", oauth_timestamp=\"")); VERIFY_ARE_EQUAL(0, header_authorization.find(prefix)); // Verify suffix with 'oauth_verifier'. const utility::string_t suffix(U(", oauth_verifier=\"simsalabim\"")); VERIFY_IS_TRUE(std::equal(suffix.rbegin(), suffix.rend(), header_authorization.rbegin())); // Verify we have 'oauth_nonce' and 'oauth_signature'. VERIFY_ARE_NOT_EQUAL(utility::string_t::npos, header_authorization.find(U("oauth_nonce"))); VERIFY_ARE_NOT_EQUAL(utility::string_t::npos, header_authorization.find(U("oauth_signature"))); // Reply with access token and secret. std::map<utility::string_t, utility::string_t> headers; headers[header_names::content_type] = mime_types::application_x_www_form_urlencoded; request->reply(status_codes::OK, U(""), headers, "oauth_token=test&oauth_token_secret=bar"); }); m_oauth1_config.set_token(oauth1_token(U("xyzzy"), U(""))); // Simulate temporary token. const web::http::uri redirected_uri(U("http://localhost:17778/?oauth_token=xyzzy&oauth_verifier=simsalabim")); m_oauth1_config.token_from_redirected_uri(redirected_uri).wait(); VERIFY_IS_TRUE(m_oauth1_config.token().is_valid_access_token()); VERIFY_ARE_EQUAL(m_oauth1_config.token().access_token(), U("test")); VERIFY_ARE_EQUAL(m_oauth1_config.token().secret(), U("bar")); }
TEST_FIXTURE(oauth1_server_setup, oauth1_build_authorization_uri) { m_server.server()->next_request().then([](test_request *request) { const utility::string_t header_authorization(request->m_headers[header_names::authorization]); // Verify prefix, and without 'oauth_token'. const utility::string_t prefix(U("OAuth oauth_version=\"1.0\", oauth_consumer_key=\"test_key\", oauth_signature_method=\"HMAC-SHA1\", oauth_timestamp=\"")); VERIFY_ARE_EQUAL(0, header_authorization.find(prefix)); // Verify suffix with proper 'oauth_callback'. const utility::string_t suffix(U(", oauth_callback=\"http%3A%2F%2Flocalhost%3A17778%2F\"")); VERIFY_IS_TRUE(std::equal(suffix.rbegin(), suffix.rend(), header_authorization.rbegin())); // Reply with temporary token and secret. std::map<utility::string_t, utility::string_t> headers; headers[header_names::content_type] = mime_types::application_x_www_form_urlencoded; request->reply(status_codes::OK, U(""), headers, "oauth_token=testbar&oauth_token_secret=xyzzy&oauth_callback_confirmed=true"); }); VERIFY_IS_FALSE(m_oauth1_config.token().is_valid_access_token()); utility::string_t auth_uri = m_oauth1_config.build_authorization_uri().get(); VERIFY_ARE_EQUAL(auth_uri, U("http://localhost:17778/?oauth_token=testbar")); VERIFY_IS_FALSE(m_oauth1_config.token().is_valid_access_token()); }
TEST_FIXTURE(oauth1_server_setup, oauth1_plaintext_request) { m_oauth1_config.set_token(m_test_token); m_oauth1_config.set_method(oauth1_methods::plaintext); http_client_config client_config; client_config.set_oauth1(m_oauth1_config); http_client client(m_server_uri, client_config); m_server.server()->next_request().then([](test_request *request) { const utility::string_t header_authorization(request->m_headers[header_names::authorization]); const utility::string_t prefix(U("OAuth oauth_version=\"1.0\", oauth_consumer_key=\"test_key\", oauth_token=\"test_token\", oauth_signature_method=\"PLAINTEXT\", oauth_timestamp=\"")); VERIFY_ARE_EQUAL(0, header_authorization.find(prefix)); request->reply(status_codes::OK); }); VERIFY_IS_TRUE(m_oauth1_config.token().is_valid_access_token()); http_response response = client.request(methods::GET).get(); VERIFY_ARE_EQUAL(status_codes::OK, response.status_code()); }