alibabacloud-gateway-pds/main.tea (287 lines of code) (raw):
import SPI;
import Credential;
import Util;
import OpenApiUtil;
import EncodeUtil;
import SignatureUtil;
import String;
import Map;
import Array;
extends SPI;
init() {
super();
}
async function modifyConfiguration(context: SPI.InterceptorContext, attributeMap: SPI.AttributeMap): void {
var config = context.configuration;
config.endpoint = getEndpoint(config.network, config.endpoint);
}
async function modifyRequest(context: SPI.InterceptorContext, attributeMap: SPI.AttributeMap): void {
var request = context.request;
var config = context.configuration;
var date = Util.getDateUTCString();
request.headers = {
date = date,
host = config.endpoint,
x-acs-version = request.version,
x-acs-action = request.action,
user-agent = request.userAgent,
x-acs-signature-nonce = Util.getNonce(),
accept = 'application/json',
...request.headers
};
var signatureAlgorithm : string = Util.defaultString(request.signatureAlgorithm, 'ACS4-HMAC-SHA256');
var signatureVersion = Util.defaultString(request.signatureVersion, 'v1');
var hashedRequestPayload = EncodeUtil.hexEncode(EncodeUtil.hash(Util.toBytes(''), signatureAlgorithm));
if (!Util.isUnset(request.stream)) {
var tmp = Util.readAsBytes(request.stream);
hashedRequestPayload = EncodeUtil.hexEncode(EncodeUtil.hash(tmp, signatureAlgorithm));
request.stream = tmp;
request.headers.content-type = 'application/octet-stream';
} else {
if (!Util.isUnset(request.body)) {
if (Util.equalString(request.reqBodyType, 'json')) {
var jsonObj = Util.toJSONString(request.body);
hashedRequestPayload = EncodeUtil.hexEncode(EncodeUtil.hash(Util.toBytes(jsonObj), signatureAlgorithm));
request.stream = jsonObj;
request.headers.content-type = 'application/json; charset=utf-8';
} else {
var m = Util.assertAsMap(request.body);
var formObj = OpenApiUtil.toForm(m);
hashedRequestPayload = EncodeUtil.hexEncode(EncodeUtil.hash(Util.toBytes(formObj), signatureAlgorithm));
request.stream = formObj;
request.headers.content-type = 'application/x-www-form-urlencoded';
}
}
}
if (String.equals(signatureVersion, 'v4')){
if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SM3')) {
request.headers.x-acs-content-sm3 = hashedRequestPayload;
} else {
request.headers.x-acs-content-sha256 = hashedRequestPayload;
}
} else {
request.headers.x-acs-signature-method = 'HMAC-SHA1';
request.headers.x-acs-signature-version = '1.0';
}
if (!Util.equalString(request.authType, 'Anonymous') && !Util.isUnset(request.credential)) {
var credential : Credential = request.credential;
var credentialModel = credential.getCredential();
var authType = credentialModel.type;
if (Util.equalString(authType, 'bearer')) {
var bearerToken = credentialModel.bearerToken;
request.headers.x-acs-bearer-token = bearerToken;
request.headers.Authorization = `Bearer ${bearerToken}`;
} else {
var accessKeyId = credentialModel.accessKeyId;
var accessKeySecret = credentialModel.accessKeySecret;
var securityToken = credentialModel.securityToken;
if (!Util.empty(securityToken)) {
request.headers.x-acs-security-token = securityToken;
}
var headers : map[string]string = {};
if (!Util.isUnset(request.headers.content-type)) {
headers = request.headers;
} else if (String.equals(request.reqBodyType, 'formData') && String.equals(request.action, 'DownloadFile') && String.equals(request.pathname, '/v2/file/download')) {
var headersArray : [string] = Map.keySet(request.headers);
for(var key : headersArray) {
headers[key] = request.headers[key];
}
headers.content-type = 'application/x-www-form-urlencoded; charset=UTF-8';
} else {
headers = request.headers;
}
if (String.equals(signatureVersion, 'v4')) {
var dateNew = String.subString(date, 0, 10);
var region = getRegion(config.endpoint);
var signingkey = getSigningkey(signatureAlgorithm, accessKeySecret, region, dateNew);
request.headers.Authorization = getAuthorizationV4(request.pathname, request.method, request.query, headers, signatureAlgorithm, hashedRequestPayload, accessKeyId, signingkey, request.productId, region, dateNew);
} else {
request.headers.Authorization = getAuthorization(request.pathname, request.method, request.query, headers, accessKeyId, accessKeySecret);
}
}
}
}
async function modifyResponse(context: SPI.InterceptorContext, attributeMap: SPI.AttributeMap): void {
var request = context.request;
var response = context.response;
if (Util.is4xx(response.statusCode) || Util.is5xx(response.statusCode)) {
var _res = Util.readAsJSON(response.body);
var err = Util.assertAsMap(_res);
var headers : map[string]string = response.headers;
var requestId = headers.x-ca-request-id;
err.statusCode = response.statusCode;
err.requestId = requestId;
throw {
code = `${defaultAny(err.Code, err.code)}`,
message = `${defaultAny(err.Message, err.message)}`,
data = err,
};
}
if (!Util.isUnset(response.body)) {
if (Util.equalNumber(response.statusCode, 204)) {
Util.readAsString(response.body);
} else if (Util.equalString(request.bodyType, 'binary')) {
response.deserializedBody = response.body;
} else if (Util.equalString(request.bodyType, 'byte')) {
var byt = Util.readAsBytes(response.body);
response.deserializedBody = byt;
} else if (Util.equalString(request.bodyType, 'string')) {
var str = Util.readAsString(response.body);
response.deserializedBody = str;
} else if (Util.equalString(request.bodyType, 'json')) {
response.deserializedBody = Util.readAsJSON(response.body);
} else if (Util.equalString(request.bodyType, 'array')) {
response.deserializedBody = Util.readAsJSON(response.body);
} else {
response.deserializedBody = Util.readAsString(response.body);
}
}
}
async function getEndpoint(network: string, endpoint: string) : string{
var realEndpoint = 'api.aliyunpds.com';
if (!Util.empty(endpoint)) {
realEndpoint = endpoint;
}
if (!Util.empty(network) && String.equals(network, 'vpc')) {
realEndpoint = String.replace(realEndpoint, 'api.aliyunpds.com', 'api-vpc.aliyunpds.com', null);
realEndpoint = String.replace(realEndpoint, 'admin.aliyunpds.com', 'admin-vpc.aliyunpds.com', null);
}
return realEndpoint;
}
function defaultAny(inputValue: any, defaultValue: any): any {
if (Util.isUnset(inputValue)) {
return defaultValue;
}
return inputValue;
}
async function getAuthorization(pathname: string, method: string, query: map[string]string, headers: map[string]string, ak: string, secret: string): string {
var signature = getSignature(pathname, method, query, headers, secret);
return `acs ${ak}:${signature}`;
}
async function getSignature(pathname: string, method: string, query: map[string]string, headers: map[string]string, secret: string): string {
var stringToSign : string = '';
var canonicalizedResource = buildCanonicalizedResource(pathname, query);
var canonicalizedHeaders = buildCanonicalizedHeaders(headers);
stringToSign = `${method}\n${canonicalizedHeaders}${canonicalizedResource}`;
var signature = SignatureUtil.HmacSHA1Sign(stringToSign, secret);
return EncodeUtil.base64EncodeToString(signature);
}
async function buildCanonicalizedResource(pathname: string, query: map[string]string): string {
var canonicalizedResource : string = pathname;
if (!Util.isUnset(query)) {
var queryArray : [string] = Map.keySet(query);
var sortedQueryArray = Array.ascSort(queryArray);
var separator : string = '?';
for(var key : sortedQueryArray) {
canonicalizedResource = `${canonicalizedResource}${separator}${key}`;
if (!Util.empty(query[key])) {
canonicalizedResource = `${canonicalizedResource}=${query[key]}`;
}
separator = '&';
}
}
return canonicalizedResource;
}
async function buildCanonicalizedHeaders(headers: map[string]string): string {
var accept = headers.accept;
if (Util.isUnset(accept)) {
accept = '';
}
var contentMd5 = headers.content-md5;
if (Util.isUnset(contentMd5)) {
contentMd5 = '';
}
var contentType = headers.content-type;
if (Util.isUnset(contentType)) {
contentType = '';
}
var date = headers.date;
if (Util.isUnset(date)) {
date = '';
}
var canonicalizedHeaders : string = `${accept}\n${contentMd5}\n${contentType}\n${date}\n`;
var sortedHeaders : [string] = getSignedHeaders(headers);
for(var header : sortedHeaders) {
var value = headers[header];
var valueTrim = String.trim(value);
canonicalizedHeaders = `${canonicalizedHeaders}${header}:${valueTrim}\n`;
}
return canonicalizedHeaders;
}
async function getSignedHeaders(headers: map[string]string): [string] {
var headersArray : [string] = Map.keySet(headers);
var sortedHeadersArray = Array.ascSort(headersArray);
var tmp : string = '';
var separator : string = '';
for(var key : sortedHeadersArray) {
var lowerKey = String.toLower(key);
if (String.hasPrefix(lowerKey, 'x-acs-')) {
if (!String.contains(tmp, lowerKey)) {
tmp = `${tmp}${separator}${lowerKey}`;
separator = ';';
}
}
}
return String.split(tmp, ';', null);
}
function getRegion(endpoint: string): string {
var region = 'center';
if (Util.empty(endpoint)) {
return region;
}
if (String.contains(endpoint, '.admin.aliyunpds.com')) {
region = String.replace(endpoint, '.admin.aliyunpds.com', '', null);
}
return region;
}
async function getSigningkey(signatureAlgorithm: string, secret: string, region: string, date: string): bytes {
var sc1 = `aliyun_v4${secret}`;
var sc2 = Util.toBytes('');
if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SHA256')) {
sc2 = SignatureUtil.HmacSHA256Sign(date, sc1);
} else if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SM3')) {
sc2 = SignatureUtil.HmacSM3Sign(date, sc1);
}
var sc3 = Util.toBytes('');
if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SHA256')) {
sc3 = SignatureUtil.HmacSHA256SignByBytes(region, sc2);
} else if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SM3')) {
sc3 = SignatureUtil.HmacSM3SignByBytes(region, sc2);
}
var sc4 = Util.toBytes('');
if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SHA256')) {
sc4 = SignatureUtil.HmacSHA256SignByBytes('pds', sc3);
} else if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SM3')) {
sc4 = SignatureUtil.HmacSM3SignByBytes('pds', sc3);
}
var hmac = Util.toBytes('');
if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SHA256')) {
hmac = SignatureUtil.HmacSHA256SignByBytes('aliyun_v4_request', sc4);
} else if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SM3')) {
hmac = SignatureUtil.HmacSM3SignByBytes('aliyun_v4_request', sc4);
}
return hmac;
}
async function getAuthorizationV4(pathname: string, method: string, query: map[string]string, headers: map[string]string, signatureAlgorithm: string, payload: string, ak: string, signingkey: bytes, product: string, region: string, date: string): string {
var signature = getSignatureV4(pathname, method, query, headers, signatureAlgorithm, payload, signingkey);
var signedHeaders = getSignedHeaders(headers);
var signedHeadersStr = Array.join(signedHeaders, ';');
return `${signatureAlgorithm} Credential=${ak}/${date}/${region}/${product}/aliyun_v4_request,SignedHeaders=${signedHeadersStr},Signature=${signature}`;
}
async function getSignatureV4(pathname: string, method: string, query: map[string]string, headers: map[string]string, signatureAlgorithm: string, payload: string, signingkey: bytes): string {
var stringToSign : string = '';
var canonicalizedResource = buildCanonicalizedResource(pathname, query);
var canonicalizedHeaders = buildCanonicalizedHeaders(headers);
var signedHeaders = getSignedHeaders(headers);
var signedHeadersStr = Array.join(signedHeaders, ';');
stringToSign = `${method}\n${canonicalizedResource}\n${canonicalizedHeaders}\n${signedHeadersStr}\n${payload}`;
var hex = EncodeUtil.hexEncode(EncodeUtil.hash(Util.toBytes(stringToSign), signatureAlgorithm));
stringToSign = `${signatureAlgorithm}\n${hex}`;
var signature = Util.toBytes('');
if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SHA256')) {
signature = SignatureUtil.HmacSHA256SignByBytes(stringToSign, signingkey);
} else if (Util.equalString(signatureAlgorithm, 'ACS4-HMAC-SM3')) {
signature = SignatureUtil.HmacSM3SignByBytes(stringToSign, signingkey);
}
return EncodeUtil.hexEncode(signature);
}