Display local IP addresses

This commit is contained in:
Matéo Duparc 2021-05-04 22:26:36 +02:00
parent d50dd127ba
commit a42f5a2e87
Signed by: hardcoresushi
GPG Key ID: 007F84120107191E
7 changed files with 78 additions and 18 deletions

@ -32,6 +32,7 @@ uuid = {version = "0.8", features = ["v4"]}
webbrowser = "0.5.5" webbrowser = "0.5.5"
libmdns = "0.6" #mDNS advertiser libmdns = "0.6" #mDNS advertiser
multicast_dns = "0.5" #mDNS browser multicast_dns = "0.5" #mDNS browser
pnet_datalink = "0.27.2"
base64 = "0.13.0" base64 = "0.13.0"
time = "0.2.25" time = "0.2.25"
scrypt = "0.7.0" scrypt = "0.7.0"

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="#FILL_COLOR"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z"/></svg>

After

(image error) Size: 233 B

@ -224,21 +224,35 @@ input[type="file"] {
background-color: var(--accent); background-color: var(--accent);
border-radius: 12px; border-radius: 12px;
} }
#refresher {
position: relative;
}
#refresher button {
position: absolute;
right: 10px;
top: 15px;
z-index: 1;
}
#refresher button::after { #refresher button::after {
content: url("/static/imgs/icons/refresh"); content: url("/static/imgs/icons/refresh");
} }
#connect_box { #connect_box {
margin-bottom: 20px; margin-bottom: 20px;
} }
#refresher, #connect_box>div {
position: relative;
}
#show_local_ips, #refresher button {
position: absolute;
right: 10px;
top: 15px;
z-index: 1;
}
#show_local_ips::after {
content: url("/static/imgs/icons/info/52585C");
background-color: unset;
padding: unset;
width: 38px;
height: 38px;
}
#show_local_ips:hover::after {
background-color: unset;
content: url("/static/imgs/icons/info/FF3C00");
}
ul.ips {
list-style-type: unset;
}
#chat_header { #chat_header {
flex-direction: row; flex-direction: row;
align-items: center; align-items: center;

@ -23,6 +23,9 @@
<ul id="offline_sessions"> <ul id="offline_sessions">
</ul> </ul>
<div id="connect_box"> <div id="connect_box">
<div>
<button id="show_local_ips" title="Local IP addresses"></button>
</div>
<p class="section_title">Add a new peer by IP:</p> <p class="section_title">Add a new peer by IP:</p>
<input type="text" id="ip_input" placeholder="Enter IP address"> <input type="text" id="ip_input" placeholder="Enter IP address">
</div> </div>

@ -3,6 +3,7 @@
let identityName = undefined; let identityName = undefined;
let socket = null; let socket = null;
let notificationAllowed = false; let notificationAllowed = false;
let localIps = [];
let currentSessionId = -1; let currentSessionId = -1;
let sessionsData = new Map(); let sessionsData = new Map();
let msgHistory = new Map(); let msgHistory = new Map();
@ -30,6 +31,21 @@ ip_input.addEventListener("keyup", function(event) {
ip_input.value = ""; ip_input.value = "";
} }
}); });
document.getElementById("show_local_ips").onclick = function() {
let mainDiv = document.createElement("div");
let h2Title = document.createElement("h2");
h2Title.textContent = "Your IP addresses:";
mainDiv.appendChild(h2Title);
let ul = document.createElement("ul");
ul.classList.add("ips");
for (let i=0; i<localIps.length; ++i) {
let li = document.createElement("li");
li.textContent = localIps[i];
ul.appendChild(li);
}
mainDiv.appendChild(ul);
showPopup(mainDiv);
}
let message_input = document.getElementById("message_input"); let message_input = document.getElementById("message_input");
message_input.addEventListener("keyup", function(event) { message_input.addEventListener("keyup", function(event) {
if (event.key === "Enter") { if (event.key === "Enter") {
@ -428,6 +444,9 @@ socket.onmessage = function(msg) {
case "not_seen": case "not_seen":
setNotSeen(msg.data.slice(args[0].length+1)); setNotSeen(msg.data.slice(args[0].length+1));
break; break;
case "local_ips":
setLocalIps(msg.data.slice(args[0].length+1));
break;
case "set_name": case "set_name":
onNameSet(msg.data.slice(args[0].length+1)); onNameSet(msg.data.slice(args[0].length+1));
break; break;
@ -465,12 +484,15 @@ function onNameTold(sessionId, name) {
displaySessions(); displaySessions();
} }
function setNotSeen(str_sessionIds) { function setNotSeen(str_sessionIds) {
let sessionIds = str_sessionIds.split(" "); let sessionIds = str_sessionIds.split(' ');
for (let i=0; i<sessionIds.length; ++i) { for (let i=0; i<sessionIds.length; ++i) {
sessionsData.get(sessionIds[i]).seen = false; sessionsData.get(sessionIds[i]).seen = false;
} }
displaySessions(); displaySessions();
} }
function setLocalIps(str_ips) {
localIps = str_ips.split(' ');
}
function onIsContact(sessionId, verified, fingerprint, name) { function onIsContact(sessionId, verified, fingerprint, name) {
if (sessionsData.has(sessionId)) { if (sessionsData.has(sessionId)) {
let session = sessionsData.get(sessionId); let session = sessionsData.get(sessionId);

@ -116,6 +116,15 @@ async fn websocket_worker(mut ui_connection: UiConnection, global_vars: Arc<RwLo
session_manager.get_saved_msgs().into_iter().for_each(|msgs| { session_manager.get_saved_msgs().into_iter().for_each(|msgs| {
ui_connection.load_msgs(&msgs.0, &msgs.1); ui_connection.load_msgs(&msgs.0, &msgs.1);
}); });
let mut ips = Vec::new();
for interface in pnet_datalink::interfaces() {
if !interface.is_loopback() {
for ip in interface.ips {
ips.push(ip.ip());
}
}
}
ui_connection.set_local_ips(ips);
discover_peers(session_manager.clone()); discover_peers(session_manager.clone());
let handle = Handle::current(); let handle = Handle::current();
std::thread::spawn(move || { //new thread needed to block on read_message() without blocking tokio tasks std::thread::spawn(move || { //new thread needed to block on read_message() without blocking tokio tasks
@ -549,6 +558,7 @@ fn handle_static(req: HttpRequest) -> HttpResponse {
"download" => Some(include_str!("frontend/imgs/icons/download.svg")), "download" => Some(include_str!("frontend/imgs/icons/download.svg")),
"cancel" => Some(include_str!("frontend/imgs/icons/cancel.svg")), "cancel" => Some(include_str!("frontend/imgs/icons/cancel.svg")),
"refresh" => Some(include_str!("frontend/imgs/icons/refresh.svg")), "refresh" => Some(include_str!("frontend/imgs/icons/refresh.svg")),
"info" => Some(include_str!("frontend/imgs/icons/info.svg")),
"delete_conversation" => Some(include_str!("frontend/imgs/icons/delete_conversation.svg")), "delete_conversation" => Some(include_str!("frontend/imgs/icons/delete_conversation.svg")),
_ => None _ => None
} { } {

@ -3,7 +3,7 @@ use tungstenite::{WebSocket, protocol::Role, Message};
use crate::{protocol, session_manager::LargeFileDownload}; use crate::{protocol, session_manager::LargeFileDownload};
mod ui_messages { mod ui_messages {
use std::{iter::FromIterator, net::IpAddr, str::from_utf8}; use std::{fmt::Display, iter::FromIterator, net::IpAddr, str::from_utf8};
use tungstenite::Message; use tungstenite::Message;
use uuid::Uuid; use uuid::Uuid;
use crate::{print_error, session_manager::{protocol, LargeFileDownload, FileState}, utils::to_uuid_bytes}; use crate::{print_error, session_manager::{protocol, LargeFileDownload, FileState}, utils::to_uuid_bytes};
@ -11,17 +11,22 @@ mod ui_messages {
const ON_NEW_MESSAGE: &str = "new_message"; const ON_NEW_MESSAGE: &str = "new_message";
const LOAD_SENT_MESSAGE: &str = "load_sent_msg"; const LOAD_SENT_MESSAGE: &str = "load_sent_msg";
fn new_message(verb: &str, session_id: &usize, outgoing: bool, raw_message: &[u8]) -> Option<Message> { fn new_message(command: &str, session_id: &usize, outgoing: bool, raw_message: &[u8]) -> Option<Message> {
match from_utf8(raw_message) { match from_utf8(raw_message) {
Ok(msg) => Some(Message::from(format!("{} {} {} {}", verb, session_id, outgoing, msg))), Ok(msg) => Some(Message::from(format!("{} {} {} {}", command, session_id, outgoing, msg))),
Err(e) => { Err(e) => {
print_error!(e); print_error!(e);
None None
} }
} }
} }
fn simple_event(verb: &str, session_id: &usize) -> Message { fn simple_event(command: &str, session_id: &usize) -> Message {
Message::from(format!("{} {}", verb, session_id)) Message::from(format!("{} {}", command, session_id))
}
fn data_list<T: Display>(command: &str, data: Vec<T>) -> Message {
Message::from(command.to_owned()+&String::from_iter(data.into_iter().map(|i| {
format!(" {}", i)
})))
} }
pub fn on_disconnected(session_id: &usize) -> Message { pub fn on_disconnected(session_id: &usize) -> Message {
@ -91,9 +96,10 @@ mod ui_messages {
} }
} }
pub fn set_not_seen(session_ids: Vec<usize>) -> Message { pub fn set_not_seen(session_ids: Vec<usize>) -> Message {
Message::from("not_seen".to_owned()+&String::from_iter(session_ids.into_iter().map(|session_id| { data_list("not_seen", session_ids)
format!(" {}", session_id) }
}))) pub fn set_local_ips(ips: Vec<IpAddr>) -> Message {
data_list("local_ips", ips)
} }
pub fn on_name_told(session_id: &usize, name: &str) -> Message { pub fn on_name_told(session_id: &usize, name: &str) -> Message {
Message::from(format!("name_told {} {}", session_id, name)) Message::from(format!("name_told {} {}", session_id, name))
@ -183,6 +189,9 @@ impl UiConnection {
pub fn set_not_seen(&mut self, session_ids: Vec<usize>) { pub fn set_not_seen(&mut self, session_ids: Vec<usize>) {
self.write_message(ui_messages::set_not_seen(session_ids)); self.write_message(ui_messages::set_not_seen(session_ids));
} }
pub fn set_local_ips(&mut self, ips: Vec<IpAddr>) {
self.write_message(ui_messages::set_local_ips(ips));
}
pub fn set_name(&mut self, new_name: &str) { pub fn set_name(&mut self, new_name: &str) {
self.write_message(ui_messages::set_name(new_name)); self.write_message(ui_messages::set_name(new_name));
} }