forked from basildane/WakeOnLAN
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathExplorer.vb
957 lines (764 loc) · 39 KB
/
Explorer.vb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
' WakeOnLAN - Wake On LAN
' Copyright (C) 2004-2019 Aquila Technology, LLC. <[email protected]>
'
' This file is part of WakeOnLAN.
'
' WakeOnLAN is free software: you can redistribute it and/or modify
' it under the terms of the GNU General Public License as published by
' the Free Software Foundation, either version 3 of the License, or
' (at your option) any later version.
'
' WakeOnLAN is distributed in the hope that it will be useful,
' but WITHOUT ANY WARRANTY; without even the implied warranty of
' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
' GNU General Public License for more details.
'
' You should have received a copy of the GNU General Public License
' along with WakeOnLAN. If not, see <http://www.gnu.org/licenses/>.
Imports AlphaWindow
Imports AutoUpdaterDotNET
Imports System.Globalization
Imports System.Linq
Imports System.ComponentModel
Imports System.Threading
Imports Machines
Public Class Explorer
Private ReadOnly _lvwColumnSorter As New ListViewColumnSorter()
Private allowClose As Boolean = False
Private WithEvents _historyBackgroundworker As New BackgroundWorker()
Public Shared Pool As Semaphore = New Semaphore(0, My.Settings.Threads)
Public Sub New()
' This call is required by the designer.
InitializeComponent()
End Sub
Private Sub Explorer_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
Dim auto As New Autorun()
AutoStartWithWindowsToolStripMenuItem.Checked = auto.AutoRun()
Location = My.Settings.MainWindow_Location
Size = My.Settings.MainWindow_Size
If Not IsOnScreen(Me) Then CenterForm(Me)
MenuStrip.Location = New Point(0, 0)
ListView.View = My.Settings.ListView_View
GetListViewState(ListView, My.Settings.ListView_Columns)
ShowGroupsToolStripMenuItem.Checked = My.Settings.ShowGroups
TraceLogToolStripMenuItem.Checked = My.Settings.TraceLog
ToolBarToolStripMenuItem.Checked = My.Settings.ShowToolBar
ToolStrip.Visible = ToolBarToolStripMenuItem.Checked
StatusBarToolStripMenuItem.Checked = My.Settings.ShowStatusBar
StatusStrip.Visible = StatusBarToolStripMenuItem.Checked
SetMinimizeToTray()
If Not My.Settings.ShowHotButtons Then ChangeHotButtonsPanel()
If Not My.Settings.ShowFolders Then ToggleFoldersVisible()
ListView.ShowGroups = My.Settings.ShowGroups
PingToolStripButton.Checked = My.Settings.Pinger
' Scheduling functions are only available in Vista and 2008 and higher
'
ScheduleToolStripMenuItem.Enabled = (Environment.OSVersion.Version.Major >= 6)
ScheduleToolStripButton.Enabled = ScheduleToolStripMenuItem.Enabled
CultureManager_UICultureChanged(Application.CurrentCulture)
SetView(ListView.View)
Machines.Load(Pool)
Machines.Dirty = False
Try
If (My.Application.CommandLineArgs(0) = "/min") Then
Hide()
Else
Show()
End If
Catch ex As Exception
End Try
End Sub
' The form is now shown, release the hold on the thread pool
Private Sub Explorer_Shown(sender As Object, e As EventArgs) Handles Me.Shown
LoadTree()
Pool.Release(My.Settings.Threads)
If My.Settings.autocheckUpdates Then TimerUpdate.Start()
End Sub
Private Sub TimerUpdate_Tick(sender As Object, e As EventArgs) Handles TimerUpdate.Tick
TimerUpdate.Stop()
AutoUpdater.CurrentCulture = Application.CurrentCulture
AutoUpdater.AppCastURL = My.Settings.updateURL
AutoUpdater.versionURL = My.Settings.updateVersions
AddHandler AutoUpdater.UpdateStatus, AddressOf UpdateStatus
AutoUpdater.Start(My.Settings.updateIntervalDays)
End Sub
Private Delegate Sub UpdateStatusHandler(sender As Object, e As AutoUpdateEventArgs)
Private Sub UpdateStatus(sender As Object, e As AutoUpdateEventArgs)
If (InvokeRequired) Then
BeginInvoke(New UpdateStatusHandler(AddressOf UpdateStatus), New Object() {sender, e})
Return
End If
Select Case e.Status
Case AutoUpdateEventArgs.StatusCodes.trace
Tracelog.WriteLine(e.Text)
Case AutoUpdateEventArgs.StatusCodes.updateAvailable
ToolStripStatusLabel2.Text = e.Text
NotifyIconUpdate.Visible = True
NotifyIconUpdate.ShowBalloonTip(0, My.Resources.Strings.Title, e.Text, ToolTipIcon.Info)
Case Else
ToolStripStatusLabel2.Text = e.Text
End Select
If (e.Status <> AutoUpdateEventArgs.StatusCodes.checking) Then
'RemoveHandler AutoUpdater.UpdateStatus, AddressOf UpdateStatus
End If
End Sub
Private Sub NotifyIconUpdate_BalloonTipClicked(sender As Object, e As EventArgs) Handles NotifyIconUpdate.BalloonTipClicked, NotifyIconUpdate.Click
NotifyIconUpdate.Visible = False
AboutBox.ShowDialog(Me)
End Sub
Private Sub SetMinimizeToTray()
MinimizeToTaskTrayToolStripMenuItem.Checked = My.Settings.MinimizeToTray
ShowInTaskbar = Not My.Settings.MinimizeToTray
NotifyIcon1.Visible = My.Settings.MinimizeToTray
End Sub
Private Sub Explorer_FormClosing(ByVal sender As Object, ByVal e As FormClosingEventArgs) Handles Me.FormClosing
If (My.Settings.MinimizeToTray) Then
If (e.CloseReason = CloseReason.UserClosing And allowClose = False) Then
e.Cancel = True
If (Not My.Settings.ackMinimize) Then
MessageBox.Show(My.Resources.Strings.ackMinimized, My.Resources.Strings.Title, MessageBoxButtons.OK, MessageBoxIcon.Information)
My.Settings.ackMinimize = True
End If
WindowState = FormWindowState.Minimized
Exit Sub
End If
End If
SaveChanges()
Tracelog.WriteLine("Explorer_FormClosing, reason: " & e.CloseReason.ToString())
Tracelog.Close()
End Sub
Private Sub SaveChanges()
Tracelog.WriteLine("SaveChanges")
My.Settings.ListView_View = ListView.View
My.Settings.ListView_Columns = SaveListViewState(ListView)
If WindowState = FormWindowState.Normal Then
My.Settings.MainWindow_Location = Location
My.Settings.MainWindow_Size = Size
End If
My.Settings.ShowToolBar = ToolBarToolStripMenuItem.Checked
My.Settings.ShowStatusBar = StatusBarToolStripMenuItem.Checked
My.Settings.ShowGroups = ShowGroupsToolStripMenuItem.Checked
My.Settings.ShowHotButtons = ShowHotButtonsToolStripMenuItem.Checked
My.Settings.ShowFolders = FoldersToolStripMenuItem.Checked
My.Settings.Pinger = PingToolStripButton.Checked
Machines.Save()
Machines.Close()
End Sub
Public Sub TraceEvent(s As String, method As Machine.TraceMethods)
Select Case method
Case Machine.TraceMethods.WriteLine
Tracelog.WriteLine(s)
Case Machine.TraceMethods.Indent
Tracelog.Indent()
Case Machine.TraceMethods.UnIndent
Tracelog.UnIndent()
End Select
End Sub
Public Sub StatusChange(ByVal hostName As String, ByVal Status As Machine.StatusCodes, IPAddress As String)
Try
Try
If Status = Machine.StatusCodes.Uninitialized Then
ListView.Items(hostName).SubItems.Item(1).Text = ListView.Groups.Item(Machine.StatusCodes.Unknown).ToString
Else
ListView.Items(hostName).SubItems.Item(1).Text = ListView.Groups.Item(Status.GetHashCode).ToString
End If
Catch ex As Exception
Tracelog.WriteLine("Explorer::StatusChange::ListView exception: " _
& hostName & ", " & ex.Message _
& ", status " & Status.ToString _
& " item.count: " & ListView.Items.Count)
End Try
'Todo globalize strings
Select Case Status
Case Machine.StatusCodes.Uninitialized
ListView.Items(hostName).ImageIndex = 0
Case Machine.StatusCodes.Unknown
ListView.Items(hostName).ImageIndex = 0
Tracelog.WriteLine("Explorer::StatusChange::" & DateTime.Now.ToLongTimeString & " Host: " & hostName & " [unknown], " & IPAddress)
Case Machine.StatusCodes.Fail
ListView.Items(hostName).ImageIndex = 0
Tracelog.WriteLine("Explorer::StatusChange::" & DateTime.Now.ToLongTimeString & " Host: " & hostName & " [fail], " & IPAddress)
Case Machine.StatusCodes.Offline
If ListView.Items(hostName).ImageIndex = 2 Then
WOL.AquilaWolLibrary.WriteLog(String.Format("Host ""{0}"" is offline.", hostName), EventLogEntryType.Information, WOL.AquilaWolLibrary.EventId.Down)
Tracelog.WriteLine("Explorer::StatusChange::" & DateTime.Now.ToLongTimeString & " Host: " & hostName & " [offline]")
If My.Settings.Sound Then
My.Computer.Audio.Play(My.Resources.down, AudioPlayMode.Background)
End If
If (My.Settings.MinimizeToTray) Then
NotifyIcon1.ShowBalloonTip(5000, hostName, My.Resources.Strings.OffLine, ToolTipIcon.Info)
End If
End If
ListView.Items(hostName).ImageIndex = 1
Case Machine.StatusCodes.Online
If ListView.Items(hostName).ImageIndex = 1 Then
WOL.AquilaWolLibrary.WriteLog(String.Format("Host ""{0}"" is online.", hostName), EventLogEntryType.Information, WOL.AquilaWolLibrary.EventId.Up)
Tracelog.WriteLine("Explorer::StatusChange::" & DateTime.Now.ToLongTimeString & " Host: " & hostName & " [online]")
If My.Settings.Sound Then
My.Computer.Audio.Play(My.Resources.up, AudioPlayMode.Background)
End If
If (My.Settings.MinimizeToTray) Then
NotifyIcon1.ShowBalloonTip(5000, hostName, My.Resources.Strings.OnLine, ToolTipIcon.Info)
End If
End If
ListView.Items(hostName).ImageIndex = 2
ListView.Items(hostName).SubItems(2).Text = IPAddress
Case Else
Tracelog.WriteLine("Explorer::StatusChange::" & DateTime.Now.ToLongTimeString & " Host: " & hostName & " [undefined status] " & Status.ToString)
Debug.Fail("status: " & Status)
End Select
If Status = Machine.StatusCodes.Uninitialized Then Status = Machine.StatusCodes.Unknown
ListView.Items(hostName).Group = ListView.Groups(Status.ToString)
ListView.Sort()
Catch ex As Exception
Tracelog.WriteLine("Explorer::StatusChange exception: " & hostName & ", " & ex.Message)
End Try
End Sub
Private Sub LoadTree()
Dim tvRoot As TreeNode
Dim tvNode As TreeNode
TreeView.SuspendLayout()
TreeView.Nodes.Clear()
tvRoot = TreeView.Nodes.Add(My.Resources.Strings.AllMachines)
Dim groups() As String = (From machine As Machine In Machines
Where machine.Group <> ""
Order By machine.Group
Select machine.Group).Distinct().ToArray()
For Each groupName As String In groups
tvNode = tvRoot.Nodes.Add(groupName)
If My.Settings.CurrentGroup = groupName Then TreeView.SelectedNode = tvNode
Next
If My.Settings.CurrentGroup = tvRoot.Text Then TreeView.SelectedNode = tvRoot
If TreeView.SelectedNode Is Nothing Then TreeView.SelectedNode = tvRoot
TreeView.ResumeLayout()
End Sub
Private Sub TreeView_AfterSelect(ByVal sender As Object, ByVal e As TreeViewEventArgs) Handles TreeView.AfterSelect
My.Settings.CurrentGroup = e.Node.Text
LoadList()
End Sub
Private Sub LoadList()
Dim listViewItem As ListViewItem
ListView.SuspendLayout()
ListView.Sorting = SortOrder.None
ListView.ListViewItemSorter = Nothing
ListView.Items.Clear()
For Each machine As Machine In From m1 As Machine In Machines Where TreeView.SelectedNode.Level = 0 Or TreeView.SelectedNode.Text = m1.Group
listViewItem = ListView.Items.Add(machine.Name, machine.Name, 0)
listViewItem.SubItems.Add(machine.Status.ToString)
listViewItem.SubItems.Add(machine.IP)
listViewItem.SubItems.Add(machine.Netbios)
listViewItem.SubItems.Add(machine.Note)
listViewItem.SubItems.Add(machine.Group)
StatusChange(machine.Name, machine.Status, machine.IP)
Next
ListView.ListViewItemSorter = _lvwColumnSorter
_lvwColumnSorter.SortColumn = My.Settings.SortColumn
_lvwColumnSorter.Order = My.Settings.SortDirection
If (_lvwColumnSorter.SortColumn = 2) Then
_lvwColumnSorter.ObjectType = "IP"
Else
_lvwColumnSorter.ObjectType = "String"
End If
ListView.SetSortIcon(_lvwColumnSorter.SortColumn, _lvwColumnSorter.Order)
ListView.Sort()
ListView.ResumeLayout()
Application.DoEvents()
DoPing()
End Sub
Private Sub DoPing()
For Each machine As Machine In Machines
If PingToolStripButton.Checked Then
If TreeView.SelectedNode.Level = 0 Or TreeView.SelectedNode.Text = machine.Group Then
machine.Run()
Else
machine.Cancel()
End If
Else
machine.Cancel()
End If
Next
End Sub
Private Sub ExitToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ExitToolStripMenuItem.Click
Close()
End Sub
Private Sub ToolBarToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ToolBarToolStripMenuItem.Click
'Toggle the visibility of the toolstrip and also the checked state of the associated menu item
ToolBarToolStripMenuItem.Checked = Not ToolBarToolStripMenuItem.Checked
ToolStrip.Visible = ToolBarToolStripMenuItem.Checked
End Sub
Private Sub StatusBarToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles StatusBarToolStripMenuItem.Click
'Toggle the visibility of the statusstrip and also the checked state of the associated menu item
StatusBarToolStripMenuItem.Checked = Not StatusBarToolStripMenuItem.Checked
StatusStrip.Visible = StatusBarToolStripMenuItem.Checked
End Sub
'Change whether or not the folders pane is visible
Private Sub ToggleFoldersVisible()
'First toggle the checked state of the associated menu item
FoldersToolStripMenuItem.Checked = Not FoldersToolStripMenuItem.Checked
'Change the Folders toolbar button to be in sync
FoldersToolStripButton.Checked = FoldersToolStripMenuItem.Checked
' Collapse the Panel containing the TreeView.
SplitContainer.Panel1Collapsed = Not FoldersToolStripMenuItem.Checked
End Sub
Private Sub FoldersToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles FoldersToolStripMenuItem.Click, FoldersToolStripButton.Click
ToggleFoldersVisible()
End Sub
Private Sub SetView(ByVal view As View)
'Figure out which menu item should be checked
Dim menuItemToCheck As ToolStripMenuItem = Nothing
Select Case view
Case View.Details
menuItemToCheck = DetailsToolStripMenuItem1
Case View.LargeIcon
menuItemToCheck = LargeIconsToolStripMenuItem1
Case View.List
menuItemToCheck = ListToolStripMenuItem1
Case View.SmallIcon
menuItemToCheck = SmallIconsToolStripMenuItem1
Case View.Tile
menuItemToCheck = TileToolStripMenuItem1
Case Else
Debug.Fail("Unexpected View")
view = View.Details
menuItemToCheck = DetailsToolStripMenuItem1
End Select
'Check the appropriate menu item and deselect all others under the Views menu
For Each menuItem As ToolStripMenuItem In ListViewToolStripButton.DropDownItems
If menuItem Is menuItemToCheck Then
menuItem.Checked = True
Else
menuItem.Checked = False
End If
Next
'Finally, set the view requested
ListView.View = view
'ListView.AutoResizeColumns(ColumnHeaderAutoResizeStyle.ColumnContent)
End Sub
Private Sub ListToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ListToolStripMenuItem1.Click
SetView(View.List)
End Sub
Private Sub DetailsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles DetailsToolStripMenuItem1.Click
SetView(View.Details)
End Sub
Private Sub LargeIconsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles LargeIconsToolStripMenuItem1.Click
SetView(View.LargeIcon)
End Sub
Private Sub SmallIconsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles SmallIconsToolStripMenuItem1.Click
SetView(View.SmallIcon)
End Sub
Private Sub TileToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles TileToolStripMenuItem1.Click
SetView(View.Tile)
End Sub
Private Sub ResetWindowLayoutToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ResetWindowLayoutToolStripMenuItem.Click, ResetWindowLayoutToolStripMenuItem1.Click
My.Settings.MinimizeToTray = False
Size = New Size(780, 580)
MinimizeToTaskTrayToolStripMenuItem.Checked = My.Settings.MinimizeToTray
ShowInTaskbar = Not My.Settings.MinimizeToTray
NotifyIcon1.Visible = My.Settings.MinimizeToTray
Show()
WindowState = FormWindowState.Normal
Top = (My.Computer.Screen.WorkingArea.Height \ 2) - (Height \ 2)
Left = (My.Computer.Screen.WorkingArea.Width \ 2) - (Width \ 2)
BringToFront()
Activate()
End Sub
Private Sub PingToolStripButton_Click(ByVal sender As Object, ByVal e As EventArgs) Handles PingToolStripButton.Click
DoPing()
End Sub
Private Sub ShowGroupsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ShowGroupsToolStripMenuItem.Click
ListView.ShowGroups = ShowGroupsToolStripMenuItem.Checked
End Sub
Private Sub ContextMenuStrip_Machines_Opening(ByVal sender As Object, ByVal e As CancelEventArgs) Handles ContextMenuStrip_Machines.Opening
Dim showThem As Boolean
PropertiesToolStripMenuItem.Visible = (ListView.SelectedItems.Count = 1)
showThem = ListView.SelectedItems.Count > 0
WakeUpToolStripMenuItem.Visible = showThem
ToolStripSeparator10.Visible = showThem
ShutdownToolStripMenuItem.Visible = showThem
RDPToolStripMenuItem.Visible = showThem
ClearIPToolStripMenuItem.Visible = showThem
DeleteToolStripMenuItem.Visible = showThem
End Sub
Private Sub ListView_ColumnClick(ByVal sender As Object, ByVal e As ColumnClickEventArgs) Handles ListView.ColumnClick
' Determine if the clicked column is already the column that is
' being sorted.
If (e.Column = _lvwColumnSorter.SortColumn) Then
' Reverse the current sort direction for this column.
If (_lvwColumnSorter.Order = SortOrder.Ascending) Then
_lvwColumnSorter.Order = SortOrder.Descending
Else
_lvwColumnSorter.Order = SortOrder.Ascending
End If
Else
' Set the column number that is to be sorted; default to ascending.
_lvwColumnSorter.SortColumn = e.Column
_lvwColumnSorter.Order = SortOrder.Ascending
End If
If (e.Column = 2) Then
_lvwColumnSorter.ObjectType = "IP"
Else
_lvwColumnSorter.ObjectType = "String"
End If
My.Settings.SortColumn = _lvwColumnSorter.SortColumn
My.Settings.SortDirection = _lvwColumnSorter.Order
' Perform the sort with these new sort options.
ListView.SetSortIcon(_lvwColumnSorter.SortColumn, _lvwColumnSorter.Order)
ListView.Sort()
End Sub
Private Sub ListView_DoubleClick(ByVal sender As Object, ByVal e As EventArgs) Handles ListView.DoubleClick
RemoteCommand(ListView.SelectedItems(0).Name)
End Sub
Private Sub ListView_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs) Handles ListView.SelectedIndexChanged
ToolStripStatusLabel1.Text = String.Empty
ToolStripStatusLabel2.Text = String.Empty
ToolStripProgressBar1.Value = 0
If ListView.SelectedItems.Count = 1 Then
TimerPing.Start()
Else
ResetMonitor()
End If
End Sub
Private Sub ResetMonitor()
TimerPing.Stop()
ToolStripStatusLabel1.Text = String.Empty
ToolStripStatusLabel2.Text = String.Empty
ToolStripProgressBar1.Visible = False
End Sub
Private Sub TimerPing_Tick(ByVal sender As Object, ByVal e As EventArgs) Handles TimerPing.Tick
Dim machine As Machine
Dim i As Integer
If PingToolStripButton.Checked = False Or ListView.SelectedItems.Count <> 1 Then
ResetMonitor()
Exit Sub
End If
machine = Machines(ListView.SelectedItems(0).Name)
Try
Select Case machine.Status
Case Machine.StatusCodes.Unknown
ToolStripStatusLabel1.Text = My.Resources.Strings.OffLine
ToolStripStatusLabel2.Text = String.Format(My.Resources.Strings.HostNotResponding, machine.Name)
ToolStripProgressBar1.Value = 0
Case Machine.StatusCodes.Offline
ToolStripStatusLabel1.Text = My.Resources.Strings.OffLine
ToolStripStatusLabel2.Text = String.Format(My.Resources.Strings.HostNotResponding, machine.Name)
ToolStripProgressBar1.Value = 0
Case Machine.StatusCodes.Online
ToolStripStatusLabel1.Text = My.Resources.Strings.OnLine
i = machine.Reply.RoundtripTime
If i > 10 Then i = 10
ToolStripProgressBar1.Visible = True
ToolStripProgressBar1.Value = 10 - i
ToolStripStatusLabel2.Text = String.Format(My.Resources.Strings.ResponseTime, machine.Name, machine.Reply.RoundtripTime)
End Select
Catch ex As Exception
ResetMonitor()
ToolStripStatusLabel1.Text = ex.Message
End Try
End Sub
Private Sub Button_StartAll_Click(ByVal sender As Object, ByVal e As EventArgs) Handles Button_StartAll.Click
ResetMonitor()
For Each machine As Machine In Machines
ToolStripStatusLabel1.Text = String.Format(My.Resources.Strings.SentTo, machine.Name, machine.MAC)
WakeUp(machine)
Application.DoEvents()
Thread.Sleep(750)
Next
End Sub
Private Sub Button_Emergency_Click(ByVal sender As Object, ByVal e As EventArgs) Handles Button_Emergency.Click
ResetMonitor()
ToolStripStatusLabel1.Text = My.Resources.Strings.EmergencyShutdown
Shutdown.PerformEmergencyShutdown(Me)
End Sub
Private Sub AboutToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles AboutToolStripMenuItem.Click
TimerUpdate.Stop()
AboutBox.ShowDialog(Me)
End Sub
Private Sub ContentsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ContentsToolStripMenuItem.Click
ShowHelp(Me, "default.html")
End Sub
Private Sub SearchForMachinesToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles SearchForMachinesToolStripMenuItem.Click
ResetMonitor()
Search.ShowDialog(Me)
If Search.DialogResult = DialogResult.OK Then
LoadTree()
End If
Search.Dispose()
End Sub
Private Sub WakeUpToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles WakeUpToolStripMenuItem.Click
Dim machine As Machine
For Each listViewItem As ListViewItem In ListView.SelectedItems
machine = Machines(listViewItem.Name)
ToolStripStatusLabel1.Text = String.Format(My.Resources.Strings.SentTo, machine.Name, machine.MAC)
WakeUp(machine)
Next
End Sub
Private Sub OptionsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles OptionsToolStripMenuItem.Click, OptionsToolStripButton.Click
Dim splitter, splitter1 As Integer
Options.ShowDialog(Me)
If (My.Settings.Language <> Application.CurrentCulture.IetfLanguageTag) Then
' save the splitter position, the CultureManager sometimes moves them
'
splitter1 = SplitContainer1.SplitterDistance
splitter = SplitContainer.SplitterDistance
Localization.CultureManager.ApplicationUICulture = New CultureInfo(My.Settings.Language)
LoadTree()
TreeView.SelectedNode = TreeView.Nodes(0)
My.Settings.DefaultMessage = My.Resources.Strings.DefaultMessage
My.Settings.emerg_message = My.Resources.Strings.DefaultEmergency
SplitContainer.SplitterDistance = splitter
SplitContainer1.SplitterDistance = splitter1
End If
End Sub
Private Sub CultureManager_UICultureChanged(newCulture As CultureInfo) Handles CultureManager.UICultureChanged
Text = My.Resources.Strings.Title
NotifyIcon1.Text = My.Resources.Strings.Title
ListView.Groups("Online").Header = My.Resources.Strings.OnLine
ListView.Groups("Offline").Header = My.Resources.Strings.OffLine
ListView.Groups("Unknown").Header = My.Resources.Strings.lit_Unknown
ToolStripStatusLabel1.Text = String.Format(My.Resources.Strings.Version, My.Application.Info.Version.Major, My.Application.Info.Version.Minor, My.Application.Info.Version.Build, My.Application.Info.Version.Revision)
ToolStripStatusLabel2.Text = String.Empty
End Sub
Private Sub RDPToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles RDPToolStripMenuItem.Click
RemoteCommand(ListView.SelectedItems(0).Name)
End Sub
Private Sub ShutdownToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ShutdownToolStripMenuItem.Click
Dim items As String()
ResetMonitor()
items = ListView.SelectedItems.Cast(Of ListViewItem).Select(Function(lvi As ListViewItem) lvi.Text).ToArray()
Shutdown.PerformShutdown(Me, items)
End Sub
Private Sub PropertiesToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles PropertiesToolStripMenuItem.Click
Properties.Edit(ListView.SelectedItems(0).Name)
If Properties.DialogResult = DialogResult.OK Then
LoadTree()
End If
Properties.Dispose()
End Sub
Private Sub NewToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles NewToolStripMenuItem.Click, NewToolStripMenuItem1.Click
Properties.Create()
If Properties.DialogResult = DialogResult.OK Then
LoadTree()
End If
Properties.Dispose()
End Sub
Private Sub ImportToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ImportToolStripMenuItem.Click
Dim fileBrowser As New OpenFileDialog
With fileBrowser
.Filter = "All files (*.*)|*.*"
.Title = My.Resources.Strings.SelectFile
.ShowDialog(Me)
If String.IsNullOrEmpty(.FileName) Then Exit Sub
Machines.Import(.FileName)
End With
LoadList()
MsgBox(String.Format(My.Resources.Strings.ImportedFrom, fileBrowser.FileName), MsgBoxStyle.Information)
End Sub
Private Sub ExportToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ExportToolStripMenuItem.Click
Dim fileBrowser As New SaveFileDialog
With fileBrowser
.CheckFileExists = False
.Title = My.Resources.Strings.WhereSave
.Filter = "All files (*.*)|*.*"
.ShowDialog(Me)
If String.IsNullOrEmpty(.FileName) Then Exit Sub
Machines.Export(.FileName)
End With
MsgBox(String.Format(My.Resources.Strings.ExportedTo, fileBrowser.FileName), MsgBoxStyle.Information)
End Sub
Private Sub ClearIPToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles ClearIPToolStripMenuItem.Click
Dim m As Machine
If MessageBox.Show(String.Format(My.Resources.Strings.AreYouSure), String.Format(My.Resources.Strings.lit_RemoveIP, ListView.SelectedItems.Count), MessageBoxButtons.YesNo, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1) = DialogResult.Yes Then
For Each l As ListViewItem In ListView.SelectedItems
m = Machines(l.Name)
m.IP = String.Empty
Machines.Update(m)
l.SubItems(2).Text = String.Empty
Next
End If
End Sub
Private Sub DeleteToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles DeleteToolStripMenuItem.Click
If MessageBox.Show(String.Format(My.Resources.Strings.AreYouSure), String.Format(My.Resources.Strings.lit_DeleteRecords, ListView.SelectedItems.Count), MessageBoxButtons.YesNo, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1) = DialogResult.Yes Then
For Each l As ListViewItem In ListView.SelectedItems
Machines.Remove(l.Name)
l.Remove()
Next
Machines.Save()
End If
End Sub
Private Sub ShowHotButtonsToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ShowHotButtonsToolStripMenuItem.Click, HotToolStripButton.Click
ChangeHotButtonsPanel()
End Sub
Private Sub ChangeHotButtonsPanel()
SplitContainer1.Panel2Collapsed = Not SplitContainer1.Panel2Collapsed
ShowHotButtonsToolStripMenuItem.Checked = Not SplitContainer1.Panel2Collapsed
If SplitContainer1.Panel2Collapsed Then
HotToolStripButton.Checked = False
ShowHotButtonsToolStripMenuItem.Checked = False
Else
HotToolStripButton.Checked = True
ShowHotButtonsToolStripMenuItem.Checked = True
End If
End Sub
Private Sub PrintToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles PrintToolStripMenuItem.Click
ReportViewer.Show(Me)
End Sub
Private Sub ScheduleToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles ScheduleToolStripMenuItem.Click, ScheduleToolStripButton.Click
Try
Schedule.Schedule.Show(Me)
Catch
End Try
End Sub
Private Sub LicenseToolStripMenuItem_Click(ByVal sender As Object, ByVal e As EventArgs) Handles LicenseToolStripMenuItem.Click
License.ShowDialog(Me)
End Sub
Private Sub ContextToolStripMenuItemOpen_Click(sender As Object, e As EventArgs) Handles ContextToolStripMenuItemOpen.Click, NotifyIcon1.DoubleClick
Show()
WindowState = FormWindowState.Normal
BringToFront()
Activate()
End Sub
Private Sub ContextToolStripMenuItemExit_Click(sender As Object, e As EventArgs) Handles ContextToolStripMenuItemExit.Click
allowClose = True
Close()
End Sub
Private Sub MinimizeToTaskTrayToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles MinimizeToTaskTrayToolStripMenuItem.Click
My.Settings.MinimizeToTray = Not My.Settings.MinimizeToTray
SetMinimizeToTray()
End Sub
Private Sub AutoStartWithWindowsToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles AutoStartWithWindowsToolStripMenuItem.Click
Dim auto As New Autorun
AutoStartWithWindowsToolStripMenuItem.Checked = Not AutoStartWithWindowsToolStripMenuItem.Checked
auto.AutoRun = AutoStartWithWindowsToolStripMenuItem.Checked
End Sub
Private Sub Explorer_Resize(sender As Object, e As EventArgs) Handles MyBase.Resize
If (WindowState = FormWindowState.Minimized And My.Settings.MinimizeToTray = True) Then
Hide()
End If
End Sub
Private Sub ToolStripMenuItemWakeUp_Opening(sender As Object, e As EventArgs) Handles TrayMenuItemWakeUp.DropDownOpening
' load all of the machines into the task tray menu
'
TrayMenuItemWakeUp.DropDownItems.Clear()
For Each s As String In (From machine As Machine In Machines
Order By machine.Name
Select machine.Name).ToArray()
Dim item As ToolStripMenuItem = New ToolStripMenuItem() With {
.Name = s,
.Text = s
}
TrayMenuItemWakeUp.DropDownItems.Add(item)
AddHandler item.Click, AddressOf TaskTrayWake_Click
Next
End Sub
Private Sub TaskTrayWake_Click(sender As Object, e As EventArgs)
Dim item As ToolStripMenuItem = TryCast(sender, ToolStripMenuItem)
Dim machine As Machine
If item IsNot Nothing Then
machine = Machines(item.Name)
ToolStripStatusLabel1.Text = String.Format(My.Resources.Strings.SentTo, machine.Name, machine.MAC)
WakeUp(machine)
End If
End Sub
Private Sub ToolStripMenuItemRDP_Opening(sender As Object, e As EventArgs) Handles TrayMenuItemRDP.DropDownOpening
' load all of the machines into the task tray menu
'
TrayMenuItemRDP.DropDownItems.Clear()
For Each s As String In (From machine As Machine In Machines
Order By machine.Name
Select machine.Name).ToArray()
Dim item As ToolStripMenuItem = New ToolStripMenuItem() With {
.Name = s,
.Text = s
}
TrayMenuItemRDP.DropDownItems.Add(item)
AddHandler item.Click, AddressOf TaskTrayRDP_Click
Next
End Sub
Private Sub TaskTrayRDP_Click(sender As Object, e As EventArgs)
Dim item As ToolStripMenuItem = TryCast(sender, ToolStripMenuItem)
RemoteCommand(item.Name)
End Sub
Private Sub ShutdownToolStripMenuItem_Opening(sender As Object, e As EventArgs) Handles TrayMenuItemShutdown.DropDownOpening
' load all of the machines into the task tray menu
'
TrayMenuItemShutdown.DropDownItems.Clear()
For Each s As String In (From machine As Machine In Machines
Order By machine.Name
Select machine.Name).ToArray()
Dim item As ToolStripMenuItem = New ToolStripMenuItem() With {
.Name = s,
.Text = s
}
TrayMenuItemShutdown.DropDownItems.Add(item)
AddHandler item.Click, AddressOf TaskTrayShutdown_Click
Next
End Sub
Private Sub TaskTrayShutdown_Click(sender As Object, e As EventArgs)
Dim item As ToolStripMenuItem = TryCast(sender, ToolStripMenuItem)
Dim items() As String
Dim machine As Machine
If item IsNot Nothing Then
machine = Machines(item.Name)
items = {item.Name}
Shutdown.PerformShutdown(Me, items)
Shutdown.Show()
End If
End Sub
Private Sub ListenToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles ListenToolStripMenuItem.Click, ListenerToolStripButton.Click
My.Forms.Listener.Show()
End Sub
' TreeView context menu
Private Sub WakeUpToolStripMenuItem1_Click(sender As Object, e As EventArgs) Handles WakeUpToolStripMenuItem1.Click
Dim machine As Machine
For Each l As ListViewItem In ListView.Items
machine = Machines(l.Name)
ToolStripStatusLabel1.Text = String.Format(My.Resources.Strings.SentTo, machine.Name, machine.MAC)
WakeUp(machine)
Next
End Sub
Private Sub ShutDownToolStripMenuItem1_Click(sender As Object, e As EventArgs) Handles ShutDownToolStripMenuItem1.Click
Dim items As String()
ResetMonitor()
items = ListView.Items.Cast(Of ListViewItem).Select(Function(lvi As ListViewItem) lvi.Text).ToArray()
Shutdown.PerformShutdown(Me, items)
End Sub
' if user right-clicks a group, select that group
Private Sub TreeView_NodeMouseClick(sender As Object, e As TreeNodeMouseClickEventArgs) Handles TreeView.NodeMouseClick
If e.Button = MouseButtons.Right Then
TreeView.SelectedNode = e.Node
End If
End Sub
Private Sub DonateToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles DonateToolStripMenuItem.Click
Process.Start(My.Settings.donate)
End Sub
Private Sub EventLogToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles EventLogToolStripMenuItem.Click, EventLogToolStripButton.Click
If (Not _historyBackgroundworker.IsBusy) Then
_historyBackgroundworker.RunWorkerAsync(Thread.CurrentThread.CurrentUICulture)
End If
End Sub
Private Sub HistoryBackgroundworker_DoWork(ByVal sender As Object, ByVal e As DoWorkEventArgs) Handles _historyBackgroundworker.DoWork
Thread.CurrentThread.CurrentUICulture = e.Argument
History.ShowDialog()
End Sub
Private Sub ToolStripMenuItemWakeUp_Click(sender As Object, e As EventArgs) Handles TrayMenuItemWakeUp.Click
'TODO
End Sub
Private Sub Explorer_Closing(sender As Object, e As CancelEventArgs) Handles Me.Closing
My.Settings.Save()
End Sub
Private Sub TraceLogToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles TraceLogToolStripMenuItem.Click
My.Settings.TraceLog = TraceLogToolStripMenuItem.Checked
If TraceLogToolStripMenuItem.Checked = True Then
If MessageBox.Show("Tracing enabled. WOL will now restart.", "AquilaWOL", MessageBoxButtons.OKCancel, MessageBoxIcon.Information) = DialogResult.OK Then
Application.Restart()
End If
Else
Tracelog.Close()
End If
End Sub
Private Sub MessageToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles MessageToolStripMenuItem.Click
Dim Send As New SendMessage(ListView.SelectedItems.Cast(Of ListViewItem).Select(Function(lvi As ListViewItem) lvi.Text).ToArray())
End Sub
Private Sub TrayMenuItemRDP_Click(sender As Object, e As EventArgs) Handles TrayMenuItemRDP.Click
End Sub
End Class