s3gof3r/auth.go

89 строки
1.8 KiB
Go
Исходник Обычный вид История

2014-02-21 20:22:33 +04:00
package s3gof3r
import (
"encoding/json"
"errors"
"io/ioutil"
"net/http"
"os"
)
// Keys for an Amazon Web Services account.
// Used for signing http requests.
type Keys struct {
AccessKey string
SecretKey string
SecurityToken string
}
type mdCreds struct {
Code string
LastUpdated string
Type string
AccessKeyId string
SecretAccessKey string
Token string
Expiration string
}
// Requests the AWS keys from the instance-based metadata on EC2
// Assumes only one IAM role.
2014-02-21 20:22:33 +04:00
func InstanceKeys() (keys Keys, err error) {
rolePath := "http://169.254.169.254/latest/meta-data/iam/security-credentials/"
var creds mdCreds
// request the role name for the instance
// assumes there is only one
resp, err := http.Get(rolePath)
if err != nil {
return
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
err = newRespError(resp)
return
}
role, err := ioutil.ReadAll(resp.Body)
if err != nil {
return
}
// request the credential metadata for the role
resp, err = http.Get(rolePath + string(role))
if err != nil {
return
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
err = newRespError(resp)
return
}
metadata, err := ioutil.ReadAll(resp.Body)
if err != nil {
return
}
json.Unmarshal([]byte(metadata), &creds)
keys = Keys{AccessKey: creds.AccessKeyId,
SecretKey: creds.SecretAccessKey,
SecurityToken: creds.Token,
}
return
}
// Reads the AWS keys from the environment
2014-02-21 20:22:33 +04:00
func EnvKeys() (keys Keys, err error) {
keys = Keys{AccessKey: os.Getenv("AWS_ACCESS_KEY_ID"),
SecretKey: os.Getenv("AWS_SECRET_ACCESS_KEY"),
}
if keys.AccessKey == "" || keys.SecretKey == "" {
err = errors.New("Keys not set in environment: AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY")
2014-02-21 20:22:33 +04:00
}
return
}