2026-03-16 09:48:26 -04:00
|
|
|
package s3
|
|
|
|
|
|
2026-03-17 20:53:41 -04:00
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
2026-03-16 09:48:26 -04:00
|
|
|
|
|
|
|
|
// Config holds the parsed fields from an S3 URL. Use ParseURL to create one from a URL string.
|
|
|
|
|
type Config struct {
|
|
|
|
|
Endpoint string // host[:port] only, e.g. "s3.us-east-1.amazonaws.com"
|
|
|
|
|
PathStyle bool
|
|
|
|
|
Bucket string
|
|
|
|
|
Prefix string
|
|
|
|
|
Region string
|
|
|
|
|
AccessKey string
|
|
|
|
|
SecretKey string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Object represents an S3 object returned by list operations.
|
|
|
|
|
type Object struct {
|
2026-03-17 20:53:41 -04:00
|
|
|
Key string
|
|
|
|
|
Size int64
|
|
|
|
|
LastModified time.Time
|
2026-03-16 09:48:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListResult holds the response from a ListObjectsV2 call.
|
|
|
|
|
type ListResult struct {
|
|
|
|
|
Objects []Object
|
|
|
|
|
IsTruncated bool
|
|
|
|
|
NextContinuationToken string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ErrorResponse is returned when S3 responds with a non-2xx status code.
|
|
|
|
|
type ErrorResponse struct {
|
|
|
|
|
StatusCode int
|
|
|
|
|
Code string `xml:"Code"`
|
|
|
|
|
Message string `xml:"Message"`
|
|
|
|
|
Body string `xml:"-"` // raw response body
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *ErrorResponse) Error() string {
|
|
|
|
|
if e.Code != "" {
|
|
|
|
|
return fmt.Sprintf("s3: %s (HTTP %d): %s", e.Code, e.StatusCode, e.Message)
|
|
|
|
|
}
|
|
|
|
|
return fmt.Sprintf("s3: HTTP %d: %s", e.StatusCode, e.Body)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// listObjectsV2Response is the XML response from S3 ListObjectsV2
|
|
|
|
|
type listObjectsV2Response struct {
|
|
|
|
|
Contents []listObject `xml:"Contents"`
|
|
|
|
|
IsTruncated bool `xml:"IsTruncated"`
|
|
|
|
|
NextContinuationToken string `xml:"NextContinuationToken"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type listObject struct {
|
2026-03-17 20:53:41 -04:00
|
|
|
Key string `xml:"Key"`
|
|
|
|
|
Size int64 `xml:"Size"`
|
|
|
|
|
LastModified string `xml:"LastModified"`
|
2026-03-16 09:48:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// deleteResult is the XML response from S3 DeleteObjects
|
|
|
|
|
type deleteResult struct {
|
|
|
|
|
Errors []deleteError `xml:"Error"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type deleteError struct {
|
|
|
|
|
Key string `xml:"Key"`
|
|
|
|
|
Code string `xml:"Code"`
|
|
|
|
|
Message string `xml:"Message"`
|
|
|
|
|
}
|
2026-03-16 20:00:19 -04:00
|
|
|
|
2026-03-19 21:11:36 -04:00
|
|
|
// MultipartUpload represents an in-progress multipart upload returned by ListMultipartUploads.
|
|
|
|
|
type MultipartUpload struct {
|
|
|
|
|
Key string
|
|
|
|
|
UploadID string
|
|
|
|
|
Initiated time.Time
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// listMultipartUploadsResult is the XML response from S3 ListMultipartUploads
|
|
|
|
|
type listMultipartUploadsResult struct {
|
|
|
|
|
Uploads []listUpload `xml:"Upload"`
|
|
|
|
|
IsTruncated bool `xml:"IsTruncated"`
|
|
|
|
|
NextKeyMarker string `xml:"NextKeyMarker"`
|
|
|
|
|
NextUploadIDMarker string `xml:"NextUploadIdMarker"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type listUpload struct {
|
|
|
|
|
Key string `xml:"Key"`
|
|
|
|
|
UploadID string `xml:"UploadId"`
|
|
|
|
|
Initiated string `xml:"Initiated"`
|
|
|
|
|
}
|
|
|
|
|
|
2026-03-16 20:00:19 -04:00
|
|
|
// initiateMultipartUploadResult is the XML response from S3 InitiateMultipartUpload
|
|
|
|
|
type initiateMultipartUploadResult struct {
|
|
|
|
|
UploadID string `xml:"UploadId"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// completedPart represents a successfully uploaded part for CompleteMultipartUpload
|
|
|
|
|
type completedPart struct {
|
|
|
|
|
PartNumber int
|
|
|
|
|
ETag string
|
|
|
|
|
}
|