You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							70 lines
						
					
					
						
							1.7 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							70 lines
						
					
					
						
							1.7 KiB
						
					
					
				| package s3_backend | |
| 
 | |
| import ( | |
| 	"fmt" | |
| 	"github.com/aws/aws-sdk-go/aws/request" | |
| 	"github.com/chrislusf/seaweedfs/weed/util" | |
| 	"sync" | |
| 
 | |
| 	"github.com/aws/aws-sdk-go/aws" | |
| 	"github.com/aws/aws-sdk-go/aws/credentials" | |
| 	"github.com/aws/aws-sdk-go/aws/session" | |
| 	"github.com/aws/aws-sdk-go/service/s3" | |
| 	"github.com/aws/aws-sdk-go/service/s3/s3iface" | |
| ) | |
| 
 | |
| var ( | |
| 	s3Sessions   = make(map[string]s3iface.S3API) | |
| 	sessionsLock sync.RWMutex | |
| ) | |
| 
 | |
| func getSession(region string) (s3iface.S3API, bool) { | |
| 	sessionsLock.RLock() | |
| 	defer sessionsLock.RUnlock() | |
| 
 | |
| 	sess, found := s3Sessions[region] | |
| 	return sess, found | |
| } | |
| 
 | |
| func createSession(awsAccessKeyId, awsSecretAccessKey, region, endpoint string) (s3iface.S3API, error) { | |
| 
 | |
| 	sessionsLock.Lock() | |
| 	defer sessionsLock.Unlock() | |
| 
 | |
| 	if t, found := s3Sessions[region]; found { | |
| 		return t, nil | |
| 	} | |
| 
 | |
| 	config := &aws.Config{ | |
| 		Region:                        aws.String(region), | |
| 		Endpoint:                      aws.String(endpoint), | |
| 		S3ForcePathStyle:              aws.Bool(true), | |
| 		S3DisableContentMD5Validation: aws.Bool(true), | |
| 	} | |
| 	if awsAccessKeyId != "" && awsSecretAccessKey != "" { | |
| 		config.Credentials = credentials.NewStaticCredentials(awsAccessKeyId, awsSecretAccessKey, "") | |
| 	} | |
| 
 | |
| 	sess, err := session.NewSession(config) | |
| 	if err != nil { | |
| 		return nil, fmt.Errorf("create aws session in region %s: %v", region, err) | |
| 	} | |
| 	sess.Handlers.Build.PushBack(func(r *request.Request) { | |
| 		r.HTTPRequest.Header.Set("User-Agent", "SeaweedFS/"+util.VERSION_NUMBER) | |
| 	}) | |
| 
 | |
| 	t := s3.New(sess) | |
| 
 | |
| 	s3Sessions[region] = t | |
| 
 | |
| 	return t, nil | |
| 
 | |
| } | |
| 
 | |
| func deleteFromS3(sess s3iface.S3API, sourceBucket string, sourceKey string) (err error) { | |
| 	_, err = sess.DeleteObject(&s3.DeleteObjectInput{ | |
| 		Bucket: aws.String(sourceBucket), | |
| 		Key:    aws.String(sourceKey), | |
| 	}) | |
| 	return err | |
| }
 |