forked from M-Labs/ionpak-thermostat
support setting IP address via web interface
This commit is contained in:
parent
1a06b524d2
commit
5c1cacbd38
@ -11,7 +11,7 @@ use core::cell::{Cell, RefCell};
|
||||
use core::fmt;
|
||||
use cortex_m::interrupt::Mutex;
|
||||
use smoltcp::Error;
|
||||
use smoltcp::wire::{EthernetAddress, IpAddress};
|
||||
use smoltcp::wire::EthernetAddress;
|
||||
use smoltcp::iface::{ArpCache, SliceArpCache, EthernetInterface};
|
||||
use smoltcp::socket::{AsSocket, SocketSet};
|
||||
use smoltcp::socket::{TcpSocket, TcpSocketBuffer};
|
||||
@ -156,7 +156,7 @@ fn main() {
|
||||
println!("programmed MAC address is invalid, using default");
|
||||
hardware_addr = EthernetAddress([0x10, 0xE2, 0xD5, 0x00, 0x03, 0x00]);
|
||||
}
|
||||
let mut protocol_addrs = [IpAddress::v4(192, 168, 69, 1)];
|
||||
let mut protocol_addrs = [config.ip];
|
||||
println!("MAC {} IP {}", hardware_addr, protocol_addrs[0]);
|
||||
let mut arp_cache_entries: [_; 8] = Default::default();
|
||||
let mut arp_cache = SliceArpCache::new(&mut arp_cache_entries[..]);
|
||||
@ -220,7 +220,7 @@ fn main() {
|
||||
match request_status {
|
||||
Ok(true) => {
|
||||
if socket.can_send() {
|
||||
pages::serve(socket, &request, &LOOP_ANODE, &LOOP_CATHODE, &ELECTROMETER);
|
||||
pages::serve(socket, &request, &mut config, &LOOP_ANODE, &LOOP_CATHODE, &ELECTROMETER);
|
||||
}
|
||||
request.reset();
|
||||
socket.close();
|
||||
|
39
firmware/src/network_settings.html
Normal file
39
firmware/src/network_settings.html
Normal file
@ -0,0 +1,39 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<title>ionpak</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<link rel="stylesheet" href="style.css">
|
||||
<body>
|
||||
|
||||
<div class="w3-sidebar w3-light-grey w3-bar-block" style="width:15%">
|
||||
<h3 class="w3-bar-item"><img src="logo.svg"></h3>
|
||||
<a href="/" class="w3-bar-item w3-button">Measure</a>
|
||||
<a href="/gauge_settings.html" class="w3-bar-item w3-button">Gauge settings</a>
|
||||
<a href="/network_settings.html" class="w3-bar-item w3-button">Network settings</a>
|
||||
<a href="/firmware.html" class="w3-bar-item w3-button">Firmware</a>
|
||||
</div>
|
||||
|
||||
<div style="margin-left:15%">
|
||||
|
||||
<div class="w3-container w3-teal">
|
||||
<h1>Network settings</h1>
|
||||
</div>
|
||||
|
||||
<div class="w3-container">
|
||||
<p>{status}</p>
|
||||
</div>
|
||||
|
||||
<div class="w3-container">
|
||||
<form class="w3-container w3-card-4" method="GET">
|
||||
<p>
|
||||
<label>IP address</label>
|
||||
<input class="w3-input w3-border" name="ip" type="text" value="{ip}"></p>
|
||||
<p>
|
||||
<button class="w3-btn w3-blue">Update</button></p>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</body>
|
||||
</html>
|
@ -1,11 +1,13 @@
|
||||
use core::fmt;
|
||||
use core::fmt::Write;
|
||||
use core::cell::RefCell;
|
||||
use core::str;
|
||||
use cortex_m;
|
||||
use cortex_m::interrupt::Mutex;
|
||||
use smoltcp::socket::TcpSocket;
|
||||
|
||||
use http;
|
||||
use config;
|
||||
use loop_anode;
|
||||
use loop_cathode;
|
||||
use electrometer;
|
||||
@ -31,6 +33,7 @@ impl fmt::LowerExp for OpnFmt {
|
||||
}
|
||||
|
||||
pub fn serve(output: &mut TcpSocket, request: &http::Request,
|
||||
config: &mut config::Config,
|
||||
loop_anode_m: &Mutex<RefCell<loop_anode::Controller>>,
|
||||
loop_cathode_m: &Mutex<RefCell<loop_cathode::Controller>>,
|
||||
electrometer_m: &Mutex<RefCell<electrometer::Electrometer>>) {
|
||||
@ -61,6 +64,31 @@ pub fn serve(output: &mut TcpSocket, request: &http::Request,
|
||||
cathode_fbv=OpnFmt(cathode.fbv),
|
||||
ion_current=OpnFmt(electrometer.ic.and_then(|x| Some(x*1.0e9)))).unwrap();
|
||||
},
|
||||
b"/network_settings.html" => {
|
||||
let mut status = "";
|
||||
|
||||
let ip_arg = request.get_arg(b"ip");
|
||||
if ip_arg.is_ok() {
|
||||
let ip_arg = str::from_utf8(ip_arg.unwrap());
|
||||
if ip_arg.is_ok() {
|
||||
let ip = ip_arg.unwrap().parse();
|
||||
if ip.is_ok() {
|
||||
let ip = ip.unwrap();
|
||||
status = "IP address has been updated and will be active after a reboot.";
|
||||
config.ip = ip;
|
||||
config.save();
|
||||
} else {
|
||||
status = "failed to parse IP address";
|
||||
}
|
||||
} else {
|
||||
status = "IP address contains an invalid UTF-8 character";
|
||||
}
|
||||
}
|
||||
|
||||
http::write_reply_header(output, 200, "text/html; charset=utf-8", false).unwrap();
|
||||
write!(output, include_str!("network_settings.html"),
|
||||
status=status, ip=config.ip).unwrap();
|
||||
},
|
||||
b"/firmware.html" => {
|
||||
http::write_reply_header(output, 200, "text/html; charset=utf-8", false).unwrap();
|
||||
write!(output, include_str!("firmware.html"),
|
||||
|
Loading…
Reference in New Issue
Block a user