-
Notifications
You must be signed in to change notification settings - Fork 4.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Unable to set charset
when mime-types are guessed (S3)
#1346
Comments
+1 |
2 similar comments
👍 |
👍 |
🐼 |
👍 |
1 similar comment
👍 |
Marking as feature request. Any suggestions on how you would like to see it exposed in the CLI would be appreciated. |
@kyleknap perhaps via |
You can explicitly set For
For
Is this different from want you want? |
@quiver yes it's a bit different; we have client-side app that we're syncing with a multitude of different file types. we'd really like to continue to take advantage of the mime-type guessing feature which saves us from having to batch upload files based on type. |
@gf3 |
@kyleknap just checking in here, anything i can do to help this along? |
+1 |
As a stop-gap, could the default "guessed" MIME type for HTML be changed to |
Any updates on this perhaps? When we use Thanks! |
Running into this problem myself now, trying to sync a bunch of static website files to a bucket and s3cmd is not setting the correct I'd like to keep the deployment job simple by just syncing the directory up the pipe instead of having to define the content-type on a per file-type or file basis. Any way this is now possible? |
As @dmahlow mentioned, you can define the content-type on a per-file-type basis. Just to illustrate what that might look like:
|
Good Morning! We're closing this issue here on GitHub, as part of our migration to UserVoice for feature requests involving the AWS CLI. This will let us get the most important features to you, by making it easier to search for and show support for the features you care the most about, without diluting the conversation with bug reports. As a quick UserVoice primer (if not already familiar): after an idea is posted, people can vote on the ideas, and the product team will be responding directly to the most popular suggestions. We’ve imported existing feature requests from GitHub - Search for this issue there! And don't worry, this issue will still exist on GitHub for posterity's sake. As it’s a text-only import of the original post into UserVoice, we’ll still be keeping in mind the comments and discussion that already exist here on the GitHub issue. GitHub will remain the channel for reporting bugs. Once again, this issue can now be found by searching for the title on: https://aws.uservoice.com/forums/598381-aws-command-line-interface -The AWS SDKs & Tools Team |
Based on community feedback, we have decided to return feature requests to GitHub issues. |
Thanks to @perennialmind's comment for a reasonable work around. Would be nice to be able to specify mappings of some kind, though, to avoid finicky configs like this. |
@gf3 First of all, the NERVE of appearing in my ONLINE EXPERIENCE. How dare you. Second: the aws-cli/awscli/customizations/s3/utils.py Line 294 in 072688c
My Python environment is hosed, but I'll take a run at a patch unless somebody beats me to it. There's an argument to be made that it isn't |
Alright, so https://github.com/aws/aws-cli/compare/develop...pnc:libmagic?expand=1 However, it:
Leaving it for posterity in case someone wants to pick up the torch, but this doesn't seem super viable unless someone from the core team encourages it. |
+1 for getting this solved correctly, please! My s3 copy commands are littered with include and exclude statements now 👎... looking very similar to justatheory's |
Still an issue, I've updated my blog publish script from the broken link above to this script. Sure wish I could specify mappings explicitly and call it once! |
This is still an issue in the v2 cli, it's a real pain! I don't think the current default is sensible. I understand the compatibility impact in updating this, but please put this behind a feature flag at least. |
Discovered this issue today in our codebase. |
+1 |
Hi guys, this works for my python script. from awscli.clidriver import create_clidriver
from awscli.customizations.s3 import utils
def on_queued_charset(self, future, **kwargs):
guessed_type = utils.guess_content_type(self._get_filename(future))
if not guessed_type:
return
if "text/" in guessed_type or "application/" in guessed_type or guessed_type == 'image/svg+xml':
guessed_type += ";charset=UTF-8"
future.meta.call_args.extra_args["ContentType"] = guessed_type
utils.BaseProvideContentTypeSubscriber.on_queued = on_queued_charset
driver = create_clidriver()
old_stdout = sys.stdout
old_stderr = sys.stderr
sys.stdout = cli_stdout = StringIO()
sys.stderr = cli_stderr = StringIO()
args = [
"s3",
"sync",
"local_dir",
"s3://bucket",
"--region=us-east-2",
"--delete",
]
cli_status = driver.main(args)
sys.stdout = old_stdout
sys.stderr = old_stderr
print(cli_stdout.getvalue(), cli_stderr.getvalue()) |
We are syncing a directory of various file types to an S3 bucket and
aws-cli
is correctly guessing the mime-types, however in our case it's important that it also append thecharset
. For example the guessed content-type forindex.html
might look like this:But we'd like a way to be able to tell
aws-cli
that thecharset
for all the synced files isUTF8
for instance:Version:
aws-cli/1.7.26 Python/2.7.6 Darwin/14.4.0
The text was updated successfully, but these errors were encountered: