/*
* Copyright 2007 Yusuke Yamamoto
*
* 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 twitter4j.auth;
import twitter4j.TwitterException;
import twitter4j.internal.http.HttpResponse;
import twitter4j.internal.util.z_T4JInternalStringUtil;
import javax.crypto.spec.SecretKeySpec;
abstract class OAuthToken implements java.io.Serializable {
private static final long serialVersionUID = 3891133932519746686L;
private String token;
private String tokenSecret;
private transient SecretKeySpec secretKeySpec;
String[] responseStr = null;
public OAuthToken(String token, String tokenSecret) {
this.token = token;
this.tokenSecret = tokenSecret;
}
OAuthToken(HttpResponse response) throws TwitterException {
this(response.asString());
}
OAuthToken(String string) {
responseStr = z_T4JInternalStringUtil.split(string, "&");
tokenSecret = getParameter("oauth_token_secret");
token = getParameter("oauth_token");
}
public String getToken() {
return token;
}
public String getTokenSecret() {
return tokenSecret;
}
/*package*/ void setSecretKeySpec(SecretKeySpec secretKeySpec) {
this.secretKeySpec = secretKeySpec;
}
/*package*/ SecretKeySpec getSecretKeySpec() {
return secretKeySpec;
}
public String getParameter(String parameter) {
String value = null;
for (String str : responseStr) {
if (str.startsWith(parameter + '=')) {
value = z_T4JInternalStringUtil.split(str, "=")[1].trim();
break;
}
}
return value;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof OAuthToken)) return false;
OAuthToken that = (OAuthToken) o;
if (!token.equals(that.token)) return false;
if (!tokenSecret.equals(that.tokenSecret)) return false;
return true;
}
@Override
public int hashCode() {
int result = token.hashCode();
result = 31 * result + tokenSecret.hashCode();
return result;
}
@Override
public String toString() {
return "OAuthToken{" +
"token='" + token + '\'' +
", tokenSecret='" + tokenSecret + '\'' +
", secretKeySpec=" + secretKeySpec +
'}';
}
}