| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 |
- package aws
- import (
- "bytes"
- "fmt"
- "github.com/ks3sdklib/aws-sdk-go/aws/retry"
- "io"
- "net/http"
- "os"
- "time"
- "github.com/ks3sdklib/aws-sdk-go/aws/credentials"
- )
- // DefaultChainCredentials is a Credentials which will find the first available
- // credentials Value from the list of Providers.
- //
- // This should be used in the default case. Once the type of credentials are
- // known switching to the specific Credentials will be more efficient.
- var DefaultChainCredentials = credentials.NewChainCredentials(
- []credentials.Provider{
- &credentials.EnvProvider{},
- &credentials.SharedCredentialsProvider{Filename: "", Profile: ""},
- &credentials.EC2RoleProvider{ExpiryWindow: 5 * time.Minute},
- })
- // DefaultMaxRetries is the default number of retries for a service.
- const DefaultMaxRetries = 3
- // DefaultConfig is the default all service configuration will be based off of.
- var DefaultConfig = &Config{
- Credentials: DefaultChainCredentials,
- Endpoint: "",
- Ks3BillEndpoint: "ks3bill.api.ksyun.com",
- Region: "",
- DisableSSL: false,
- ManualSend: false,
- HTTPClient: http.DefaultClient,
- LogHTTPBody: false,
- LogLevel: Off,
- Logger: os.Stdout,
- MaxRetries: DefaultMaxRetries,
- RetryRule: retry.DefaultExponentialRetryRule,
- ShouldRetry: retry.ShouldRetry,
- DisableParamValidation: false,
- DisableComputeChecksums: false,
- S3ForcePathStyle: false,
- DomainMode: false,
- SignerVersion: "V2",
- CrcCheckEnabled: false,
- DisableRestProtocolURICleaning: true,
- DisableDnsCache: false,
- }
- // A Config provides service configuration
- type Config struct {
- Credentials *credentials.Credentials
- Endpoint string
- Ks3BillEndpoint string
- Region string
- DisableSSL bool
- ManualSend bool
- HTTPClient *http.Client
- LogHTTPBody bool
- LogLevel uint
- Logger io.Writer
- MaxRetries int // 重试次数
- RetryRule retry.RetryRule // 重试规则
- ShouldRetry func(error) bool // 是否需要重试
- DisableParamValidation bool
- DisableComputeChecksums bool
- S3ForcePathStyle bool
- DomainMode bool
- SignerVersion string
- CrcCheckEnabled bool // 允许crc64校验,默认为false
- DisableRestProtocolURICleaning bool // 禁用path clean,默认为true
- DisableDnsCache bool // 禁用DNS缓存,默认为false
- }
- // Copy will return a shallow copy of the Config object.
- func (c Config) Copy() Config {
- dst := Config{}
- dst.Credentials = c.Credentials
- dst.Endpoint = c.Endpoint
- dst.Ks3BillEndpoint = c.Ks3BillEndpoint
- dst.Region = c.Region
- dst.DisableSSL = c.DisableSSL
- dst.ManualSend = c.ManualSend
- dst.HTTPClient = c.HTTPClient
- dst.LogHTTPBody = c.LogHTTPBody
- dst.LogLevel = c.LogLevel
- dst.Logger = c.Logger
- dst.MaxRetries = c.MaxRetries
- dst.RetryRule = c.RetryRule
- dst.ShouldRetry = c.ShouldRetry
- dst.DisableParamValidation = c.DisableParamValidation
- dst.DisableComputeChecksums = c.DisableComputeChecksums
- dst.S3ForcePathStyle = c.S3ForcePathStyle
- dst.DomainMode = c.DomainMode
- dst.SignerVersion = c.SignerVersion
- dst.CrcCheckEnabled = c.CrcCheckEnabled
- dst.DisableRestProtocolURICleaning = c.DisableRestProtocolURICleaning
- dst.DisableDnsCache = c.DisableDnsCache
- return dst
- }
- // Merge merges the newcfg attribute values into this Config. Each attribute
- // will be merged into this config if the newcfg attribute's value is non-zero.
- // Due to this, newcfg attributes with zero values cannot be merged in. For
- // example bool attributes cannot be cleared using Merge, and must be explicitly
- // set on the Config structure.
- func (c Config) Merge(newcfg *Config) *Config {
- if newcfg == nil {
- return &c
- }
- cfg := Config{}
- if newcfg.Credentials != nil {
- cfg.Credentials = newcfg.Credentials
- } else {
- cfg.Credentials = c.Credentials
- }
- if newcfg.Endpoint != "" {
- cfg.Endpoint = newcfg.Endpoint
- } else {
- cfg.Endpoint = c.Endpoint
- }
- if newcfg.Ks3BillEndpoint != "" {
- cfg.Ks3BillEndpoint = newcfg.Ks3BillEndpoint
- } else {
- cfg.Ks3BillEndpoint = c.Ks3BillEndpoint
- }
- if newcfg.Region != "" {
- cfg.Region = newcfg.Region
- } else {
- cfg.Region = c.Region
- }
- if newcfg.DisableSSL {
- cfg.DisableSSL = newcfg.DisableSSL
- } else {
- cfg.DisableSSL = c.DisableSSL
- }
- if newcfg.ManualSend {
- cfg.ManualSend = newcfg.ManualSend
- } else {
- cfg.ManualSend = c.ManualSend
- }
- if newcfg.DisableDnsCache {
- cfg.DisableDnsCache = newcfg.DisableDnsCache
- } else {
- cfg.DisableDnsCache = c.DisableDnsCache
- }
- if newcfg.HTTPClient != nil {
- cfg.HTTPClient = newcfg.HTTPClient
- } else {
- cfg.HTTPClient = c.HTTPClient
- if !cfg.DisableDnsCache {
- cfg.HTTPClient.Transport = DnsCacheTransport
- }
- }
- defaultHTTPRedirect(cfg.HTTPClient)
- if newcfg.LogHTTPBody {
- cfg.LogHTTPBody = newcfg.LogHTTPBody
- } else {
- cfg.LogHTTPBody = c.LogHTTPBody
- }
- if newcfg.LogLevel != 0 {
- cfg.LogLevel = newcfg.LogLevel
- } else {
- cfg.LogLevel = c.LogLevel
- }
- if newcfg.Logger != nil {
- cfg.Logger = newcfg.Logger
- } else {
- cfg.Logger = c.Logger
- }
- if newcfg.MaxRetries != 0 {
- cfg.MaxRetries = newcfg.MaxRetries
- } else {
- cfg.MaxRetries = c.MaxRetries
- }
- if newcfg.RetryRule != nil {
- cfg.RetryRule = newcfg.RetryRule
- } else {
- cfg.RetryRule = c.RetryRule
- }
- if newcfg.ShouldRetry != nil {
- cfg.ShouldRetry = newcfg.ShouldRetry
- } else {
- cfg.ShouldRetry = c.ShouldRetry
- }
- if newcfg.DisableParamValidation {
- cfg.DisableParamValidation = newcfg.DisableParamValidation
- } else {
- cfg.DisableParamValidation = c.DisableParamValidation
- }
- if newcfg.DisableComputeChecksums {
- cfg.DisableComputeChecksums = newcfg.DisableComputeChecksums
- } else {
- cfg.DisableComputeChecksums = c.DisableComputeChecksums
- }
- if newcfg.S3ForcePathStyle {
- cfg.S3ForcePathStyle = newcfg.S3ForcePathStyle
- } else {
- cfg.S3ForcePathStyle = c.S3ForcePathStyle
- }
- if newcfg.DomainMode {
- cfg.DomainMode = newcfg.DomainMode
- } else {
- cfg.DomainMode = c.DomainMode
- }
- if newcfg.SignerVersion != "" {
- cfg.SignerVersion = newcfg.SignerVersion
- } else {
- cfg.SignerVersion = c.SignerVersion
- }
- if newcfg.CrcCheckEnabled {
- cfg.CrcCheckEnabled = newcfg.CrcCheckEnabled
- } else {
- cfg.CrcCheckEnabled = c.CrcCheckEnabled
- }
- if newcfg.DisableRestProtocolURICleaning {
- cfg.DisableRestProtocolURICleaning = newcfg.DisableRestProtocolURICleaning
- } else {
- cfg.DisableRestProtocolURICleaning = c.DisableRestProtocolURICleaning
- }
- return &cfg
- }
- // Define the level of the output log
- const (
- Off = iota
- Error
- Warn
- Info
- Debug
- )
- // LogTag Tag for each level of log
- var LogTag = []string{"[error]", "[warn]", "[info]", "[debug]"}
- func (c Config) writeLog(level uint, format string, a ...interface{}) {
- if c.LogLevel < level {
- return
- }
- var logBuffer bytes.Buffer
- logBuffer.WriteString(time.Now().Format("2006/01/02 15:04:05"))
- logBuffer.WriteString(" ")
- logBuffer.WriteString(LogTag[level-1])
- logBuffer.WriteString(fmt.Sprintf(format, a...))
- if logBuffer.Bytes()[logBuffer.Len()-1] != '\n' {
- logBuffer.WriteString("\n")
- }
- fmt.Fprintf(c.Logger, "%s", logBuffer.String())
- }
- func (c Config) LogError(format string, a ...interface{}) {
- if c.LogLevel < Error {
- return
- }
- c.writeLog(Error, format, a...)
- }
- func (c Config) LogWarn(format string, a ...interface{}) {
- if c.LogLevel < Warn {
- return
- }
- c.writeLog(Warn, format, a...)
- }
- func (c Config) LogInfo(format string, a ...interface{}) {
- if c.LogLevel < Info {
- return
- }
- c.writeLog(Info, format, a...)
- }
- func (c Config) LogDebug(format string, a ...interface{}) {
- if c.LogLevel < Debug {
- return
- }
- c.writeLog(Debug, format, a...)
- }
|