v0.1.4
## [0.1.4] - 2026-03-31 ### 🐛 Bug Fixes - *(deps)* Update module github.com/aws/aws-sdk-go-v2/service/s3 to v1.97.0 (#80) - *(deps)* Update module github.com/aws/aws-sdk-go-v2/feature/s3/transfermanager to v0.1.9 (#82) - *(deps)* Update aws-sdk-go-v2 monorepo (#83) - *(deps)* Update aws-sdk-go-v2 monorepo (#87) - *(deps)* Update aws-sdk-go-v2 monorepo (#88) - *(deps)* Update aws-sdk-go-v2 monorepo (#90) ### ⚙️ Miscellaneous Tasks - *(deps)* Update pre-commit hook golangci/golangci-lint to v2.11.2 (#74) - *(deps)* Update pre-commit hook golangci/golangci-lint to v2.11.3 (#76) - *(deps)* Update pre-commit hook gitleaks/gitleaks to v8.30.1 (#78) - *(deps)* Update pre-commit hook golangci/golangci-lint to v2.11.4 (#85) <!-- generated by git-cliff --> --- **Note:** Please use **Squash Merge** when merging this PR. Reviewed-on: #91 Co-authored-by: Unbound Releaser <releaser@unbound.se> Co-committed-by: Unbound Releaser <releaser@unbound.se>
Storage Module
Shared storage utilities for AWS S3.
Features
- S3 object storage with presigned URL generation
- Two upload strategies: managed uploads (for large files) and direct uploads
- Configurable part size for multipart uploads
- 15-minute presigned URL expiration
Usage
Using the Upload Manager (recommended for large files)
import "gitea.unbound.se/unboundsoftware/storage"
// Create storage with automatic AWS config loading
s3Storage, err := storage.New("my-bucket")
if err != nil {
// handle error
}
// Upload a file and get a presigned URL
url, err := s3Storage.Store("path/to/file.pdf", fileReader, "application/pdf")
Using Direct Upload (for smaller files or custom config)
import (
"github.com/aws/aws-sdk-go-v2/config"
"git.unbound.se/unboundsoftware/storage"
)
// Load custom AWS config
cfg, err := config.LoadDefaultConfig(context.Background())
if err != nil {
// handle error
}
// Create storage with custom config
s3Storage := storage.NewS3(cfg, "my-bucket")
// Upload a file and get a presigned URL
url, err := s3Storage.Store("path/to/file.pdf", fileReader, "application/pdf")
Configuration
The storage module uses AWS SDK v2 and loads configuration from:
- Environment variables (
AWS_REGION,AWS_ACCESS_KEY_ID,AWS_SECRET_ACCESS_KEY) - Shared configuration files (
~/.aws/config,~/.aws/credentials) - IAM roles (when running on AWS infrastructure)
Description