forked from I2P_Developers/i2p.i2p
OSX Launcher:
* UI Bugfixes/features * restart might work * open console button should work * cleanup
This commit is contained in:
@ -24,63 +24,93 @@ import Cocoa
|
|||||||
@IBOutlet var routerUptimeLabel: NSTextField?
|
@IBOutlet var routerUptimeLabel: NSTextField?
|
||||||
@IBOutlet var routerPIDLabel: NSTextField?
|
@IBOutlet var routerPIDLabel: NSTextField?
|
||||||
|
|
||||||
|
|
||||||
@IBOutlet var quickControlView: NSView?
|
@IBOutlet var quickControlView: NSView?
|
||||||
@IBOutlet var routerStartStopButton: NSButton?
|
@IBOutlet var routerStartStopButton: NSButton?
|
||||||
|
@IBOutlet var restartRouterButton: NSButton?
|
||||||
@IBOutlet var openConsoleButton: NSButton?
|
@IBOutlet var openConsoleButton: NSButton?
|
||||||
|
|
||||||
|
|
||||||
|
@objc func actionBtnOpenConsole(_ sender: Any?) {
|
||||||
|
SwiftMainDelegate.openLink(url: "http://localhost:7657")
|
||||||
|
}
|
||||||
|
|
||||||
@objc func actionBtnStartRouter(_ sender: Any?) {
|
@objc func actionBtnStartRouter(_ sender: Any?) {
|
||||||
NSLog("START ROUTER")
|
NSLog("Router start clicked")
|
||||||
/*if (RouterManager.shared().getRouterTask() == nil) {
|
/*if (RouterManager.shared().getRouterTask() == nil) {
|
||||||
SBridge.sharedInstance().startupI2PRouter(RouterProcessStatus.i2pDirectoryPath)
|
SBridge.sharedInstance().startupI2PRouter(RouterProcessStatus.i2pDirectoryPath)
|
||||||
}*/
|
}*/
|
||||||
(sender as! NSButton).isTransparent = true
|
(sender as! NSButton).isTransparent = true
|
||||||
let routerStatus = RouterRunner.launchAgent?.status()
|
let routerStatus = RouterRunner.launchAgent?.status()
|
||||||
switch routerStatus {
|
DispatchQueue(label: "background_start").async {
|
||||||
case .loaded?:
|
switch routerStatus {
|
||||||
RouterManager.shared().routerRunner.StartAgent(information: RouterRunner.launchAgent)
|
case .loaded?:
|
||||||
case .unloaded?:
|
RouterManager.shared().routerRunner.StartAgent(RouterRunner.launchAgent)
|
||||||
do {
|
case .unloaded?:
|
||||||
try LaunchAgentManager.shared.load(RouterRunner.launchAgent!)
|
do {
|
||||||
RouterManager.shared().routerRunner.StartAgent(information: RouterRunner.launchAgent)
|
try LaunchAgentManager.shared.load(RouterRunner.launchAgent!)
|
||||||
} catch {
|
RouterManager.shared().routerRunner.StartAgent(RouterRunner.launchAgent)
|
||||||
RouterManager.shared().eventManager.trigger(eventName: "router_exception", information: error)
|
} catch {
|
||||||
|
RouterManager.shared().eventManager.trigger(eventName: "router_exception", information: error)
|
||||||
|
}
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self.reEnableButton()
|
||||||
}
|
}
|
||||||
break
|
|
||||||
default:
|
|
||||||
break
|
|
||||||
}
|
}
|
||||||
self.reEnableButton()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@objc func actionBtnStopRouter(_ sender: Any?) {
|
@objc func actionBtnStopRouter(_ sender: Any?) {
|
||||||
NSLog("STOP ROUTER")
|
NSLog("Router stop clicked")
|
||||||
let routerStatus = RouterRunner.launchAgent?.status()
|
DispatchQueue(label: "background_shutdown").async {
|
||||||
switch routerStatus {
|
RouterManager.shared().routerRunner.StopAgent({
|
||||||
case .running?:
|
RouterProcessStatus.isRouterRunning = false
|
||||||
NSLog("Found running router")
|
RouterProcessStatus.isRouterChildProcess = false
|
||||||
RouterManager.shared().routerRunner.StopAgent()
|
NSLog("Router should be stopped by now.")
|
||||||
break
|
})
|
||||||
default:
|
// Wait for it to die.
|
||||||
break
|
|
||||||
}
|
}
|
||||||
|
RouterManager.shared().eventManager.trigger(eventName: "toggle_popover")
|
||||||
self.reEnableButton()
|
self.reEnableButton()
|
||||||
}
|
}
|
||||||
|
|
||||||
@objc func actionBtnRestartRouter(sender: Any?) {
|
func restartFn() {
|
||||||
if (RouterManager.shared().getRouterTask() != nil) {
|
RouterManager.shared().routerRunner.StopAgent({
|
||||||
//RouterManager.shared().getRouterTask()?.requestRestart()
|
sleep(30)
|
||||||
|
RouterManager.shared().routerRunner.StartAgent()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
@objc func actionBtnRestartRouter(_ sender: Any?) {
|
||||||
|
RouterManager.shared().eventManager.trigger(eventName: "toggle_popover")
|
||||||
|
let currentStatus : AgentStatus = RouterRunner.launchAgent?.status() ?? AgentStatus.unloaded
|
||||||
|
if currentStatus != AgentStatus.loaded && currentStatus != AgentStatus.unloaded {
|
||||||
|
NSLog("Found a running router, will unload it from launchd")
|
||||||
|
// OK, router seems to be running
|
||||||
|
DispatchQueue(label: "background_restart").async {
|
||||||
|
self.restartFn()
|
||||||
|
// Report done to main thread
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self.reEnableButton()
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
NSLog("Can't restart a non running router, start it however...")
|
NSLog("Can't restart a non running router, start it however...")
|
||||||
//SBridge.sharedInstance().startupI2PRouter(RouterProcessStatus.i2pDirectoryPath)
|
RouterManager.shared().routerRunner.StartAgent()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func handlerRouterStart(information:Any?) {
|
func handlerRouterStart(information:Any?) {
|
||||||
print("Triggered handlerRouterStart")
|
NSLog("Triggered handlerRouterStart")
|
||||||
NSLog("PID2! %@", information as! String)
|
NSLog("PID2! %@", information as! String)
|
||||||
routerPIDLabel?.cell?.stringValue = "Router PID: "+(information as! String)
|
routerPIDLabel?.cell?.stringValue = "Router PID: "+(information as! String)
|
||||||
routerPIDLabel?.needsDisplay = true
|
routerPIDLabel?.needsDisplay = true
|
||||||
routerStatusLabel?.cell?.stringValue = "Router status: Running"
|
routerStatusLabel?.cell?.stringValue = "Router status: Running"
|
||||||
|
RouterManager.shared().lastRouterPid = (information as? String)
|
||||||
self.toggleSetButtonStop()
|
self.toggleSetButtonStop()
|
||||||
self.reEnableButton()
|
self.reEnableButton()
|
||||||
}
|
}
|
||||||
@ -112,10 +142,16 @@ import Cocoa
|
|||||||
RouterStatusView.instance = self
|
RouterStatusView.instance = self
|
||||||
}
|
}
|
||||||
self.reEnableButton()
|
self.reEnableButton()
|
||||||
|
openConsoleButton!.cell!.action = #selector(self.actionBtnOpenConsole(_:))
|
||||||
|
openConsoleButton!.cell!.target = self
|
||||||
|
restartRouterButton!.cell!.action = #selector(self.actionBtnRestartRouter(_:))
|
||||||
|
restartRouterButton!.cell!.target = self
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleRouterStop() {
|
func handleRouterStop() {
|
||||||
routerPIDLabel?.cell?.stringValue = "Router PID: Not running"
|
routerPIDLabel?.cell?.stringValue = "Router PID: Not running"
|
||||||
|
RouterManager.shared().lastRouterPid = nil
|
||||||
self.toggleSetButtonStart()
|
self.toggleSetButtonStart()
|
||||||
reEnableButton()
|
reEnableButton()
|
||||||
}
|
}
|
||||||
@ -133,41 +169,49 @@ import Cocoa
|
|||||||
}
|
}
|
||||||
|
|
||||||
func setRouterStatusLabelText() {
|
func setRouterStatusLabelText() {
|
||||||
routerStartStopButton?.needsDisplay = true
|
|
||||||
routerStartStopButton?.target = self
|
routerStartStopButton?.target = self
|
||||||
quickControlView?.needsDisplay = true
|
let staticStartedByLabelText = "Router started by launcher? "
|
||||||
|
let staticIsRunningLabelText = "Router status: "
|
||||||
|
let staticRouterVersionLabelText = "Router version: "
|
||||||
|
let staticRouterPidLabelText = "Router PID: "
|
||||||
|
|
||||||
do {
|
// Use default here to avoid any potential crashes with force unwrapping
|
||||||
let currentStatus : AgentStatus = RouterRunner.launchAgent!.status()
|
let currentStatus : AgentStatus = RouterRunner.launchAgent?.status() ?? AgentStatus.unloaded
|
||||||
if currentStatus == AgentStatus.loaded || currentStatus == AgentStatus.unloaded {
|
if currentStatus == AgentStatus.loaded || currentStatus == AgentStatus.unloaded {
|
||||||
routerStatusLabel?.cell?.stringValue = "Router status: Not running"
|
routerStatusLabel?.cell?.stringValue = staticIsRunningLabelText+"Not running"
|
||||||
} else {
|
|
||||||
routerStatusLabel?.cell?.stringValue = "Router status: Running"
|
|
||||||
}
|
|
||||||
} catch {
|
|
||||||
// Ensure it's set even AgentStatus is nil (uninitialized yet..)
|
|
||||||
routerStatusLabel?.cell?.stringValue = "Router status: Not running"
|
|
||||||
}
|
|
||||||
|
|
||||||
let staticStartedByLabelText = "Router started by launcher?"
|
|
||||||
if RouterProcessStatus.isRouterChildProcess {
|
|
||||||
routerStartedByLabel?.cell?.stringValue = staticStartedByLabelText+" Yes"
|
|
||||||
} else {
|
} else {
|
||||||
routerStartedByLabel?.cell?.stringValue = staticStartedByLabelText+" No"
|
routerStatusLabel?.cell?.stringValue = staticIsRunningLabelText+"Running"
|
||||||
}
|
}
|
||||||
routerStartedByLabel?.needsDisplay = true
|
|
||||||
|
if RouterProcessStatus.isRouterChildProcess {
|
||||||
|
routerStartedByLabel?.cell?.stringValue = staticStartedByLabelText+"Yes"
|
||||||
|
} else {
|
||||||
|
routerStartedByLabel?.cell?.stringValue = staticStartedByLabelText+"No"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try to display PID - if not, the string behind ?? is used as "default"
|
||||||
|
let tmpPidText = RouterManager.shared().lastRouterPid ?? "Not running"
|
||||||
|
routerPIDLabel?.cell?.stringValue = staticRouterPidLabelText+tmpPidText
|
||||||
|
|
||||||
if let version = RouterProcessStatus.routerVersion {
|
if let version = RouterProcessStatus.routerVersion {
|
||||||
routerVersionLabel?.cell?.stringValue = "Router version: " + version
|
routerVersionLabel?.cell?.stringValue = staticRouterVersionLabelText + version
|
||||||
} else {
|
} else {
|
||||||
routerVersionLabel?.cell?.stringValue = "Router version: Still unknown"
|
routerVersionLabel?.cell?.stringValue = staticRouterVersionLabelText + "Still unknown"
|
||||||
}
|
}
|
||||||
|
|
||||||
if let routerStartTime = RouterProcessStatus.routerStartedAt {
|
if let routerStartTime = RouterProcessStatus.routerStartedAt {
|
||||||
routerUptimeLabel?.cell?.stringValue = "Uptime: Router started " + DateTimeUtils.timeAgoSinceDate(date: NSDate(date: routerStartTime), numericDates: false)
|
routerUptimeLabel?.cell?.stringValue = "Uptime: Router started " + DateTimeUtils.timeAgoSinceDate(date: NSDate(date: routerStartTime), numericDates: false)
|
||||||
} else {
|
} else {
|
||||||
routerUptimeLabel?.cell?.stringValue = "Uptime: Router isn't running"
|
routerUptimeLabel?.cell?.stringValue = "Uptime: Router isn't running"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Needs display function alerts the rendrerer that the UI parts need to be re-drawed.
|
||||||
|
routerStartStopButton?.needsDisplay = true
|
||||||
|
quickControlView?.needsDisplay = true
|
||||||
routerUptimeLabel?.needsDisplay = true
|
routerUptimeLabel?.needsDisplay = true
|
||||||
|
routerVersionLabel?.needsDisplay = true
|
||||||
|
routerStartedByLabel?.needsDisplay = true
|
||||||
|
routerPIDLabel?.needsDisplay = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -44,19 +44,22 @@ import Cocoa
|
|||||||
let pidStr = information as! String
|
let pidStr = information as! String
|
||||||
NSLog("PID! %@", pidStr)
|
NSLog("PID! %@", pidStr)
|
||||||
showPopover(sender: nil)
|
showPopover(sender: nil)
|
||||||
//self.ctrl?.getRouterStatusView()?.handlerRouterStart(information: pidStr)
|
RouterManager.shared().lastRouterPid = pidStr
|
||||||
self.ctrl?.getRouterStatusView()?.needsDisplay = true
|
self.ctrl?.getRouterStatusView()?.needsDisplay = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func event_toggle(information:Any?) {
|
||||||
|
self.togglePopover(sender: self)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
override init() {
|
override init() {
|
||||||
super.init()
|
super.init()
|
||||||
self.ctrl = PopoverViewController.freshController()
|
self.ctrl = PopoverViewController.freshController()
|
||||||
popover.contentViewController = self.ctrl
|
popover.contentViewController = self.ctrl
|
||||||
//updateObjectRef = SUUpdater.shared()
|
RouterManager.shared().eventManager.listenTo(eventName: "router_pid", action: pidReaction)
|
||||||
//updateObjectRef?.checkForUpdatesInBackground()
|
|
||||||
RouterManager.shared().eventManager.listenTo(eventName: "router_pid", action: pidReaction)
|
|
||||||
|
|
||||||
|
RouterManager.shared().eventManager.listenTo(eventName: "toggle_popover", action: event_toggle)
|
||||||
|
|
||||||
if let button = statusItem.button {
|
if let button = statusItem.button {
|
||||||
button.image = NSImage(named:"StatusBarButtonImage")
|
button.image = NSImage(named:"StatusBarButtonImage")
|
||||||
|
Reference in New Issue
Block a user