mirror of
https://github.com/nushell/nushell
synced 2025-01-14 06:04:09 +00:00
Add support for downloading unsupported mime types (#1441)
This commit is contained in:
parent
8d38743e27
commit
2a8cb24309
1 changed files with 26 additions and 1 deletions
|
@ -53,7 +53,7 @@ pub async fn fetch_helper(path: &Value, has_raw: bool, row: Value) -> ReturnValu
|
||||||
|
|
||||||
let path_span = path.tag.span;
|
let path_span = path.tag.span;
|
||||||
|
|
||||||
let result = fetch(&path_str, path_span).await;
|
let result = fetch(&path_str, path_span, has_raw).await;
|
||||||
|
|
||||||
if let Err(e) = result {
|
if let Err(e) = result {
|
||||||
return Err(e);
|
return Err(e);
|
||||||
|
@ -83,6 +83,7 @@ pub async fn fetch_helper(path: &Value, has_raw: bool, row: Value) -> ReturnValu
|
||||||
pub async fn fetch(
|
pub async fn fetch(
|
||||||
location: &str,
|
location: &str,
|
||||||
span: Span,
|
span: Span,
|
||||||
|
has_raw: bool,
|
||||||
) -> Result<(Option<String>, UntaggedValue, Tag), ShellError> {
|
) -> Result<(Option<String>, UntaggedValue, Tag), ShellError> {
|
||||||
if url::Url::parse(location).is_err() {
|
if url::Url::parse(location).is_err() {
|
||||||
return Err(ShellError::labeled_error(
|
return Err(ShellError::labeled_error(
|
||||||
|
@ -227,6 +228,30 @@ pub async fn fetch(
|
||||||
},
|
},
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
(_ty, _sub_ty) if has_raw => {
|
||||||
|
let raw_bytes = r.body_bytes().await?;
|
||||||
|
|
||||||
|
// For unsupported MIME types, we do not know if the data is UTF-8,
|
||||||
|
// so we get the raw body bytes and try to convert to UTF-8 if possible.
|
||||||
|
match std::str::from_utf8(&raw_bytes) {
|
||||||
|
Ok(response_str) => Ok((
|
||||||
|
None,
|
||||||
|
UntaggedValue::string(response_str),
|
||||||
|
Tag {
|
||||||
|
span,
|
||||||
|
anchor: Some(AnchorLocation::Url(location.to_string())),
|
||||||
|
},
|
||||||
|
)),
|
||||||
|
Err(_) => Ok((
|
||||||
|
None,
|
||||||
|
UntaggedValue::binary(raw_bytes),
|
||||||
|
Tag {
|
||||||
|
span,
|
||||||
|
anchor: Some(AnchorLocation::Url(location.to_string())),
|
||||||
|
},
|
||||||
|
)),
|
||||||
|
}
|
||||||
|
}
|
||||||
(ty, sub_ty) => Ok((
|
(ty, sub_ty) => Ok((
|
||||||
None,
|
None,
|
||||||
UntaggedValue::string(format!(
|
UntaggedValue::string(format!(
|
||||||
|
|
Loading…
Reference in a new issue