add tnoe, begin home node rewrite
This commit is contained in:
parent
44e490cf46
commit
4a555dc180
5 changed files with 409 additions and 0 deletions
55
pi/homemgmt.spl
Normal file
55
pi/homemgmt.spl
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
"#time.spl" import
|
||||||
|
|
||||||
|
"home node management" =program-name
|
||||||
|
|
||||||
|
def remote, revpfwkey
|
||||||
|
|
||||||
|
"revpfw.spl" import
|
||||||
|
"network.spl" import
|
||||||
|
|
||||||
|
"tudbut.de" =remote
|
||||||
|
"REVPFWKEY" env:get =revpfwkey
|
||||||
|
|
||||||
|
func panic-handler { |
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func main { exitcode | with args ;
|
||||||
|
"management system starting up." println
|
||||||
|
"init revpfw subsystem" println
|
||||||
|
&revpfw-watcher fork
|
||||||
|
1000 time:sleep;
|
||||||
|
"init ircbot subsystem" println
|
||||||
|
&ircbot-watcher fork
|
||||||
|
1000 time:sleep;
|
||||||
|
"init network monitor subsystem" println
|
||||||
|
&network-monitor fork
|
||||||
|
1000 time:sleep;
|
||||||
|
}
|
||||||
|
|
||||||
|
func watcher { | with statevar update delay ;
|
||||||
|
while { statevar call =>? [ ^ok &pop ] } {
|
||||||
|
def sa time:unixms =sa
|
||||||
|
update call
|
||||||
|
delay (time:unixms sa -) - dup 0 lt if { pop 0 } time:sleep;
|
||||||
|
}
|
||||||
|
:sjson<0> panic
|
||||||
|
}
|
||||||
|
|
||||||
|
func revpfw-watcher { |
|
||||||
|
[ ^ok ^down ] =revpfw-state
|
||||||
|
&revpfw-state &revpfw-update watcher<1000>
|
||||||
|
}
|
||||||
|
|
||||||
|
func ircbot-watcher { |
|
||||||
|
"ircbot -> service disabled" println
|
||||||
|
1 stop
|
||||||
|
|
||||||
|
[ ^ok ^down ] =ircbot-state
|
||||||
|
&ircbot-state &ircbot-update watcher<1000>
|
||||||
|
}
|
||||||
|
|
||||||
|
func network-monitor { |
|
||||||
|
[ ^ok ^up ] =network-state
|
||||||
|
&network-state &network-update watcher<30000>
|
||||||
|
}
|
21
tnoe/tnoegatherer.spl
Normal file
21
tnoe/tnoegatherer.spl
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
"#httpserver/base.spl" import
|
||||||
|
|
||||||
|
func main { exitcode | with args ;
|
||||||
|
def server
|
||||||
|
net:http:Server:new<"::0" 4000> =server
|
||||||
|
"Started listening on ::0:4000" println
|
||||||
|
"ip a:" println
|
||||||
|
|
||||||
|
[ "ip" "a" ] command-wait;
|
||||||
|
|
||||||
|
while { 1 } {
|
||||||
|
server:accept
|
||||||
|
dup :read
|
||||||
|
dup :path println
|
||||||
|
dup :body _str println
|
||||||
|
:write-ok:write-str-body<"">:finish;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
0
|
||||||
|
}
|
194
tnoe/tnoemgmt.spl
Normal file
194
tnoe/tnoemgmt.spl
Normal file
|
@ -0,0 +1,194 @@
|
||||||
|
|
||||||
|
"#stream.spl" import
|
||||||
|
"#time.spl" import
|
||||||
|
"#json.spl" import
|
||||||
|
|
||||||
|
def state, network, connections
|
||||||
|
|
||||||
|
[ ^bring-up ] =state
|
||||||
|
"johlg" =network
|
||||||
|
6 =connections
|
||||||
|
|
||||||
|
include json:_StringyJSON in array
|
||||||
|
|
||||||
|
func panic-handler { |
|
||||||
|
catch IO {
|
||||||
|
"status" StreamTypes:file:create<1>
|
||||||
|
dup :write-exact<[ ^dead [ ^panic ] ] :sjson<0> "\n" concat :to-bytes>
|
||||||
|
:close;
|
||||||
|
} { with e ;
|
||||||
|
"fuck.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main { exitcode | with args ;
|
||||||
|
start-timer =>? ^ok not if {
|
||||||
|
"error " print :sjson<0> print " in state: " state:sjson<0> concat println
|
||||||
|
"error in timers" panic
|
||||||
|
}
|
||||||
|
0
|
||||||
|
}
|
||||||
|
|
||||||
|
func start-timer { result |
|
||||||
|
def sa time:unixms =sa
|
||||||
|
1 while { } {
|
||||||
|
1000 time:unixms sa - - dup 0 lt if { pop 0 } time:sleep;
|
||||||
|
time:unixms =sa
|
||||||
|
|
||||||
|
def v
|
||||||
|
timer-run
|
||||||
|
dup :sjson<0>
|
||||||
|
dup println
|
||||||
|
=v
|
||||||
|
catch IO {
|
||||||
|
"status" StreamTypes:file:create<1>
|
||||||
|
dup :write-exact<v "\n" concat :to-bytes>
|
||||||
|
:close;
|
||||||
|
} {
|
||||||
|
[ ^err "no fs access" "status" ] 3 stop
|
||||||
|
}
|
||||||
|
dup => [ ^reboot &=v ] if {
|
||||||
|
"" println
|
||||||
|
"reboot requested because " v concat "." concat println
|
||||||
|
catch IO {
|
||||||
|
"deny-reboot" read-file "no" eq not if {
|
||||||
|
"reboot denied because deny-reboot is set. need manual help"
|
||||||
|
pop [ ^err "reboot denied" ] 3 stop
|
||||||
|
}
|
||||||
|
} { pop }
|
||||||
|
catch IO {
|
||||||
|
"deny-reboot" StreamTypes:file:create<1>
|
||||||
|
dup :write-exact<"yes" :to-bytes>
|
||||||
|
:close;
|
||||||
|
} {
|
||||||
|
[ ^err "no fs access" "deny-reboot" ] 3 stop
|
||||||
|
}
|
||||||
|
while { 1 } {
|
||||||
|
fork<|
|
||||||
|
"status" StreamTypes:file:create<1>
|
||||||
|
dup :write-exact<[ ^dead v ] :sjson<0> "\n" concat :to-bytes>
|
||||||
|
:close;
|
||||||
|
catch {
|
||||||
|
[ "sudo" "reboot" ] command-wait;
|
||||||
|
} { pop }
|
||||||
|
>
|
||||||
|
5000 time:sleep;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
=>? [ ^ok &pop ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func timer-run { result |
|
||||||
|
def wait-time
|
||||||
|
|
||||||
|
device-present not if {
|
||||||
|
[ ^reboot "device not present" ]
|
||||||
|
2 stop
|
||||||
|
}
|
||||||
|
|
||||||
|
state => [ ^fix-device ] if {
|
||||||
|
fix-device
|
||||||
|
2 stop
|
||||||
|
}
|
||||||
|
|
||||||
|
state => [ ^bring-up ] if {
|
||||||
|
switch-networks =>? [ ^err "nmcli failed" ] if {
|
||||||
|
[ ^fix-device ] =state
|
||||||
|
[ ^ok state ] 3 stop
|
||||||
|
} dup => [ ^ok &pop ] if {
|
||||||
|
3 stop
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
is-network-up not if {
|
||||||
|
[ ^bring-up ] =state
|
||||||
|
[ ^ok state ] 2 stop
|
||||||
|
}
|
||||||
|
|
||||||
|
state => [ ^waiting &=wait-time ] if {
|
||||||
|
wait-time 0 eq if {
|
||||||
|
[ ^bring-up ] =state
|
||||||
|
[ ^ok state ] 3 stop
|
||||||
|
}
|
||||||
|
[ ^waiting wait-time 1 - ] =state
|
||||||
|
[ ^ok state ] 2 stop
|
||||||
|
}
|
||||||
|
|
||||||
|
state => [ ^connecting &=wait-time ] if {
|
||||||
|
is-network-up if {
|
||||||
|
[ ^waiting 60 20 * ] =state
|
||||||
|
catch IO {
|
||||||
|
"deny-reboot" StreamTypes:file:create<1>
|
||||||
|
dup :write-exact<"no" :to-bytes>
|
||||||
|
:close;
|
||||||
|
} {
|
||||||
|
[ ^err "no fs access" "deny-reboot" ] 4 stop
|
||||||
|
}
|
||||||
|
[ ^ok ^connected ] 3 stop
|
||||||
|
}
|
||||||
|
wait-time 0 eq if {
|
||||||
|
[ ^bring-up ] =state
|
||||||
|
[ ^ok state ] 3 stop
|
||||||
|
}
|
||||||
|
[ ^connecting wait-time -- ] =state
|
||||||
|
[ ^ok state ] 2 stop
|
||||||
|
}
|
||||||
|
|
||||||
|
[ ^err "unknown state" state ]
|
||||||
|
}
|
||||||
|
|
||||||
|
func switch-networks { result |
|
||||||
|
[ ^connecting 10 ] =state
|
||||||
|
|
||||||
|
def b
|
||||||
|
random-byte =>? [ ^ok &=b ] not if { 2 stop }
|
||||||
|
|
||||||
|
b connections % =b
|
||||||
|
|
||||||
|
def conn, hostname
|
||||||
|
network b _str concat =conn
|
||||||
|
conn "-hostname" concat read-file :replace<"\n" ""> =hostname
|
||||||
|
|
||||||
|
"connecting to " conn concat " with hostname " concat hostname concat println
|
||||||
|
|
||||||
|
[ "sudo" "hostnamectl" "set-hostname" hostname ] command-wait
|
||||||
|
[ "sudo" "nmcli" "c" "up" conn ] command-wait or
|
||||||
|
if {
|
||||||
|
[ ^err "nmcli failed" ] 2 stop
|
||||||
|
}
|
||||||
|
|
||||||
|
[ ^ok ^connected ]
|
||||||
|
}
|
||||||
|
|
||||||
|
func device-present { bool |
|
||||||
|
[ "lsusb" ] StreamTypes:cmd:create
|
||||||
|
dup :read-to-end<1024>:to-str
|
||||||
|
dup :contains<"0bda:c811"> swap:contains<"0bda:1a2b"> or swap
|
||||||
|
:close
|
||||||
|
}
|
||||||
|
|
||||||
|
func fix-device { result |
|
||||||
|
[ ^bring-up ] =state
|
||||||
|
[ "sudo" "usb_modeswitch" "-v" "0bda" "-p" "1a2b" "-K" ] command-wait;
|
||||||
|
[ ^ok ^fixing-device ]
|
||||||
|
}
|
||||||
|
|
||||||
|
func is-network-up { |
|
||||||
|
def done 0 =done
|
||||||
|
fork<| 1000 time:sleep; done not if { "ping unsuccessful" println [ "killall" "ping" ] command-wait; } >
|
||||||
|
[ "ping" "-c" "1" "1.1.1.1" ] command-wait 0 _int eq
|
||||||
|
1 =done
|
||||||
|
}
|
||||||
|
|
||||||
|
func random-byte { [result,byte] |
|
||||||
|
catch IO {
|
||||||
|
def b
|
||||||
|
"/dev/urandom" StreamTypes:file:create<0>
|
||||||
|
dup :read-one =b
|
||||||
|
:close;
|
||||||
|
[ ^ok b ]
|
||||||
|
} { with err ;
|
||||||
|
[ ^err err ]
|
||||||
|
}
|
||||||
|
}
|
107
tnoe/tnoescan-masscan.spl
Normal file
107
tnoe/tnoescan-masscan.spl
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
"#time.spl" import
|
||||||
|
"#stream.spl" import
|
||||||
|
"#json.spl" import
|
||||||
|
|
||||||
|
include json:_StringyJSON in array
|
||||||
|
include json:_StringyJSON in str
|
||||||
|
|
||||||
|
func main { exitcode | with args ;
|
||||||
|
"scanning network " print args:2 println
|
||||||
|
def nmap
|
||||||
|
[ "sudo" "masscan" "--rate" "1000" "--ping" "--wait" "2" args:2 ] StreamTypes:cmd:create =nmap
|
||||||
|
nmap:read-to-end<1024> _str =nmap
|
||||||
|
|
||||||
|
nmap:split<"\n">:iter =nmap
|
||||||
|
def records, line
|
||||||
|
[ ] =records
|
||||||
|
while { nmap:next dup =line } {
|
||||||
|
line:readf1<"Discovered open port 0/icmp on {} {}"> => &=line if {
|
||||||
|
line awrap records swap aadd =records
|
||||||
|
2 stop
|
||||||
|
}
|
||||||
|
} pop
|
||||||
|
|
||||||
|
"IPs: " println
|
||||||
|
records:foreach<| ("IP: " print) :sjson println>
|
||||||
|
|
||||||
|
"waiting..." println
|
||||||
|
3000 time:sleep;
|
||||||
|
|
||||||
|
"grabbing MACs+Hostnames" println
|
||||||
|
def i 0 =i
|
||||||
|
def newrecords
|
||||||
|
[ ] =newrecords
|
||||||
|
def running [ 0 0 0 0 0 ] =running
|
||||||
|
while { i records:len lt } {
|
||||||
|
"task " print i println
|
||||||
|
while { running:contains<0> not } {
|
||||||
|
500 time:sleep;
|
||||||
|
}
|
||||||
|
running:find<0 awrap> i fork<| with id i ;
|
||||||
|
|
||||||
|
1 id running:set;
|
||||||
|
|
||||||
|
def done [ ] =done
|
||||||
|
def nmap, out, line, ip, hostname
|
||||||
|
[ "sudo" "nmap" "-T4" "-sn" records:get<i> ] StreamTypes:cmd:create =nmap
|
||||||
|
nmap:read-to-end<1024> _str =out
|
||||||
|
[ "sudo" "nmap" "-sn" "-Pn" records:get<i> ] StreamTypes:cmd:create =nmap
|
||||||
|
out nmap:read-to-end<1024> _str concat =nmap
|
||||||
|
|
||||||
|
func submit { | with mac ;
|
||||||
|
0 done:foreach<| ip eq if { pop 1 }> not if {
|
||||||
|
done ip awrap aadd =done
|
||||||
|
newrecords [ ip hostname mac ] awrap aadd =newrecords
|
||||||
|
}
|
||||||
|
null =ip
|
||||||
|
}
|
||||||
|
|
||||||
|
nmap:split<"\n">:iter =nmap
|
||||||
|
while { nmap:next dup =line } {
|
||||||
|
line:readf<"Nmap scan report for {} ({})"> => &=line if {
|
||||||
|
ip null eq not if {
|
||||||
|
"?" submit
|
||||||
|
}
|
||||||
|
line:0 =hostname
|
||||||
|
line:1 =ip
|
||||||
|
2 stop
|
||||||
|
}
|
||||||
|
line:readf1<"Nmap scan report for {}"> => &=ip if {
|
||||||
|
"?" =hostname
|
||||||
|
2 stop
|
||||||
|
}
|
||||||
|
line:readf1<"MAC Address: {} ({})"> => &=line if {
|
||||||
|
line submit
|
||||||
|
2 stop
|
||||||
|
}
|
||||||
|
} pop
|
||||||
|
|
||||||
|
ip null eq not hostname "?" eq not and if {
|
||||||
|
"?" submit
|
||||||
|
}
|
||||||
|
|
||||||
|
0 id running:set;
|
||||||
|
|
||||||
|
> pop pop
|
||||||
|
|
||||||
|
100 time:sleep;
|
||||||
|
|
||||||
|
i ++ =i
|
||||||
|
}
|
||||||
|
while { running:contains<1> } {
|
||||||
|
500 time:sleep;
|
||||||
|
}
|
||||||
|
|
||||||
|
newrecords:foreach<| ("Record: " print) :sjson println>
|
||||||
|
|
||||||
|
"Success rate: " print newrecords:len _float records:len _float / 100 _float * print "%" println
|
||||||
|
|
||||||
|
0
|
||||||
|
}
|
||||||
|
|
||||||
|
func min { min(a,b) | with a b ;
|
||||||
|
a
|
||||||
|
a b gt if {
|
||||||
|
pop b
|
||||||
|
}
|
||||||
|
}
|
32
tnoe/tnoescan.spl
Normal file
32
tnoe/tnoescan.spl
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
"#stream.spl" import
|
||||||
|
"#json.spl" import
|
||||||
|
|
||||||
|
include json:_StringyJSON in array
|
||||||
|
|
||||||
|
func main { exitcode | with args ;
|
||||||
|
"scanning network " print args:2 println
|
||||||
|
def nmap
|
||||||
|
[ "sudo" "nmap" "-T5" "-sn" args:2 ] StreamTypes:cmd:create =nmap
|
||||||
|
nmap:read-to-end<1024> _str =nmap
|
||||||
|
|
||||||
|
nmap:split<"\n">:iter =nmap
|
||||||
|
def records, hostname, ip, line
|
||||||
|
[ ] =records
|
||||||
|
while { nmap:next dup =line } {
|
||||||
|
line:readf<"Nmap scan report for {} ({})"> => [ &=hostname &=ip ] if {
|
||||||
|
2 stop
|
||||||
|
} pop
|
||||||
|
line:readf1<"Nmap scan report for {}"> => &=ip if {
|
||||||
|
"?" =hostname
|
||||||
|
2 stop
|
||||||
|
} pop
|
||||||
|
line:readf1<"MAC Address: {} ({})"> => &=line if {
|
||||||
|
records [ ip hostname line ] awrap aadd =records
|
||||||
|
2 stop
|
||||||
|
} pop
|
||||||
|
} pop
|
||||||
|
|
||||||
|
records:foreach<| :sjson println>
|
||||||
|
|
||||||
|
0
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue