281 lines
7.6 KiB
Rust
281 lines
7.6 KiB
Rust
use super::types::*;
|
|
|
|
impl ClientHello {
|
|
fn new(name: String, exp_ver: f32) -> Self {
|
|
ClientHello {
|
|
name: name,
|
|
expected_version: exp_ver,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl FcpRequest for ClientHello {
|
|
fn parse(&self) -> String {
|
|
return format!(
|
|
"ClientHello\n\
|
|
Name={}\n\
|
|
ExpectedVersion={}\n\
|
|
EndMessage\n\n",
|
|
self.name, self.expected_version
|
|
);
|
|
}
|
|
}
|
|
|
|
pub struct ClientHello {
|
|
name: String,
|
|
expected_version: f32,
|
|
}
|
|
|
|
#[test]
|
|
fn client_hello_parses() {
|
|
let hello = ClientHello::new("user name".to_string(), 2.0);
|
|
assert_eq!(
|
|
hello.parse(),
|
|
"ClientHello\nName=user name\nExpectedVersion=2\nEndMessage\n\n"
|
|
);
|
|
}
|
|
|
|
// TODO not implemented ListPeer
|
|
pub struct ListPeer {
|
|
message_name: String,
|
|
node_identifier: NodeIdentifier,
|
|
with_volatile: Option<bool>,
|
|
with_metadata: Option<bool>,
|
|
}
|
|
pub struct ListPeers {
|
|
message_name: String,
|
|
with_volatile: Option<bool>,
|
|
with_metadata: Option<bool>,
|
|
}
|
|
|
|
pub struct ListPeerNotes {
|
|
message_name: String,
|
|
node_identifier: NodeIdentifier,
|
|
}
|
|
pub struct AddPeer {
|
|
message_name: String,
|
|
trust: TrustLevel,
|
|
visibility: VisibilityLevel,
|
|
file: Option<String>,
|
|
url: Option<String>,
|
|
raw: Option<String>,
|
|
}
|
|
pub struct ModifyPeer {
|
|
message_name: String,
|
|
node_identifier: NodeIdentifier,
|
|
allow_local_addresses: Option<bool>,
|
|
is_disabled: Option<bool>,
|
|
is_listen_only: Option<bool>,
|
|
is_burst_only: Option<bool>,
|
|
ignore_source_port: Option<bool>,
|
|
}
|
|
pub struct ModifyPeerNote {
|
|
message_name: String,
|
|
node_text: String,
|
|
peer_note_type: i32,
|
|
}
|
|
pub struct RemovePeer {
|
|
message_name: String,
|
|
node_identifier: NodeIdentifier,
|
|
}
|
|
|
|
pub struct GetNode {
|
|
message_name: String,
|
|
identifier: Option<bool>,
|
|
give_opennet_ref: Option<bool>,
|
|
with_private: Option<bool>,
|
|
with_volatile: Option<bool>,
|
|
}
|
|
|
|
pub struct GenerateSSK {
|
|
message_name: String,
|
|
identifier: Option<String>,
|
|
}
|
|
|
|
pub struct ClientPut {
|
|
uri: String, //TODO create key type
|
|
data_length: u64,
|
|
filename: String,
|
|
content_type: Option<String>,
|
|
identifier: Option<String>,
|
|
verbosity: Option<VerbosityPut>,
|
|
max_retries: Option<Retry>,
|
|
priority_class: Option<i8>,
|
|
get_chk_only: Option<bool>,
|
|
global: Option<bool>,
|
|
dont_compress: Option<bool>,
|
|
codecs: Option<Vec<String>>,
|
|
client_token: Option<String>,
|
|
persistence: Option<Box<OsStr>>,
|
|
early_encode: Option<bool>,
|
|
upload_ffrom: Option<UploadForm>,
|
|
target_uri: Option<String>, // cloning uri if does not exists
|
|
file_hash: Option<String>, //TODO SHAA256 type
|
|
binary_blob: Option<bool>,
|
|
fork_on_cacheable: Option<bool>,
|
|
extra_inserts_single_block: Option<u32>,
|
|
extra_inserts_splitfile_header_block: Option<u32>,
|
|
compatibility_mode: Option<String>, //TODO create enum???
|
|
local_request_only: Option<bool>,
|
|
override_splitfile_crypto_key: Option<String>, //key in hex
|
|
real_time_flag: Option<String>,
|
|
metadata_threshold: Option<i64>,
|
|
data: Option<String>, // Data fromdirect
|
|
}
|
|
/*
|
|
impl FcpRequest for ClientPut {
|
|
fn parse(self) -> String {
|
|
format!(
|
|
"ClientPut\n\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
{}\
|
|
EndMessage\n\
|
|
{}\
|
|
",
|
|
self.uri,
|
|
self.data_length,
|
|
self.filename,
|
|
self.content_type.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.verbosity.unwrap_or("".to_string()),
|
|
self.max_retries.unwrap_or("".to_string()),
|
|
self.priority_class.unwrap_or("".to_string()),
|
|
self.get_chk_only.unwrap_or("".to_string()),
|
|
self.global.unwrap_or("".to_string()),
|
|
self.dont_compress.unwrap_or("".to_string()),
|
|
self.codecs.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
self.identifier.unwrap_or("".to_string()),
|
|
)
|
|
}
|
|
}*/
|
|
|
|
pub fn default_unwrap<T: FcpRequest>(fcp_type: Option<&T>) -> String {
|
|
match fcp_type {
|
|
Some(val) => val.parse(),
|
|
None => String::from(""),
|
|
}
|
|
}
|
|
impl FcpRequest for String {
|
|
fn parse(&self) -> String {
|
|
self.to_string()
|
|
}
|
|
}
|
|
|
|
impl FcpRequest for bool {
|
|
fn parse(&self) -> String {
|
|
if *self {
|
|
"true".to_string()
|
|
} else {
|
|
"false".to_string()
|
|
}
|
|
}
|
|
}
|
|
|
|
impl FcpRequest for VerbosityPut {
|
|
fn parse(&self) -> String {
|
|
match self {
|
|
VerbosityPut::SimpleProgress => 0.to_string(),
|
|
VerbosityPut::ExpectedHashes => 3.to_string(),
|
|
VerbosityPut::PutFetchable => 8.to_string(),
|
|
VerbosityPut::StartedCompressionANDFinishedCompression => 9.to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn is_berbosity_put_parsing() {
|
|
assert_eq!(default_unwrap::<VerbosityPut>(None), "".to_string());
|
|
assert_eq!(
|
|
default_unwrap::<VerbosityPut>(Some(&VerbosityPut::SimpleProgress)),
|
|
"0".to_string()
|
|
);
|
|
assert_eq!(
|
|
default_unwrap::<VerbosityPut>(Some(&VerbosityPut::ExpectedHashes)),
|
|
"3".to_string()
|
|
);
|
|
assert_eq!(
|
|
default_unwrap::<VerbosityPut>(Some(&VerbosityPut::PutFetchable)),
|
|
"8".to_string()
|
|
);
|
|
assert_eq!(
|
|
default_unwrap::<VerbosityPut>(Some(
|
|
&VerbosityPut::StartedCompressionANDFinishedCompression
|
|
)),
|
|
"9".to_string()
|
|
);
|
|
}
|
|
|
|
pub struct ClientGet {
|
|
message_name: String,
|
|
ignore_ds: Option<bool>,
|
|
ds_only: Option<bool>,
|
|
uri: String, //FIXME freenet uri type
|
|
identifier: String,
|
|
verbosity: Option<VerbosityGet>,
|
|
max_size: Option<u32>,
|
|
max_retries: Option<NumOrNone>,
|
|
priority_class: Option<Priority>,
|
|
persistence: Option<Persistence>,
|
|
client_token: Option<String>,
|
|
global: Option<bool>,
|
|
return_type: Option<ReturnType>,
|
|
binary_blob: Option<bool>,
|
|
filter_data: Option<bool>,
|
|
allowed_mime_types: Option<Vec<String>>,
|
|
filename: Option<Box<Path>>,
|
|
temp_filename: Option<Box<Path>>,
|
|
real_time_flag: Option<bool>,
|
|
initial_metadata_data_length: u64,
|
|
}
|
|
|
|
pub struct Disconnect {
|
|
message_name: String,
|
|
}
|
|
|
|
pub struct Shutdown {
|
|
message_name: String,
|
|
}
|