1
0
mirror of https://github.com/gilbertchen/duplicacy synced 2025-12-20 10:13:20 +00:00

First cut of Swift v2

This commit is contained in:
Mark Feit
2021-12-04 10:11:19 -05:00
parent e43e848d47
commit c363d21954

View File

@@ -15,6 +15,7 @@ import (
type SwiftStorage struct { type SwiftStorage struct {
StorageBase StorageBase
ctx *context.Context
connection *swift.Connection connection *swift.Connection
container string container string
storageDir string storageDir string
@@ -106,6 +107,8 @@ func CreateSwiftStorage(storageURL string, key string, threads int) (storage *Sw
arguments["protocol"] = "https" arguments["protocol"] = "https"
} }
ctx := context.Context()
// Please refer to https://godoc.org/github.com/ncw/swift#Connection // Please refer to https://godoc.org/github.com/ncw/swift#Connection
connection := swift.Connection{ connection := swift.Connection{
Domain: arguments["domain"], Domain: arguments["domain"],
@@ -129,17 +132,18 @@ func CreateSwiftStorage(storageURL string, key string, threads int) (storage *Sw
TrustId: arguments["trust_id"], TrustId: arguments["trust_id"],
} }
err = connection.Authenticate() err = connection.Authenticate(ctx)
if err != nil { if err != nil {
return nil, err return nil, err
} }
_, _, err = connection.Container(container) _, _, err = connection.Container(ctx, container)
if err != nil { if err != nil {
return nil, err return nil, err
} }
storage = &SwiftStorage{ storage = &SwiftStorage{
context: &ctx,
connection: &connection, connection: &connection,
container: container, container: container,
storageDir: storageDir, storageDir: storageDir,
@@ -168,7 +172,7 @@ func (storage *SwiftStorage) ListFiles(threadIndex int, dir string) (files []str
options.Delimiter = '/' options.Delimiter = '/'
} }
objects, err := storage.connection.ObjectsAll(storage.container, &options) objects, err := storage.connection.ObjectsAll(storage.ctx, storage.container, &options)
if err != nil { if err != nil {
return nil, nil, err return nil, nil, err
} }
@@ -190,12 +194,12 @@ func (storage *SwiftStorage) ListFiles(threadIndex int, dir string) (files []str
// DeleteFile deletes the file or directory at 'filePath'. // DeleteFile deletes the file or directory at 'filePath'.
func (storage *SwiftStorage) DeleteFile(threadIndex int, filePath string) (err error) { func (storage *SwiftStorage) DeleteFile(threadIndex int, filePath string) (err error) {
return storage.connection.ObjectDelete(storage.container, storage.storageDir+filePath) return storage.connection.ObjectDelete(storage.ctx, storage.container, storage.storageDir+filePath)
} }
// MoveFile renames the file. // MoveFile renames the file.
func (storage *SwiftStorage) MoveFile(threadIndex int, from string, to string) (err error) { func (storage *SwiftStorage) MoveFile(threadIndex int, from string, to string) (err error) {
return storage.connection.ObjectMove(storage.container, storage.storageDir+from, return storage.connection.ObjectMove(storage.ctx, storage.container, storage.storageDir+from,
storage.container, storage.storageDir+to) storage.container, storage.storageDir+to)
} }
@@ -207,7 +211,7 @@ func (storage *SwiftStorage) CreateDirectory(threadIndex int, dir string) (err e
// GetFileInfo returns the information about the file or directory at 'filePath'. // GetFileInfo returns the information about the file or directory at 'filePath'.
func (storage *SwiftStorage) GetFileInfo(threadIndex int, filePath string) (exist bool, isDir bool, size int64, err error) { func (storage *SwiftStorage) GetFileInfo(threadIndex int, filePath string) (exist bool, isDir bool, size int64, err error) {
object, _, err := storage.connection.Object(storage.container, storage.storageDir+filePath) object, _, err := storage.connection.Object(storage.ctx, storage.container, storage.storageDir+filePath)
if err != nil { if err != nil {
if err == swift.ObjectNotFound { if err == swift.ObjectNotFound {
@@ -223,7 +227,7 @@ func (storage *SwiftStorage) GetFileInfo(threadIndex int, filePath string) (exis
// DownloadFile reads the file at 'filePath' into the chunk. // DownloadFile reads the file at 'filePath' into the chunk.
func (storage *SwiftStorage) DownloadFile(threadIndex int, filePath string, chunk *Chunk) (err error) { func (storage *SwiftStorage) DownloadFile(threadIndex int, filePath string, chunk *Chunk) (err error) {
file, _, err := storage.connection.ObjectOpen(storage.container, storage.storageDir+filePath, false, nil) file, _, err := storage.connection.ObjectOpen(storage.ctx, storage.container, storage.storageDir+filePath, false, nil)
if err != nil { if err != nil {
return err return err
} }
@@ -234,7 +238,7 @@ func (storage *SwiftStorage) DownloadFile(threadIndex int, filePath string, chun
// UploadFile writes 'content' to the file at 'filePath'. // UploadFile writes 'content' to the file at 'filePath'.
func (storage *SwiftStorage) UploadFile(threadIndex int, filePath string, content []byte) (err error) { func (storage *SwiftStorage) UploadFile(threadIndex int, filePath string, content []byte) (err error) {
reader := CreateRateLimitedReader(content, storage.UploadRateLimit/storage.threads) reader := CreateRateLimitedReader(content, storage.UploadRateLimit/storage.threads)
_, err = storage.connection.ObjectPut(storage.container, storage.storageDir+filePath, reader, true, "", "application/duplicacy", nil) _, err = storage.connection.ObjectPut(storage.ctx, storage.container, storage.storageDir+filePath, reader, true, "", "application/duplicacy", nil)
return err return err
} }