1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
use crate::prelude::*; use nu_engine::WholeStreamCommand; use nu_errors::ShellError; use nu_protocol::{Signature, TaggedDictBuilder, UntaggedValue}; pub struct FromUrl; impl WholeStreamCommand for FromUrl { fn name(&self) -> &str { "from url" } fn signature(&self) -> Signature { Signature::build("from url") } fn usage(&self) -> &str { "Parse url-encoded string as a table." } fn run(&self, args: CommandArgs) -> Result<OutputStream, ShellError> { from_url(args) } } fn from_url(args: CommandArgs) -> Result<OutputStream, ShellError> { let tag = args.name_tag(); let input = args.input; let concat_string = input.collect_string(tag.clone())?; let result = serde_urlencoded::from_str::<Vec<(String, String)>>(&concat_string.item); match result { Ok(result) => { let mut row = TaggedDictBuilder::new(tag); for (k, v) in result { row.insert_untagged(k, UntaggedValue::string(v)); } Ok(OutputStream::one(row.into_value())) } _ => Err(ShellError::labeled_error_with_secondary( "String not compatible with url-encoding", "input not url-encoded", tag, "value originates from here", concat_string.tag, )), } } #[cfg(test)] mod tests { use super::FromUrl; use super::ShellError; #[test] fn examples_work_as_expected() -> Result<(), ShellError> { use crate::examples::test as test_examples; test_examples(FromUrl {}) } }