mirror of
https://github.com/thegeeklab/wp-s3-action.git
synced 2024-11-22 01:00:40 +00:00
Merge pull request #20 from divercraig/master
Adding support for uploading files with Content Encoding
This commit is contained in:
commit
4e658422f0
9
DOCS.md
9
DOCS.md
@ -9,6 +9,7 @@ Use the S3 sync plugin to synchronize files and folders with an Amazon S3 bucket
|
|||||||
* `target` - target folder in your S3 bucket
|
* `target` - target folder in your S3 bucket
|
||||||
* `delete` - deletes files in the target not found in the source
|
* `delete` - deletes files in the target not found in the source
|
||||||
* `content_type` - override default mime-types to use this value
|
* `content_type` - override default mime-types to use this value
|
||||||
|
* `content_encoding` - override default content encoding header for files
|
||||||
* `metadata` - set custom metadata
|
* `metadata` - set custom metadata
|
||||||
* `redirects` - targets that should redirect elsewhere
|
* `redirects` - targets that should redirect elsewhere
|
||||||
* `cloudfront_distribution_id` - (optional) the cloudfront distribution id to invalidate after syncing
|
* `cloudfront_distribution_id` - (optional) the cloudfront distribution id to invalidate after syncing
|
||||||
@ -29,7 +30,7 @@ publish:
|
|||||||
cloudfront_distribution_id: "9c5785d3ece6a9cdefa4"
|
cloudfront_distribution_id: "9c5785d3ece6a9cdefa4"
|
||||||
```
|
```
|
||||||
|
|
||||||
Both `acl` and `content_type` can be passed as a string value to apply to all files, or as a map to apply to a subset of files.
|
The `acl`, `content_type`, and `content_encoding` parameters can be passed as a string value to apply to all files, or as a map to apply to a subset of files.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
@ -41,6 +42,9 @@ publish:
|
|||||||
"private/*": private
|
"private/*": private
|
||||||
content_type:
|
content_type:
|
||||||
".svg": image/svg+xml
|
".svg": image/svg+xml
|
||||||
|
content_encoding:
|
||||||
|
".js": gzip
|
||||||
|
".css": gzip
|
||||||
region: "us-east-1"
|
region: "us-east-1"
|
||||||
bucket: "my-bucket.s3-website-us-east-1.amazonaws.com"
|
bucket: "my-bucket.s3-website-us-east-1.amazonaws.com"
|
||||||
access_key: "970d28f4dd477bc184fbd10b376de753"
|
access_key: "970d28f4dd477bc184fbd10b376de753"
|
||||||
@ -54,6 +58,9 @@ In the case of `acl` the key of the map is a glob. If there are no matches in yo
|
|||||||
|
|
||||||
The `content_type` field the key is an extension including the leading dot `.`. If you want to set a content type for files with no extension, set the key to the empty string `""`. If there are no matches for the `content_type` of any file, one will automatically be determined for you.
|
The `content_type` field the key is an extension including the leading dot `.`. If you want to set a content type for files with no extension, set the key to the empty string `""`. If there are no matches for the `content_type` of any file, one will automatically be determined for you.
|
||||||
|
|
||||||
|
In the `content_encoding` field the key is an extension including the leading dot `.`. If you want to set a encoding type for files with no extension, set the key
|
||||||
|
to th empty string `""`. If there are no matches for the `content_encoding` of a file, no content-encoding header will be added.
|
||||||
|
|
||||||
The `metadata` field can be set as either an object where the keys are the metadata headers:
|
The `metadata` field can be set as either an object where the keys are the metadata headers:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
|
55
aws.go
55
aws.go
@ -82,6 +82,19 @@ func (a *AWS) Upload(local, remote string) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var contentEncoding string
|
||||||
|
if a.vargs.ContentEncoding.IsString() {
|
||||||
|
contentEncoding = a.vargs.ContentEncoding.String()
|
||||||
|
} else if !a.vargs.ContentEncoding.IsEmpty() {
|
||||||
|
encodingMap := a.vargs.ContentEncoding.Map()
|
||||||
|
for patternExt := range encodingMap {
|
||||||
|
if patternExt == fileExt {
|
||||||
|
contentEncoding = encodingMap[patternExt]
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
metadata := map[string]*string{}
|
metadata := map[string]*string{}
|
||||||
vmap := a.vargs.Metadata.Map()
|
vmap := a.vargs.Metadata.Map()
|
||||||
if len(vmap) > 0 {
|
if len(vmap) > 0 {
|
||||||
@ -108,15 +121,21 @@ func (a *AWS) Upload(local, remote string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
debug("Uploading \"%s\" with Content-Type \"%s\" and permissions \"%s\"", local, contentType, access)
|
debug("\"%s\" not found in bucket, uploading with Content-Type \"%s\" and permissions \"%s\"", local, contentType, access)
|
||||||
_, err = a.client.PutObject(&s3.PutObjectInput{
|
var putObject = &s3.PutObjectInput{
|
||||||
Bucket: aws.String(a.vargs.Bucket),
|
Bucket: aws.String(a.vargs.Bucket),
|
||||||
Key: aws.String(remote),
|
Key: aws.String(remote),
|
||||||
Body: file,
|
Body: file,
|
||||||
ContentType: aws.String(contentType),
|
ContentType: aws.String(contentType),
|
||||||
ACL: aws.String(access),
|
ACL: aws.String(access),
|
||||||
Metadata: metadata,
|
Metadata: metadata,
|
||||||
})
|
}
|
||||||
|
|
||||||
|
if(len(contentEncoding) > 0) {
|
||||||
|
putObject.ContentEncoding = aws.String(contentEncoding)
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = a.client.PutObject(putObject)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -137,6 +156,16 @@ func (a *AWS) Upload(local, remote string) error {
|
|||||||
shouldCopy = true
|
shouldCopy = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if !shouldCopy && head.ContentEncoding == nil && contentEncoding != "" {
|
||||||
|
debug("Content-Encoding has changed from unset to %s", contentEncoding)
|
||||||
|
shouldCopy = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if !shouldCopy && head.ContentEncoding != nil && contentEncoding != *head.ContentEncoding {
|
||||||
|
debug("Content-Encoding has changed from %s to %s", *head.ContentEncoding, contentEncoding)
|
||||||
|
shouldCopy = true
|
||||||
|
}
|
||||||
|
|
||||||
if !shouldCopy && len(head.Metadata) != len(metadata) {
|
if !shouldCopy && len(head.Metadata) != len(metadata) {
|
||||||
debug("Count of metadata values has changed for %s", local)
|
debug("Count of metadata values has changed for %s", local)
|
||||||
shouldCopy = true
|
shouldCopy = true
|
||||||
@ -193,7 +222,7 @@ func (a *AWS) Upload(local, remote string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
debug("Updating metadata for \"%s\" Content-Type: \"%s\", ACL: \"%s\"", local, contentType, access)
|
debug("Updating metadata for \"%s\" Content-Type: \"%s\", ACL: \"%s\"", local, contentType, access)
|
||||||
_, err = a.client.CopyObject(&s3.CopyObjectInput{
|
var copyObject = &s3.CopyObjectInput{
|
||||||
Bucket: aws.String(a.vargs.Bucket),
|
Bucket: aws.String(a.vargs.Bucket),
|
||||||
Key: aws.String(remote),
|
Key: aws.String(remote),
|
||||||
CopySource: aws.String(fmt.Sprintf("%s/%s", a.vargs.Bucket, remote)),
|
CopySource: aws.String(fmt.Sprintf("%s/%s", a.vargs.Bucket, remote)),
|
||||||
@ -201,7 +230,13 @@ func (a *AWS) Upload(local, remote string) error {
|
|||||||
ContentType: aws.String(contentType),
|
ContentType: aws.String(contentType),
|
||||||
Metadata: metadata,
|
Metadata: metadata,
|
||||||
MetadataDirective: aws.String("REPLACE"),
|
MetadataDirective: aws.String("REPLACE"),
|
||||||
})
|
}
|
||||||
|
|
||||||
|
if(len(contentEncoding) > 0) {
|
||||||
|
copyObject.ContentEncoding = aws.String(contentEncoding)
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = a.client.CopyObject(copyObject)
|
||||||
return err
|
return err
|
||||||
} else {
|
} else {
|
||||||
_, err = file.Seek(0, 0)
|
_, err = file.Seek(0, 0)
|
||||||
@ -210,14 +245,20 @@ func (a *AWS) Upload(local, remote string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
debug("Uploading \"%s\" with Content-Type \"%s\" and permissions \"%s\"", local, contentType, access)
|
debug("Uploading \"%s\" with Content-Type \"%s\" and permissions \"%s\"", local, contentType, access)
|
||||||
_, err = a.client.PutObject(&s3.PutObjectInput{
|
var putObject = &s3.PutObjectInput{
|
||||||
Bucket: aws.String(a.vargs.Bucket),
|
Bucket: aws.String(a.vargs.Bucket),
|
||||||
Key: aws.String(remote),
|
Key: aws.String(remote),
|
||||||
Body: file,
|
Body: file,
|
||||||
ContentType: aws.String(contentType),
|
ContentType: aws.String(contentType),
|
||||||
ACL: aws.String(access),
|
ACL: aws.String(access),
|
||||||
Metadata: metadata,
|
Metadata: metadata,
|
||||||
})
|
}
|
||||||
|
|
||||||
|
if(len(contentEncoding) > 0){
|
||||||
|
putObject.ContentEncoding = aws.String(contentEncoding)
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = a.client.PutObject(putObject)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
1
types.go
1
types.go
@ -12,6 +12,7 @@ type PluginArgs struct {
|
|||||||
Delete bool `json:"delete"`
|
Delete bool `json:"delete"`
|
||||||
Access StringMap `json:"acl"`
|
Access StringMap `json:"acl"`
|
||||||
ContentType StringMap `json:"content_type"`
|
ContentType StringMap `json:"content_type"`
|
||||||
|
ContentEncoding StringMap `json:"content_encoding"`
|
||||||
Metadata DeepStringMap `json:"metadata"`
|
Metadata DeepStringMap `json:"metadata"`
|
||||||
Redirects map[string]string `json:"redirects"`
|
Redirects map[string]string `json:"redirects"`
|
||||||
CloudFrontDistribution string `json:"cloudfront_distribution_id"`
|
CloudFrontDistribution string `json:"cloudfront_distribution_id"`
|
||||||
|
Loading…
Reference in New Issue
Block a user