Add support for BEP 39.

Add update-url field to info struct.

See BEP 39 for more details:
http://bittorrent.org/beps/bep_0039.html

type: added
fixes:
- https://github.com/casey/intermodal/issues/98
This commit is contained in:
Annie Cherkaev 2020-04-27 17:03:58 -07:00 committed by Casey Rodarmor
parent d077da405e
commit f1514dd301
No known key found for this signature in database
GPG Key ID: 556186B153EC6FE0
6 changed files with 91 additions and 3 deletions

View File

@ -2,9 +2,10 @@ Changelog
========= =========
UNRELEASED - 2020-04-25 UNRELEASED - 2020-04-28
----------------------- -----------------------
- :books: [`xxxxxxxxxxxx`](https://github.com/casey/intermodal/commits/master) Improve documentation - _Casey Rodarmor <casey@rodarmor.com>_ - :sparkles: [`xxxxxxxxxxxx`](https://github.com/casey/intermodal/commits/master) Add support for BEP 39. - Fixes [#98](https://github.com/casey/intermodal/issues/98) - _Annie Cherkaev <annie.cherk@gmail.com>_
- :books: [`d077da405e1f`](https://github.com/casey/intermodal/commit/d077da405e1f50e4b1f2dc78cf821105640c9110) Improve documentation - _Casey Rodarmor <casey@rodarmor.com>_
- :wrench: [`f8711a79a3d9`](https://github.com/casey/intermodal/commit/f8711a79a3d92da5b30fd3e8b7bba7a5e2d73766) Improve the done and merge recipes - _Casey Rodarmor <casey@rodarmor.com>_ - :wrench: [`f8711a79a3d9`](https://github.com/casey/intermodal/commit/f8711a79a3d92da5b30fd3e8b7bba7a5e2d73766) Improve the done and merge recipes - _Casey Rodarmor <casey@rodarmor.com>_
- :wrench: [`97ee5684f8e0`](https://github.com/casey/intermodal/commit/97ee5684f8e0f8de7dbdb4f930018c8df0f012b1) Don't invalid build cache when `Cargo.lock` changes - _Casey Rodarmor <casey@rodarmor.com>_ - :wrench: [`97ee5684f8e0`](https://github.com/casey/intermodal/commit/97ee5684f8e0f8de7dbdb4f930018c8df0f012b1) Don't invalid build cache when `Cargo.lock` changes - _Casey Rodarmor <casey@rodarmor.com>_
- :books: [`c75ec39b14bb`](https://github.com/casey/intermodal/commit/c75ec39b14bb4375a875d2d2c73718b44eb54e12) Remove watch dropdown image from readme - _Casey Rodarmor <casey@rodarmor.com>_ - :books: [`c75ec39b14bb`](https://github.com/casey/intermodal/commit/c75ec39b14bb4375a875d2d2c73718b44eb54e12) Remove watch dropdown image from readme - _Casey Rodarmor <casey@rodarmor.com>_

View File

@ -20,6 +20,13 @@ pub(crate) struct Info {
pub(crate) pieces: PieceList, pub(crate) pieces: PieceList,
#[serde(flatten)] #[serde(flatten)]
pub(crate) mode: Mode, pub(crate) mode: Mode,
#[serde(
skip_serializing_if = "Option::is_none",
default,
with = "unwrap_or_skip",
rename = "update-url"
)]
pub(crate) update_url: Option<String>,
} }
impl Info { impl Info {

View File

@ -1,7 +1,7 @@
use crate::common::*; use crate::common::*;
// Systems with pointers larger than 64 bits may eventually exist, but // Systems with pointers larger than 64 bits may eventually exist, but
// for now let's assume that usize is at most 32 bits, and document that // for now let's assume that usize is at most 64 bits, and document that
// assumption with this assert. // assumption with this assert.
const_assert!(std::mem::size_of::<usize>() <= std::mem::size_of::<u64>()); const_assert!(std::mem::size_of::<usize>() <= std::mem::size_of::<u64>());

View File

@ -143,6 +143,7 @@ mod tests {
length: Bytes(20), length: Bytes(20),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };
@ -176,6 +177,7 @@ mod tests {
md5sum: Some(Md5Digest::from_hex("000102030405060708090a0b0c0d0e0f")), md5sum: Some(Md5Digest::from_hex("000102030405060708090a0b0c0d0e0f")),
}], }],
}, },
update_url: None,
}, },
}; };
@ -224,6 +226,7 @@ mod tests {
length: Bytes(5), length: Bytes(5),
md5sum: Some(Md5Digest::from_hex("000102030405060708090a0b0c0d0e0f")), md5sum: Some(Md5Digest::from_hex("000102030405060708090a0b0c0d0e0f")),
}, },
update_url: None,
}, },
}; };
@ -279,6 +282,7 @@ mod tests {
length: Bytes(5), length: Bytes(5),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };
@ -321,6 +325,7 @@ mod tests {
path: FilePath::from_components(&["a", "b"]), path: FilePath::from_components(&["a", "b"]),
}], }],
}, },
update_url: None,
}, },
}; };
@ -369,6 +374,7 @@ mod tests {
path: FilePath::from_components(&["a", "b"]), path: FilePath::from_components(&["a", "b"]),
}], }],
}, },
update_url: None,
}, },
}; };
@ -413,6 +419,7 @@ mod tests {
length: Bytes(5), length: Bytes(5),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };
@ -453,6 +460,7 @@ mod tests {
length: Bytes(5), length: Bytes(5),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };

