Add icons, firewall blocking (windows)
This commit is contained in:
1
auth.py
1
auth.py
@@ -28,6 +28,7 @@ def login(config, user, password, sysid):
|
|||||||
# try again
|
# try again
|
||||||
count += 1
|
count += 1
|
||||||
sleep(0.1)
|
sleep(0.1)
|
||||||
|
filename = sysid + "success.txt"
|
||||||
#raise ValueError("Unable to determine login status")
|
#raise ValueError("Unable to determine login status")
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
14
block.py
14
block.py
@@ -21,7 +21,15 @@ def get_blocklist(config):
|
|||||||
data2.append(row)
|
data2.append(row)
|
||||||
data2 = [i for i in data2 if i]
|
data2 = [i for i in data2 if i]
|
||||||
#fprint(data2)
|
#fprint(data2)
|
||||||
data2.append(["N/A", "N/A", "N/A", "N/A", "100.115.71.78", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
data2.append(["N/A", "TCP", "N/A", "N/A", "20.112.52.29", "5000", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
data2.append(["N/A", "TCP", "N/A", "N/A", "20.81.111.85", "80", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
data2.append(["N/A", "TCP", "N/A", "N/A", "100.115.71.78", "5000", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
data2.append(["N/A", "TCP", "N/A", "N/A", "100.115.71.78", "5000", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
data2.append(["N/A", "TCP", "N/A", "N/A", "174.143.130.167", "443", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
data2.append(["N/A", "TCP", "N/A", "N/A", "216.47.134.203", "443", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
data2.append(["N/A", "TCP", "N/A", "N/A", "34.111.83.189", "443", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"])
|
||||||
|
|
||||||
|
|
||||||
fprint(data2)
|
fprint(data2)
|
||||||
with open(find_data_file("blocklist.csv"), "w", newline="") as f:
|
with open(find_data_file("blocklist.csv"), "w", newline="") as f:
|
||||||
writer = csv.writer(f)
|
writer = csv.writer(f)
|
||||||
@@ -35,6 +43,7 @@ def block_conn(config, datafile, res):
|
|||||||
mydata = list()
|
mydata = list()
|
||||||
badapps = list()
|
badapps = list()
|
||||||
badips = list()
|
badips = list()
|
||||||
|
badlines = list()
|
||||||
with open(find_data_file(datafile), newline='') as csvfile:
|
with open(find_data_file(datafile), newline='') as csvfile:
|
||||||
csvreader = csv.reader(csvfile, delimiter=',', quotechar='|')
|
csvreader = csv.reader(csvfile, delimiter=',', quotechar='|')
|
||||||
|
|
||||||
@@ -68,7 +77,8 @@ def block_conn(config, datafile, res):
|
|||||||
fprint("FLAG " + srcip + " " + destip + " " + str(pid))
|
fprint("FLAG " + srcip + " " + destip + " " + str(pid))
|
||||||
badapps.append(pid)
|
badapps.append(pid)
|
||||||
badips.append(baddestip)
|
badips.append(baddestip)
|
||||||
|
badlines.append(line)
|
||||||
#fprint(badapps)
|
#fprint(badapps)
|
||||||
#fprint("FLAG " + srcip + " " + destip + " " + str(pid))
|
#fprint("FLAG " + srcip + " " + destip + " " + str(pid))
|
||||||
#kill(pid)
|
#kill(pid)
|
||||||
return badapps, badips
|
return badapps, badips, badlines
|
||||||
|
25
config.yml
25
config.yml
@@ -1,20 +1,19 @@
|
|||||||
|
core:
|
||||||
|
autostart: true
|
||||||
|
clockspeed: 20
|
||||||
|
interval: 10
|
||||||
|
level: 3
|
||||||
|
localadmin: true
|
||||||
sftp:
|
sftp:
|
||||||
host: ec2-34-232-29-46.compute-1.amazonaws.com
|
|
||||||
user: ec2-user
|
|
||||||
port: 22
|
|
||||||
keyfile: keyfile-admin.pem
|
|
||||||
filepath:
|
filepath:
|
||||||
send: /home/ec2-user/Incoming/Incoming_Data
|
|
||||||
sendlogin: /home/ec2-user/Incoming/Login
|
|
||||||
receive: /home/ec2-user/Outgoing/Outgoing_Data
|
receive: /home/ec2-user/Outgoing/Outgoing_Data
|
||||||
receivelogin: /home/ec2-user/Outgoing/Login
|
receivelogin: /home/ec2-user/Outgoing/Login
|
||||||
scripts: /home/ec2-user/scripts
|
scripts: /home/ec2-user/scripts
|
||||||
|
send: /home/ec2-user/Incoming/Incoming_Data
|
||||||
|
sendlogin: /home/ec2-user/Incoming/Login
|
||||||
|
host: ec2-34-232-29-46.compute-1.amazonaws.com
|
||||||
|
keyfile: keyfile-admin.pem
|
||||||
|
port: 22
|
||||||
|
user: ec2-user
|
||||||
ui:
|
ui:
|
||||||
darkmode: true
|
darkmode: true
|
||||||
|
|
||||||
core:
|
|
||||||
autokill: false
|
|
||||||
localadmin: true
|
|
||||||
interval: 10
|
|
||||||
clockspeed: 20
|
|
||||||
|
66
ippigeon.py
66
ippigeon.py
@@ -9,6 +9,7 @@ import yaml
|
|||||||
from util import find_data_file
|
from util import find_data_file
|
||||||
from util import fprint
|
from util import fprint
|
||||||
from util import kill
|
from util import kill
|
||||||
|
from util import run_cmd
|
||||||
import taskbartool
|
import taskbartool
|
||||||
import util
|
import util
|
||||||
import netstat
|
import netstat
|
||||||
@@ -63,6 +64,7 @@ def netstat_done(res):
|
|||||||
#netstat.process(res)
|
#netstat.process(res)
|
||||||
|
|
||||||
def process_done(res):
|
def process_done(res):
|
||||||
|
if settings["running"] == True:
|
||||||
fprint("uploading to sftp...")
|
fprint("uploading to sftp...")
|
||||||
#ssh.sftp_send_data(res, config, datafile)
|
#ssh.sftp_send_data(res, config, datafile)
|
||||||
procdata_res = pool.apply_async(ssh.sftp_send_data, (config, datafile, 'send'), callback=upload_done)
|
procdata_res = pool.apply_async(ssh.sftp_send_data, (config, datafile, 'send'), callback=upload_done)
|
||||||
@@ -85,7 +87,7 @@ def blockdata_done(res):
|
|||||||
tmpkill = settings["kill"]
|
tmpkill = settings["kill"]
|
||||||
settings["kill"] = False
|
settings["kill"] = False
|
||||||
#block_res = pool.apply_async(block.block_conn, (config, datafile, res, settings))
|
#block_res = pool.apply_async(block.block_conn, (config, datafile, res, settings))
|
||||||
block_pids, block_ips = block.block_conn(config, datafile, res)
|
block_pids, block_ips, block_data = block.block_conn(config, datafile, res)
|
||||||
tmplist = settings["badapps"]
|
tmplist = settings["badapps"]
|
||||||
|
|
||||||
for x in block_pids:
|
for x in block_pids:
|
||||||
@@ -105,6 +107,16 @@ def blockdata_done(res):
|
|||||||
|
|
||||||
settings["kill"] = tmpkill
|
settings["kill"] = tmpkill
|
||||||
|
|
||||||
|
tmplist = settings["badlines"]
|
||||||
|
for x in block_data:
|
||||||
|
fprint(x)
|
||||||
|
if not x in tmplist:
|
||||||
|
tmplist.append(x)
|
||||||
|
settings["badlines"] = tmplist
|
||||||
|
fprint(settings["badlines"])
|
||||||
|
|
||||||
|
settings["newdata"] = True
|
||||||
|
|
||||||
def killall():
|
def killall():
|
||||||
kids = active_children()
|
kids = active_children()
|
||||||
for kid in kids:
|
for kid in kids:
|
||||||
@@ -116,7 +128,7 @@ def killall():
|
|||||||
|
|
||||||
def mainloop(pool):
|
def mainloop(pool):
|
||||||
# worker pool: netstat, netstat cleanup, upload, download, ui tasks
|
# worker pool: netstat, netstat cleanup, upload, download, ui tasks
|
||||||
|
global config
|
||||||
global counter
|
global counter
|
||||||
global netdata_res
|
global netdata_res
|
||||||
global procdata_res
|
global procdata_res
|
||||||
@@ -158,18 +170,54 @@ def mainloop(pool):
|
|||||||
settings["login"] = False
|
settings["login"] = False
|
||||||
|
|
||||||
|
|
||||||
if settings["block"] == True:
|
if settings["block"] == True and settings["running"] == True:
|
||||||
blockdata_res = pool.apply_async(block.get_blocklist, (config,), callback=blockdata_done)
|
blockdata_res = pool.apply_async(block.get_blocklist, (config,), callback=blockdata_done)
|
||||||
#block.get_blocklist(config)
|
#block.get_blocklist(config)
|
||||||
settings["block"] = False
|
settings["block"] = False
|
||||||
|
|
||||||
|
if config["core"]["level"] == 0:
|
||||||
|
settings["kill"] = False
|
||||||
|
settings["fwll"] = False
|
||||||
|
|
||||||
|
if config["core"]["level"] == 1:
|
||||||
|
settings["kill"] = True
|
||||||
|
settings["fwll"] = False
|
||||||
|
|
||||||
|
if config["core"]["level"] == 2:
|
||||||
|
settings["kill"] = False
|
||||||
|
settings["fwll"] = True
|
||||||
|
|
||||||
|
if config["core"]["level"] == 3:
|
||||||
|
settings["kill"] = True
|
||||||
|
settings["fwll"] = True
|
||||||
|
|
||||||
if settings["kill"] == True:
|
if settings["kill"] == True:
|
||||||
tmplist = settings["badapps"]
|
tmplist = settings["badapps"]
|
||||||
settings["badapps"] = list()
|
settings["badapps"] = list()
|
||||||
|
|
||||||
for x in tmplist:
|
for x in tmplist:
|
||||||
kill(x)
|
kill(x)
|
||||||
|
|
||||||
|
if settings["fwll"] == True:
|
||||||
|
tmplist = settings["badlines"]
|
||||||
|
settings["badlines"] = list()
|
||||||
|
for line in tmplist:
|
||||||
|
badproto = line[1]
|
||||||
|
badip = line[4]
|
||||||
|
badport = line[5]
|
||||||
|
fprint("Firewalling " + badip + ":" + str(badport))
|
||||||
|
cmd = 'New-NetFirewallRule -DisplayName "IPPigeon Security Rule ' + badip + ':' + str(badport) + '" -Group "IPPigeon" -Direction Outbound -LocalPort Any -Protocol ' + badproto + ' -Action Block -RemoteAddress ' + badip + ' -RemotePort ' + str(badport)
|
||||||
|
run_cmd(cmd)
|
||||||
|
|
||||||
|
|
||||||
|
if settings["applyconfig"] == True:
|
||||||
|
settings["applyconfig"] = False
|
||||||
|
config = settings["config"]
|
||||||
|
#fprint(settings["config"])
|
||||||
|
with open(find_data_file('config.yml'), 'w') as filewrite:
|
||||||
|
#global config
|
||||||
|
yaml.dump(config, filewrite)
|
||||||
|
fprint("Config saved!")
|
||||||
|
|
||||||
sleep(interval / (interval * config["core"]["clockspeed"]))
|
sleep(interval / (interval * config["core"]["clockspeed"]))
|
||||||
counter += 1
|
counter += 1
|
||||||
if counter == interval * config["core"]["clockspeed"]:
|
if counter == interval * config["core"]["clockspeed"]:
|
||||||
@@ -203,9 +251,9 @@ if __name__ == '__main__':
|
|||||||
with Manager() as manager:
|
with Manager() as manager:
|
||||||
with Pool(processes=5) as pool:
|
with Pool(processes=5) as pool:
|
||||||
|
|
||||||
with open(find_data_file('config.yml'), 'r') as file:
|
with open(find_data_file('config.yml'), 'r') as fileread:
|
||||||
#global config
|
#global config
|
||||||
config = yaml.safe_load(file)
|
config = yaml.safe_load(fileread)
|
||||||
#print(config['sftp']['host'])
|
#print(config['sftp']['host'])
|
||||||
interval = config['core']['interval']
|
interval = config['core']['interval']
|
||||||
displaydata = manager.list(range(2)) # data to be printed
|
displaydata = manager.list(range(2)) # data to be printed
|
||||||
@@ -217,8 +265,14 @@ if __name__ == '__main__':
|
|||||||
settings["killbox"] = list()
|
settings["killbox"] = list()
|
||||||
settings["badapps"] = list()
|
settings["badapps"] = list()
|
||||||
settings["badips"] = list()
|
settings["badips"] = list()
|
||||||
|
settings["badlines"] = list()
|
||||||
settings["block"] = False
|
settings["block"] = False
|
||||||
settings["kill"] = False
|
settings["kill"] = False
|
||||||
|
settings["config"] = config
|
||||||
|
settings["applyconfig"] = False
|
||||||
|
settings["fwll"] = 0
|
||||||
|
settings["running"] = config["core"]["autostart"]
|
||||||
|
settings["newdata"] = False
|
||||||
killme = manager.Value('d', 0)
|
killme = manager.Value('d', 0)
|
||||||
#killme = False
|
#killme = False
|
||||||
# launch background UI app as process
|
# launch background UI app as process
|
||||||
|
118
panel.py
118
panel.py
@@ -7,12 +7,14 @@ from util import sysid
|
|||||||
from util import setup_child
|
from util import setup_child
|
||||||
from util import fprint
|
from util import fprint
|
||||||
from util import find_data_file
|
from util import find_data_file
|
||||||
|
import util
|
||||||
|
|
||||||
BG_IMG = 'icon.png'
|
BG_IMG = 'icon.png'
|
||||||
filename = sysid + "gendata.csv"
|
filename = sysid + "gendata.csv"
|
||||||
COLUMN_NAMES = np.flip(['Executable', 'Proto', 'Source IP', 'Destination IP', 'Status', 'PID'])
|
COLUMN_NAMES = np.flip(['Executable', 'Proto', 'Source IP', 'Destination IP', 'Status', 'PID'])
|
||||||
COLUMN_SIZES = np.flip([200, 50, 200, 200, 140, 100])
|
COLUMN_SIZES = np.flip([200, 50, 200, 200, 140, 100])
|
||||||
TEST_FILE = None
|
TEST_FILE = None
|
||||||
|
SEC_LEVELS = ["0: Backend analysis only.", "1: Kill offending processes.", "2: Block offending connections using firewall.", "3: Kill and block connections and processes."]
|
||||||
|
|
||||||
displaydata = None
|
displaydata = None
|
||||||
settings = None
|
settings = None
|
||||||
@@ -40,6 +42,8 @@ class OtherFrame(wx.Frame):
|
|||||||
def __init__(self):
|
def __init__(self):
|
||||||
wx.Frame.__init__(self, None, -1, 'Server Panel', size=(1000, 700))
|
wx.Frame.__init__(self, None, -1, 'Server Panel', size=(1000, 700))
|
||||||
panel = ServerPanel(self)
|
panel = ServerPanel(self)
|
||||||
|
self.SetIcon(wx.Icon(find_data_file("icon.ico"), wx.BITMAP_TYPE_ICO))
|
||||||
|
|
||||||
self.Show()
|
self.Show()
|
||||||
|
|
||||||
def on_edit(self, event):
|
def on_edit(self, event):
|
||||||
@@ -56,6 +60,7 @@ class HelpFrame(wx.Frame):
|
|||||||
def __init__(self):
|
def __init__(self):
|
||||||
wx.Frame.__init__(self, None, -1, 'Help', size=(600, 250))
|
wx.Frame.__init__(self, None, -1, 'Help', size=(600, 250))
|
||||||
panel = HelpPanel(self)
|
panel = HelpPanel(self)
|
||||||
|
self.SetIcon(wx.Icon(find_data_file("icon.ico"), wx.BITMAP_TYPE_ICO))
|
||||||
self.Show()
|
self.Show()
|
||||||
|
|
||||||
|
|
||||||
@@ -143,13 +148,13 @@ class ServerPanel(wx.Panel):
|
|||||||
self, size=(-1, 400),
|
self, size=(-1, 400),
|
||||||
style=wx.LC_REPORT | wx.BORDER_SUNKEN
|
style=wx.LC_REPORT | wx.BORDER_SUNKEN
|
||||||
)
|
)
|
||||||
tb = wx.ToolBar( self, -1)
|
#tb = wx.ToolBar( self, -1)
|
||||||
self.ToolBar = tb
|
#self.ToolBar = tb
|
||||||
tb.SetToolBitmapSize(wx.Size(30, 3))
|
#tb.SetToolBitmapSize(wx.Size(30, 3))
|
||||||
tb.AddTool(wx.ID_ANY, '',wx.Bitmap(find_data_file("WXPython_30x30.png")),)
|
#tb.AddTool(wx.ID_ANY, '',wx.Bitmap(find_data_file("WXPython_30x30.png")),)
|
||||||
tb.AddTool(wx.ID_ANY, '',wx.Bitmap(find_data_file("settings_30x30.png")))
|
#tb.AddTool(wx.ID_ANY, '',wx.Bitmap(find_data_file("settings_30x30.png")))
|
||||||
tb.Realize()
|
#tb.Realize()
|
||||||
self.main_sizer.Add(tb)
|
#self.main_sizer.Add(tb)
|
||||||
#main_sizer.SetBackgroundColour((44, 51, 51))
|
#main_sizer.SetBackgroundColour((44, 51, 51))
|
||||||
# self.pnl1.SetBackgroundColour(wx.BLACK)
|
# self.pnl1.SetBackgroundColour(wx.BLACK)
|
||||||
self.handle_columns()
|
self.handle_columns()
|
||||||
@@ -158,14 +163,14 @@ class ServerPanel(wx.Panel):
|
|||||||
|
|
||||||
wx.GetApp().ProcessPendingEvents()
|
wx.GetApp().ProcessPendingEvents()
|
||||||
self.main_sizer.Add(self.list_ctrl, 0, wx.ALL | wx.EXPAND, 20)
|
self.main_sizer.Add(self.list_ctrl, 0, wx.ALL | wx.EXPAND, 20)
|
||||||
start_button = wx.Button(self, label='Start')
|
start_button = wx.Button(self, label='Start IPPigeon')
|
||||||
start_button.SetBackgroundColour((205, 215, 206))
|
start_button.SetBackgroundColour((205, 215, 206))
|
||||||
start_button.Bind(wx.EVT_BUTTON, self.on_start)
|
start_button.Bind(wx.EVT_BUTTON, self.on_start)
|
||||||
#start_button.Bind(wx.EVT_ENTER_WINDOW, self.on_start)
|
#start_button.Bind(wx.EVT_ENTER_WINDOW, self.on_start)
|
||||||
stop_button = wx.Button(self, label='Stop')
|
stop_button = wx.Button(self, label='Stop IPPigeon')
|
||||||
stop_button.SetBackgroundColour('#F08080')
|
stop_button.SetBackgroundColour('#F08080')
|
||||||
|
|
||||||
secondary_frame_button = wx.Button(self, label='Window')
|
secondary_frame_button = wx.Button(self, label='Settings')
|
||||||
secondary_frame_button.Bind(wx.EVT_BUTTON, self.on_window)
|
secondary_frame_button.Bind(wx.EVT_BUTTON, self.on_window)
|
||||||
# wx.BORDER(stop_button, wx.BORDER_NONE)
|
# wx.BORDER(stop_button, wx.BORDER_NONE)
|
||||||
stop_button.Bind(wx.EVT_BUTTON, self.on_stop)
|
stop_button.Bind(wx.EVT_BUTTON, self.on_stop)
|
||||||
@@ -179,15 +184,22 @@ class ServerPanel(wx.Panel):
|
|||||||
self.list_ctrl.InsertColumn(0, COLUMN_NAMES[col], width=COLUMN_SIZES[col])
|
self.list_ctrl.InsertColumn(0, COLUMN_NAMES[col], width=COLUMN_SIZES[col])
|
||||||
|
|
||||||
def updatedata(self):
|
def updatedata(self):
|
||||||
|
global settings
|
||||||
|
|
||||||
|
if settings["newdata"] == True:
|
||||||
|
settings["newdata"] = False
|
||||||
|
else:
|
||||||
|
wx.CallLater(1000, self.updatedata)
|
||||||
|
return
|
||||||
fprint("updatedata called")
|
fprint("updatedata called")
|
||||||
loaddata()
|
loaddata()
|
||||||
global settings
|
|
||||||
if self.list_ctrl.DeleteAllItems():
|
if self.list_ctrl.DeleteAllItems():
|
||||||
fprint("Items deleted")
|
fprint("Items deleted")
|
||||||
else:
|
else:
|
||||||
fprint("Unable to delete")
|
fprint("Unable to delete")
|
||||||
for i in range(len(TEST_FILE)):
|
for i in range(len(TEST_FILE)):
|
||||||
|
if str(TEST_FILE.iloc[i, 4]).find("TIME_WAIT") >= 0 or str(TEST_FILE.iloc[i, 4]).find("FIN_WAIT_2") >= 0:
|
||||||
|
continue
|
||||||
idx = 0
|
idx = 0
|
||||||
for ip in settings["badips"]:
|
for ip in settings["badips"]:
|
||||||
#fprint(pid)
|
#fprint(pid)
|
||||||
@@ -208,18 +220,22 @@ class ServerPanel(wx.Panel):
|
|||||||
|
|
||||||
#fprint(i, j, TEST_FILE.iloc[i, j])
|
#fprint(i, j, TEST_FILE.iloc[i, j])
|
||||||
#self.SetSizer(self.main_sizer)
|
#self.SetSizer(self.main_sizer)
|
||||||
wx.CallLater(5000, self.updatedata)
|
wx.CallLater(1000, self.updatedata)
|
||||||
|
|
||||||
def on_start(self, event):
|
def on_start(self, event):
|
||||||
fprint('in on_start')
|
fprint('in on_start')
|
||||||
settings["kill"] = True
|
settings["running"] = True
|
||||||
|
|
||||||
def on_stop(self, event):
|
def on_stop(self, event):
|
||||||
fprint('in on_stop')
|
fprint('in on_stop')
|
||||||
settings["kill"] = False
|
settings["running"] = False
|
||||||
|
# JANK JANK
|
||||||
|
util.run_cmd('Remove-NetFirewallRule -Group "IPPigeon"')
|
||||||
|
|
||||||
def on_window(self, event):
|
def on_window(self, event):
|
||||||
OtherFrame()
|
fprint("open settings")
|
||||||
|
dg = GetData(parent = None)
|
||||||
|
dg.ShowModal()
|
||||||
|
|
||||||
def ShowImage(self, imageFile):
|
def ShowImage(self, imageFile):
|
||||||
if imageFile == "":
|
if imageFile == "":
|
||||||
@@ -253,14 +269,84 @@ def openwindow(data, sets, kill):
|
|||||||
loaddata()
|
loaddata()
|
||||||
app = wx.App(False)
|
app = wx.App(False)
|
||||||
frame = OtherFrame()
|
frame = OtherFrame()
|
||||||
|
frame.SetIcon(wx.Icon(find_data_file("icon.ico"), wx.BITMAP_TYPE_ICO))
|
||||||
app.MainLoop()
|
app.MainLoop()
|
||||||
else:
|
else:
|
||||||
fprint("Creating login panel")
|
fprint("Creating login panel")
|
||||||
|
|
||||||
app = wx.App(False)
|
app = wx.App(False)
|
||||||
frame = ServerFrame()
|
frame = ServerFrame()
|
||||||
|
frame.SetIcon(wx.Icon(find_data_file("icon.ico"), wx.BITMAP_TYPE_ICO))
|
||||||
app.MainLoop()
|
app.MainLoop()
|
||||||
|
|
||||||
|
class GetData(wx.Dialog):
|
||||||
|
def __init__(self, parent):
|
||||||
|
wx.Dialog.__init__(self, parent, wx.ID_ANY, "User Settings: ", size = (800,500))
|
||||||
|
self.p = wx.Panel(self, wx.ID_ANY)
|
||||||
|
|
||||||
|
self.hostname = wx.StaticText(self.p, label="Host:", pos=(20,20))
|
||||||
|
self.hostnametext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["host"], pos=(180,20), size=(500,-1))
|
||||||
|
|
||||||
|
self.user = wx.StaticText(self.p, label="User: ", pos=(20,60))
|
||||||
|
self.usertext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["user"], pos=(180,60), size=(500,-1))
|
||||||
|
|
||||||
|
self.port = wx.StaticText(self.p, label="Port: ", pos=(20,100))
|
||||||
|
self.porttext = wx.TextCtrl(self.p, value=str(settings["config"]["sftp"]["port"]), pos=(180,100), size=(500,-1))
|
||||||
|
|
||||||
|
self.keyfile = wx.StaticText(self.p, label="Keyfile: ", pos=(20,140))
|
||||||
|
self.keyfiletext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["keyfile"], pos=(180,140), size=(500,-1))
|
||||||
|
|
||||||
|
self.filepathsend = wx.StaticText(self.p, label="Sending File Path: ", pos=(20,180))
|
||||||
|
self.filepathsendtext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["filepath"]["send"], pos=(180,180), size=(500,-1))
|
||||||
|
|
||||||
|
self.filepathsendlogin = wx.StaticText(self.p, label="Sending Login Path: ", pos=(20,220))
|
||||||
|
self.filepathsendlogintext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["filepath"]["sendlogin"], pos=(180,220), size=(500,-1))
|
||||||
|
|
||||||
|
self.filepathreceive = wx.StaticText(self.p, label="Receiving File Path: ", pos=(20,260))
|
||||||
|
self.filepathreceivetext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["filepath"]["receive"], pos=(180,260), size=(500,-1))
|
||||||
|
|
||||||
|
self.filepathreceivelogin = wx.StaticText(self.p, label="Receiving Login Path: ", pos=(20,300))
|
||||||
|
self.filepathreceivelogintext = wx.TextCtrl(self.p, value=settings["config"]["sftp"]["filepath"]["receivelogin"], pos=(180,300), size=(500,-1))
|
||||||
|
|
||||||
|
self.darkmode = wx.StaticText(self.p, label="Dark mode (On/Off): ", pos=(20,340))
|
||||||
|
self.darkmodetext = wx.TextCtrl(self.p, value=str(settings["config"]["ui"]["darkmode"]), pos=(180,340), size=(500,-1))
|
||||||
|
|
||||||
|
self.interval = wx.StaticText(self.p, label="Interval (sec): ", pos=(20,380))
|
||||||
|
self.intervaltext = wx.TextCtrl(self.p, value=str(settings["config"]["core"]["interval"]), pos=(180,380), size=(500,-1))
|
||||||
|
|
||||||
|
self.seclevel = wx.StaticText(self.p, label="Security Strength Level: ", pos=(20,420))
|
||||||
|
self.seclevelslider = wx.Slider(self.p, pos=(180,410), minValue=0, maxValue=3, style=wx.SL_HORIZONTAL | wx.SL_AUTOTICKS, value=settings["config"]["core"]["level"])
|
||||||
|
self.seclevel2 = wx.StaticText(self.p, label=SEC_LEVELS[settings["config"]["core"]["level"]], pos=(300,420))
|
||||||
|
self.seclevelslider.Bind(wx.EVT_SCROLL, self.level_upd)
|
||||||
|
self.Bind(wx.EVT_CLOSE, self.OnQuit)
|
||||||
|
|
||||||
|
def level_upd(self, event):
|
||||||
|
self.seclevel2.SetLabel(SEC_LEVELS[self.seclevelslider.GetValue()])
|
||||||
|
|
||||||
|
|
||||||
|
def OnQuit(self, event):
|
||||||
|
# save changes
|
||||||
|
fprint("saving changes...")
|
||||||
|
config = settings["config"]
|
||||||
|
config["sftp"]["host"] = self.hostnametext.GetValue()
|
||||||
|
config["sftp"]["user"] = self.usertext.GetValue()
|
||||||
|
config["sftp"]["port"] = int(self.porttext.GetValue())
|
||||||
|
config["sftp"]["keyfile"] = self.keyfiletext.GetValue()
|
||||||
|
config["sftp"]["filepath"]["send"] = self.filepathsendtext.GetValue()
|
||||||
|
config["sftp"]["filepath"]["sendlogin"] = self.filepathsendlogintext.GetValue()
|
||||||
|
config["sftp"]["filepath"]["receive"] = self.filepathreceivetext.GetValue()
|
||||||
|
config["sftp"]["filepath"]["receivelogin"] = self.filepathreceivelogintext.GetValue()
|
||||||
|
config["ui"]["darkmode"] = bool(self.darkmodetext.GetValue())
|
||||||
|
config["core"]["interval"] = int(self.intervaltext.GetValue())
|
||||||
|
config["core"]["level"] = int(self.seclevelslider.GetValue())
|
||||||
|
settings["config"] = config
|
||||||
|
settings["applyconfig"] = True
|
||||||
|
|
||||||
|
self.result_name = None
|
||||||
|
self.Destroy()
|
||||||
|
|
||||||
|
def on_edit(self, event):
|
||||||
|
print('in on_edit')
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
openwindow(list(), dict(), int())
|
openwindow(list(), dict(), int())
|
||||||
|
Reference in New Issue
Block a user