Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soto-project/soto-s3-file-transfer
Simplifying upload and download from S3 using Soto the Swift SDK for AWS.
https://github.com/soto-project/soto-s3-file-transfer
aws s3 server-side-swift soto swift swift-nio
Last synced: 5 days ago
JSON representation
Simplifying upload and download from S3 using Soto the Swift SDK for AWS.
- Host: GitHub
- URL: https://github.com/soto-project/soto-s3-file-transfer
- Owner: soto-project
- License: apache-2.0
- Created: 2020-11-05T19:15:20.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-12-18T22:30:50.000Z (about 1 month ago)
- Last Synced: 2025-01-15T10:54:42.058Z (12 days ago)
- Topics: aws, s3, server-side-swift, soto, swift, swift-nio
- Language: Swift
- Homepage: https://soto.codes
- Size: 87.9 KB
- Stars: 48
- Watchers: 4
- Forks: 14
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Soto S3 Transfer
Make uploading and downloading of files to AWS S3 easy.
## Setup
Soto S3 Transfer uses the Soto Swift SDK for AWS. You need to create a Soto S3 service object before you can use the S3 transfer manager. See Soto [documentation](https://github.com/soto-project/soto) for more guidance. You also need to supply the `threadPoolProvider` parameter which indicates where Soto S3 Transfer will get threads from to run the file loading and saving.
```swift
let client = AWSClient()
let s3 = S3(client: client, region: .euwest1)
let s3FileTransfer = S3FileTransferManager(s3: s3)
```## Upload to S3
Uploading files to S3 is done with one call.
```swift
try await s3FileTransfer.copy(
from: "/Users/me/images/test.jpg",
to: S3File(url: "s3://my-bucket/test.jpg")!
)
```
You can also upload a folder as follows
```swift
try await s3FileTransfer.copy(
from: "/Users/me/images/",
to: S3Folder(url: "s3://my-bucket/images/")!
)
```
If you are uploading a folder multiple files will be uploaded in parallel. The number of upload tasks running concurrently defaults to 4 but you can control this by setting `maxConcurrentTasks` in the `Configuration` you supply to the initialization of `S3FileTransferManager`.
```swift
let s3Transfer = S3FileTransferManager(
s3: s3,
configuration: .init(maxConcurrentTasks: 8)
)
```
## Download from S3Download is as simple as upload just swap the parameters around
```swift
try await s3FileTransfer.copy(
from: S3File(url: "s3://my-bucket/test.jpg")!,
to: "/Users/me/images/test.jpg"
)
try await s3FileTransfer.copy(
from: S3Folder(url: "s3://my-bucket/images/")!,
to: "/Users/me/downloads/images/"
)
```## Copy from one S3 bucket to another
You can also copy from one S3 bucket to another by supplying two `S3Files` or two `S3Folders`
```swift
try await s3FileTransfer.copy(
from: S3File(url: "s3://my-bucket/test2.jpg")!,
to: S3File(url: "s3://my-bucket/test.jpg")!
)
try await s3FileTransfer.copy(
from: S3Folder(url: "s3://my-bucket/images/")!,
to: S3Folder(url: "s3://my-other-bucket/images/")!)
)
```## Sync operations
There are `sync` versions of these operations as well. This will only copy files across if they are newer than the existing files. You can also have it delete files in the target folder if they don't exist in the source folder.
```swift
try await s3FileTransfer.sync(
from: "/Users/me/images/",
to: S3Folder(url: "s3://my-bucket/images")!,
delete: true
)
try await s3FileTransfer.sync(
from: S3Folder(url: "s3://my-bucket/images")!,
to: "/Users/me/downloads/images/",
delete: false
)
```## Multipart upload
If uploads are above a certain size then the transfer manager will use multipart upload to upload the file to S3. You can control what this threshold is and the multipart part sizes by supplying a configuration at initialization of the manager. If you don't supply a configuration both of these values are set to 8MB.
```swift
let s3Transfer = S3FileTransferManager(
s3: s3,
configuration: .init(multipartThreshold: 16*1024*1024, multipartPartSize: 16*1024*1024)
)
```