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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
use crate::primitive::{StringList, Variant, VariantMap};
use crate::HandshakeSerialize;
use failure::Error;
/// ClientInit is the Initial message send to the core after establishing a base layer comunication.
///
/// Features
///
/// | Flag | Name | Description |
/// | ---- | ---- | ----------- |
/// | 0x00000001 | SynchronizedMarkerLine | -- |
/// | 0x00000002 | SaslAuthentication | -- |
/// | 0x00000004 | SaslExternal | -- |
/// | 0x00000008 | HideInactiveNetworks | -- |
/// | 0x00000010 | PasswordChange | -- |
/// | 0x00000020 | CapNegotiation | IRCv3 capability negotiation, account tracking |
/// | 0x00000040 | VerifyServerSSL | IRC server SSL validation |
/// | 0x00000080 | CustomRateLimits | IRC server custom message rate limits |
/// | 0x00000100 | DccFileTransfer | Currently not supported |
/// | 0x00000200 | AwayFormatTimestamp | Timestamp formatting in away (e.g. %%hh:mm%%) |
/// | 0x00000400 | Authenticators | Support for exchangeable auth backends |
/// | 0x00000800 | BufferActivitySync | Sync buffer activity status |
/// | 0x00001000 | CoreSideHighlights | Core-Side highlight configuration and matching |
/// | 0x00002000 | SenderPrefixes | Show prefixes for senders in backlog |
/// | 0x00004000 | RemoteDisconnect | Supports RPC call disconnectFromCore to remotely disconnect a client |
/// | 0x00008000 | ExtendedFeatures | Transmit features as list of strings |
/// | -- | LongTime | Serialize message time as 64-bit |
/// | -- | RichMessages | Real Name and Avatar URL in backlog |
/// | -- | BacklogFilterType | Backlogmanager supports filtering backlog by messagetype |
/// | -- | EcdsaCertfpKeys | ECDSA keys for CertFP in identities |
/// | -- | LongMessageId | 64-bit IDs for messages |
/// | -- | SyncedCoreInfo | CoreInfo dynamically updated using signals |
#[derive(Debug, Clone)]
pub struct ClientInit {
/// Version of the client
pub client_version: String,
/// Build date of the client
pub client_date: String,
/// supported features as bitflags
pub client_features: u32,
/// List of supported extended features
pub feature_list: StringList,
}
impl HandshakeSerialize for ClientInit {
fn serialize(&self) -> Result<Vec<u8>, Error> {
let mut values: VariantMap = VariantMap::with_capacity(5);
values.insert(
"MsgType".to_string(),
Variant::String("ClientInit".to_string()),
);
values.insert(
"ClientVersion".to_string(),
Variant::String(self.client_version.clone()),
);
values.insert(
"ClientDate".to_string(),
Variant::String(self.client_date.clone()),
);
values.insert("Features".to_string(), Variant::u32(self.client_features));
values.insert(
"FeatureList".to_string(),
Variant::StringList(self.feature_list.clone()),
);
return HandshakeSerialize::serialize(&values);
}
}
impl From<VariantMap> for ClientInit {
fn from(input: VariantMap) -> Self {
ClientInit {
client_version: match_variant!(input.get("ClientVersion").unwrap(), Variant::String),
client_date: match_variant!(input.get("ClientDate").unwrap(), Variant::String),
client_features: match_variant!(input.get("Features").unwrap(), Variant::u32),
feature_list: match_variant!(input.get("FeatureList").unwrap(), Variant::StringList),
}
}
}
|