View File

@ -266,6 +266,14 @@ Sort in ascending order by size, break ties in descending path order:
--get core.excludesFile`." --get core.excludesFile`."
)] )]
ignore: bool, ignore: bool,
#[structopt(
long = "update-url",
value_name = "URL",
help = "Set torrent feed URL to `URL`, stored in the `update-url` key of the info dictionary. \
Clients that support BEP 39 will use the update URL to download revised versions of \
the torret's metainfo. Note that BEP 39 is not widely supported."
)]
update_url: Option<Url>,
} }
impl Create { impl Create {
@ -380,6 +388,7 @@ impl Create {
mode, mode,
pieces, pieces,
private, private,
update_url: self.update_url.map(|url| url.to_string()),
}; };
let metainfo = Metainfo { let metainfo = Metainfo {
@ -3123,4 +3132,63 @@ Content Size 9 bytes
assert_eq!(env.out(), ""); assert_eq!(env.out(), "");
assert_eq!(env.err(), ""); assert_eq!(env.err(), "");
} }
#[test]
fn test_update_url_invalid_url_fails() {
let mut env = test_env! {
args: [
"torrent",
"create",
"--update-url",
"not-a-URL",
"--input",
"foo"
],
tree: {
foo: "",
}
};
assert_matches!(env.run(), Err(Error::Clap { .. }));
}
#[test]
fn test_update_url_valid_url_succeeds() {
let mut env = test_env! {
args: [
"torrent",
"create",
"--update-url",
"https://www.a_real_url.com",
"--input",
"foo"
],
tree: {
foo: "",
}
};
env.assert_ok();
}
#[test]
fn test_update_url() {
let mut env = test_env! {
args: [
"torrent",
"create",
"--update-url",
"https://www.a_real_url.com",
"--input",
"foo",
],
tree: {
foo: "",
}
};
env.assert_ok();
let metainfo = env.load_metainfo("foo.torrent");
assert_eq!(
metainfo.info.update_url.as_deref(),
Some("https://www.a_real_url.com/")
);
}
} }

View File

@ -133,6 +133,7 @@ mod tests {
length: Bytes(20), length: Bytes(20),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };
@ -273,6 +274,7 @@ files\tfoo
length: Bytes(20), length: Bytes(20),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };
@ -375,6 +377,7 @@ files\tfoo
length: Bytes(20), length: Bytes(20),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };
@ -477,6 +480,7 @@ files\tfoo
length: Bytes(20), length: Bytes(20),
md5sum: None, md5sum: None,
}, },
update_url: None,
}, },
}; };