com.aliyuncs.RpcAcsRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aliyun-java-sdk-core Show documentation
Show all versions of aliyun-java-sdk-core Show documentation
Aliyun Open API SDK for Java
Copyright (C) Alibaba Cloud Computing
All rights reserved.
版权所有 (C)阿里云计算有限公司
http://www.aliyun.com
package com.aliyuncs;
import com.aliyuncs.auth.*;
import com.aliyuncs.http.FormatType;
import com.aliyuncs.http.HttpRequest;
import com.aliyuncs.http.MethodType;
import com.aliyuncs.regions.ProductDomain;
import com.aliyuncs.utils.ParameterHelper;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.HashMap;
import java.util.Map;
import static com.aliyuncs.auth.AcsURLEncoder.hexEncode;
public abstract class RpcAcsRequest extends AcsRequest {
public RpcAcsRequest(String product) {
super(product);
initialize();
}
public RpcAcsRequest(String product, String version, String action) {
super(product);
this.setSysVersion(version);
this.setSysActionName(action);
initialize();
}
public RpcAcsRequest(String product, String version, String action, SignatureVersion signatureVersion) {
super(product);
this.setSysVersion(version);
this.setSysActionName(action);
this.setSysSignatureVersion(signatureVersion);
initialize();
}
public RpcAcsRequest(String product, String version, String action, String locationProduct) {
super(product);
this.setSysVersion(version);
this.setSysActionName(action);
this.setSysLocationProduct(locationProduct);
initialize();
}
public RpcAcsRequest(String product, String version, String action, String locationProduct, SignatureVersion signatureVersion) {
super(product);
this.setSysVersion(version);
this.setSysActionName(action);
this.setSysLocationProduct(locationProduct);
this.setSysSignatureVersion(signatureVersion);
initialize();
}
public RpcAcsRequest(String product, String version, String action, String locationProduct, String endpointType) {
super(product);
this.setSysVersion(version);
this.setSysActionName(action);
this.setSysLocationProduct(locationProduct);
this.setSysEndpointType(endpointType);
initialize();
}
public RpcAcsRequest(String product, String version, String action, String locationProduct, String endpointType, SignatureVersion signatureVersion) {
super(product);
this.setSysVersion(version);
this.setSysActionName(action);
this.setSysLocationProduct(locationProduct);
this.setSysEndpointType(endpointType);
this.setSysSignatureVersion(signatureVersion);
initialize();
}
private void initialize() {
this.setSysMethod(MethodType.GET);
this.setSysAcceptFormat(FormatType.JSON);
this.setHttpContentType(FormatType.FORM);
this.composer = RpcSignatureComposer.getComposer();
}
@Override
public void setActionName(String actionName) {
super.setActionName(actionName);
this.putQueryParameter("Action", actionName);
}
@Override
public void setVersion(String version) {
super.setVersion(version);
this.putQueryParameter("Version", version);
}
@Override
public void setSecurityToken(String securityToken) {
super.setSecurityToken(securityToken);
this.putQueryParameter("SecurityToken", securityToken);
}
@Override
public void setAcceptFormat(FormatType acceptFormat) {
super.setAcceptFormat(acceptFormat);
this.putQueryParameter("Format", acceptFormat.toString());
}
@Override
public void setSysActionName(String actionName) {
super.setSysActionName(actionName);
this.putQueryParameter("Action", actionName);
}
@Override
public void setSysVersion(String version) {
super.setSysVersion(version);
this.putQueryParameter("Version", version);
}
@Override
public void setSysAcceptFormat(FormatType acceptFormat) {
super.setSysAcceptFormat(acceptFormat);
this.putQueryParameter("Format", acceptFormat.toString());
}
@Override
public void setSysSecurityToken(String securityToken) {
super.setSysSecurityToken(securityToken);
this.putQueryParameter("SecurityToken", securityToken);
}
@Override
public String composeUrl(String endpoint, Map queries) throws UnsupportedEncodingException {
Map mapQueries = (queries == null) ? this.getSysQueryParameters() : queries;
StringBuilder urlBuilder = new StringBuilder();
urlBuilder.append(this.getSysProtocol().toString());
urlBuilder.append("://").append(endpoint);
if (-1 == urlBuilder.indexOf("?")) {
urlBuilder.append("/?");
}
String query = concatQueryString(mapQueries);
return urlBuilder.append(query).toString();
}
@Override
public HttpRequest signRequest(Signer signer, AlibabaCloudCredentials credentials, FormatType format,
ProductDomain domain) throws InvalidKeyException, IllegalStateException,
UnsupportedEncodingException, NoSuchAlgorithmException {
this.resolveSignatureComposer();
Map headerMap = new HashMap();
Map bodyParams = this.getSysBodyParameters();
String hashedRequestPayload = hexEncode(signer != null ? signer.hash("".getBytes("UTF-8")) : null);
if (bodyParams != null && !bodyParams.isEmpty()) {
byte[] data;
if (FormatType.JSON == this.getHttpContentType()) {
data = ParameterHelper.getJsonData(bodyParams);
} else if (FormatType.XML == this.getHttpContentType()) {
data = ParameterHelper.getXmlData(bodyParams);
} else {
// For contentType RAW and Form, the actual data format will be form
data = ParameterHelper.getFormData(bodyParams);
}
this.setHttpContent(data, "UTF-8", null);
hashedRequestPayload = hexEncode(signer != null ? signer.hash(data) : null);
}
Map imutableMap = this.composer.refreshSignParameters(this.getSysQueryParameters(), signer, null,
format);
headerMap.putAll(this.getSysHeaders());
headerMap = this.composer.refreshSignParameters(headerMap, signer, null, null);
if (imutableMap.get("RegionId") == null && this.getSysRegionId() != null && !this.getSysRegionId().isEmpty()) {
if ((bodyParams == null || bodyParams.get("RegionId") == null)) {
imutableMap.put("RegionId", getSysRegionId());
}
}
if (null != signer && null != credentials && !(credentials instanceof AnonymousCredentials)) {
String accessKeyId = credentials.getAccessKeyId();
String accessSecret = credentials.getAccessKeySecret();
if (credentials instanceof BasicSessionCredentials) {
String sessionToken = ((BasicSessionCredentials) credentials).getSessionToken();
if (null != sessionToken) {
imutableMap.put("SecurityToken", sessionToken);
headerMap.put("x-acs-security-token", sessionToken);
}
}
if (credentials instanceof BearerTokenCredentials) {
String bearerToken = ((BearerTokenCredentials) credentials).getBearerToken();
if (null != ((BearerTokenCredentials) credentials).getBearerToken()) {
imutableMap.put("BearerToken", bearerToken);
headerMap.put("x-acs-bearer-token", bearerToken);
}
}
if (signer.getContent() != null && hashedRequestPayload != null) {
headerMap.put(signer.getContent(), hashedRequestPayload);
}
imutableMap.put("AccessKeyId", accessKeyId);
if (this.getSysSignatureVersion() == SignatureVersion.V3) {
String strToSign = this.composer.composeStringToSign(this.getSysMethod(), null, signer,
this.getSysQueryParameters(), headerMap, null) + "\n" + hashedRequestPayload;
this.strToSign = strToSign;
strToSign = signer.getSignerName() + "\n" + hexEncode(signer.hash(strToSign.getBytes("UTF-8")));
String signature = signer.signString(strToSign, accessSecret);
headerMap.put("Authorization", this.composer.getAuthorization(signer, accessKeyId, signature)
+ ",SignedHeaders=" + this.getSysSignedHeaders(headerMap));
imutableMap = this.getSysQueryParameters();
} else {
Map paramsToSign = new HashMap();
paramsToSign.putAll(bodyParams);
paramsToSign.putAll(imutableMap);
String strToSign = this.composer.composeStringToSign(
this.getSysMethod(), null, signer, paramsToSign, null, null);
this.strToSign = strToSign;
String signature;
if (credentials instanceof KeyPairCredentials) {
signature = signer.signString(strToSign, credentials);
} else {
signature = signer.signString(strToSign, accessSecret + "&");
}
imutableMap.put("Signature", this.composer.getAuthorization(signer, accessKeyId, signature));
headerMap.clear();
headerMap.putAll(this.getSysHeaders());
}
}
this.setSysUrl(this.composeUrl(domain.getDomainName(), imutableMap));
this.headers = headerMap;
return this;
}
}