/*
* Copyright 2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.social.oauth1;
import static org.junit.Assert.*;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import org.junit.Test;
import org.springframework.http.HttpMethod;
import org.springframework.http.HttpRequest;
import org.springframework.http.MediaType;
import org.springframework.http.client.ClientHttpRequestExecution;
import org.springframework.http.client.ClientHttpResponse;
import org.springframework.http.server.ServletServerHttpRequest;
import org.springframework.mock.web.MockHttpServletRequest;
public class OAuth1RequestInterceptorTest {
@Test
public void beforeExecution() throws Exception {
OAuth1RequestInterceptor interceptor = new OAuth1RequestInterceptor(new OAuth1Credentials("consumer_key", "consumer_secret", "access_token", "token_secret"));
byte[] body = "status=Hello+there".getBytes();
MockHttpServletRequest request = new MockHttpServletRequest(HttpMethod.POST.name(), "/status/update");
request.setRemoteHost("api.someprovider.com");
request.setSecure(true);
request.setContentType(MediaType.APPLICATION_FORM_URLENCODED.toString());
ClientHttpRequestExecution execution = new ClientHttpRequestExecution() {
public ClientHttpResponse execute(HttpRequest request, byte[] body) throws IOException {
String authorizationHeader = request.getHeaders().getFirst("Authorization");
Map<String, String> headerParameters = extractHeaderParameters(authorizationHeader);
// TODO: Figure out how to test this more precisely with a fixed nonce and timestamp (and thus a fixed signature)
assertEquals("1.0", headerParameters.get("oauth_version"));
assertTrue(headerParameters.containsKey("oauth_nonce"));
assertEquals("HMAC-SHA1", headerParameters.get("oauth_signature_method"));
assertEquals("consumer_key", headerParameters.get("oauth_consumer_key"));
assertEquals("access_token", headerParameters.get("oauth_token"));
assertTrue(headerParameters.containsKey("oauth_timestamp"));
assertTrue(headerParameters.containsKey("oauth_signature"));
assertEquals(MediaType.APPLICATION_FORM_URLENCODED, request.getHeaders().getContentType());
return null;
}
};
interceptor.intercept(new ServletServerHttpRequest(request), body, execution);
}
private Map<String, String> extractHeaderParameters(String authorizationHeader) {
String[] keysAndValues = authorizationHeader.substring(6).split(",\\s");
Map<String, String> parameters = new HashMap<String, String>();
for (String keyAndValue : keysAndValues) {
String[] keyValuePair = keyAndValue.split("=");
String value = keyValuePair[1].substring(1, keyValuePair[1].length() - 1);
parameters.put(keyValuePair[0], value);
}
return parameters;
}
}