2018-09-08 13:17:23 +00:00
|
|
|
/*
|
|
|
|
* 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 auth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2019-07-04 16:24:33 +00:00
|
|
|
"reflect"
|
|
|
|
|
2018-09-08 13:17:23 +00:00
|
|
|
"github.com/aliyun/alibaba-cloud-sdk-go/sdk/auth/credentials"
|
|
|
|
"github.com/aliyun/alibaba-cloud-sdk-go/sdk/auth/signers"
|
|
|
|
"github.com/aliyun/alibaba-cloud-sdk-go/sdk/errors"
|
|
|
|
"github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
|
|
|
|
"github.com/aliyun/alibaba-cloud-sdk-go/sdk/responses"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Signer interface {
|
|
|
|
GetName() string
|
|
|
|
GetType() string
|
|
|
|
GetVersion() string
|
|
|
|
GetAccessKeyId() (string, error)
|
|
|
|
GetExtraParam() map[string]string
|
|
|
|
Sign(stringToSign, secretSuffix string) string
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewSignerWithCredential(credential Credential, commonApi func(request *requests.CommonRequest, signer interface{}) (response *responses.CommonResponse, err error)) (signer Signer, err error) {
|
|
|
|
switch instance := credential.(type) {
|
|
|
|
case *credentials.AccessKeyCredential:
|
|
|
|
{
|
2019-07-04 16:24:33 +00:00
|
|
|
signer = signers.NewAccessKeySigner(instance)
|
2018-09-08 13:17:23 +00:00
|
|
|
}
|
|
|
|
case *credentials.StsTokenCredential:
|
|
|
|
{
|
2019-07-04 16:24:33 +00:00
|
|
|
signer = signers.NewStsTokenSigner(instance)
|
|
|
|
}
|
|
|
|
case *credentials.BearerTokenCredential:
|
|
|
|
{
|
|
|
|
signer = signers.NewBearerTokenSigner(instance)
|
2018-09-08 13:17:23 +00:00
|
|
|
}
|
|
|
|
case *credentials.RamRoleArnCredential:
|
|
|
|
{
|
|
|
|
signer, err = signers.NewRamRoleArnSigner(instance, commonApi)
|
|
|
|
}
|
|
|
|
case *credentials.RsaKeyPairCredential:
|
|
|
|
{
|
|
|
|
signer, err = signers.NewSignerKeyPair(instance, commonApi)
|
|
|
|
}
|
|
|
|
case *credentials.EcsRamRoleCredential:
|
|
|
|
{
|
2019-07-04 16:24:33 +00:00
|
|
|
signer = signers.NewEcsRamRoleSigner(instance, commonApi)
|
2018-09-08 13:17:23 +00:00
|
|
|
}
|
|
|
|
case *credentials.BaseCredential: // deprecated user interface
|
|
|
|
{
|
2019-07-04 16:24:33 +00:00
|
|
|
signer = signers.NewAccessKeySigner(instance.ToAccessKeyCredential())
|
2018-09-08 13:17:23 +00:00
|
|
|
}
|
|
|
|
case *credentials.StsRoleArnCredential: // deprecated user interface
|
|
|
|
{
|
|
|
|
signer, err = signers.NewRamRoleArnSigner(instance.ToRamRoleArnCredential(), commonApi)
|
|
|
|
}
|
|
|
|
case *credentials.StsRoleNameOnEcsCredential: // deprecated user interface
|
|
|
|
{
|
2019-07-04 16:24:33 +00:00
|
|
|
signer = signers.NewEcsRamRoleSigner(instance.ToEcsRamRoleCredential(), commonApi)
|
2018-09-08 13:17:23 +00:00
|
|
|
}
|
|
|
|
default:
|
|
|
|
message := fmt.Sprintf(errors.UnsupportedCredentialErrorMessage, reflect.TypeOf(credential))
|
|
|
|
err = errors.NewClientError(errors.UnsupportedCredentialErrorCode, message, nil)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func Sign(request requests.AcsRequest, signer Signer, regionId string) (err error) {
|
|
|
|
switch request.GetStyle() {
|
|
|
|
case requests.ROA:
|
|
|
|
{
|
2019-07-04 16:24:33 +00:00
|
|
|
err = signRoaRequest(request, signer, regionId)
|
2018-09-08 13:17:23 +00:00
|
|
|
}
|
|
|
|
case requests.RPC:
|
|
|
|
{
|
|
|
|
err = signRpcRequest(request, signer, regionId)
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
message := fmt.Sprintf(errors.UnknownRequestTypeErrorMessage, reflect.TypeOf(request))
|
|
|
|
err = errors.NewClientError(errors.UnknownRequestTypeErrorCode, message, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|