1 |
william |
4 |
Public Module Settings |
2 |
|
|
|
3 |
|
|
Public Sub OpenRegistry() |
4 |
|
|
GetTFTPdirectory() |
5 |
|
|
Dim objRegkey As Microsoft.Win32.RegistryKey |
6 |
|
|
'Check for registry key if this is first time |
7 |
|
|
'It's OK if the key doesn't exist; we'll write it later |
8 |
|
|
On Error GoTo NoRegKeyFirst 'Reading Registry without permission throws error. Ignore. |
9 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\AnywhereTS\ts-config") |
10 |
|
|
If (objRegkey Is Nothing) Then |
11 |
|
|
#If PRO Then |
12 |
|
|
#Else |
13 |
|
|
Globals.bolDhcpNotInst = True ' The first time we run the app. |
14 |
|
|
#End If |
15 |
|
|
Globals.bolCheckForUpdates = True |
16 |
|
|
Else |
17 |
|
|
If objRegkey.GetValue("CheckUpdate") = 0 Then |
18 |
|
|
Globals.bolCheckForUpdates = False |
19 |
|
|
Else |
20 |
|
|
Globals.bolCheckForUpdates = True |
21 |
|
|
End If |
22 |
|
|
End If |
23 |
|
|
NoRegKeyFirst: |
24 |
|
|
On Error GoTo NoRegKeySecond |
25 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\AnywhereTS\ts-config") |
26 |
|
|
If Not (objRegkey Is Nothing) Then |
27 |
|
|
If Not (objRegkey.GetValue("CheckUpdate") Is Nothing) Then |
28 |
|
|
If objRegkey.GetValue("CheckUpdate") = 0 Then |
29 |
|
|
Globals.bolCheckForUpdates = False |
30 |
|
|
Else |
31 |
|
|
Globals.bolCheckForUpdates = True |
32 |
|
|
End If |
33 |
|
|
Else |
34 |
|
|
Globals.bolCheckForUpdates = True 'if reg key "ts-config" exists, but regkey "CheckUpdate" is missing |
35 |
|
|
End If |
36 |
|
|
If Not (objRegkey.GetValue("appdir") Is Nothing) Then |
37 |
|
|
Globals.strAppdir = objRegkey.GetValue("appdir") |
38 |
|
|
End If |
39 |
|
|
If (objRegkey.GetValue("dhcp_check") = 0) Then |
40 |
|
|
#If PRO Then |
41 |
|
|
#Else |
42 |
|
|
Globals.bolDhcpNotInst = True ' The first time we run the app. |
43 |
|
|
#End If |
44 |
|
|
End If |
45 |
|
|
|
46 |
|
|
End If |
47 |
|
|
NoRegKeySecond: |
48 |
|
|
On Error GoTo 0 |
49 |
|
|
If Globals.strAppdir Is Nothing Then |
50 |
|
|
Globals.strAppdir = System.IO.Path.GetDirectoryName(Application.ExecutablePath) |
51 |
|
|
End If |
52 |
|
|
End Sub |
53 |
|
|
'Check for the TFTPD path in registry. |
54 |
|
|
Public Function GetTFTPdirectory() As String |
55 |
|
|
Dim objRegkey As Microsoft.Win32.RegistryKey |
56 |
|
|
|
57 |
|
|
'Check for registry key for TFTP directory |
58 |
|
|
Globals.strTFTPdir = Nothing |
59 |
|
|
On Error GoTo NoRegKey1 'Reading registry without permission throws error. Ignore. |
60 |
|
|
'Check for MS TFTP first |
61 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\AnywhereTS\ts-config") |
62 |
|
|
If Not (objRegkey Is Nothing) Then |
63 |
|
|
If Not (objRegkey.GetValue("TFTP_root") Is Nothing) Then |
64 |
|
|
Globals.strTFTPdir = objRegkey.GetValue("TFTP_root").ToString |
65 |
|
|
Console.WriteLine("HKLM=" + Globals.strTFTPdir) |
66 |
|
|
End If |
67 |
|
|
End If |
68 |
|
|
NoRegKey1: |
69 |
|
|
On Error GoTo NoRegKey2 |
70 |
|
|
'Check current user |
71 |
|
|
If Globals.strTFTPdir Is Nothing Then |
72 |
|
|
objRegkey = Microsoft.Win32.Registry.CurrentUser.OpenSubKey("SOFTWARE\AnywhereTS\ts-config") |
73 |
|
|
If Not (objRegkey Is Nothing) Then |
74 |
|
|
If Not (objRegkey.GetValue("TFTP_root") Is Nothing) Then |
75 |
|
|
Globals.strTFTPdir = objRegkey.GetValue("TFTP_root").ToString |
76 |
|
|
Console.WriteLine("CURRENT_USER=" + Globals.strTFTPdir) |
77 |
|
|
End If |
78 |
|
|
End If |
79 |
|
|
End If |
80 |
|
|
NoRegKey2: |
81 |
|
|
On Error GoTo -1 |
82 |
|
|
|
83 |
|
|
If Globals.strTFTPdir Is Nothing Then |
84 |
|
|
Globals.strTFTPdir = strAppdir + "\TFTP_root" |
85 |
|
|
Console.WriteLine("tftpdir=" + Globals.strTFTPdir) |
86 |
|
|
End If |
87 |
|
|
|
88 |
|
|
Return Globals.strTFTPdir |
89 |
|
|
End Function |
90 |
|
|
'Set the registry keys for TFTPD32. If bolDHCP then enable DHCP, otherwise just TFTP |
91 |
|
|
Public Sub SetTFTPD32Regkeys(ByVal bolDHCP As Boolean) |
92 |
|
|
Dim objRegkey As Microsoft.Win32.RegistryKey |
93 |
|
|
|
94 |
|
|
On Error GoTo ErrTFTPD32 |
95 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\TFTPD32", True) |
96 |
|
|
If (objRegkey Is Nothing) Then |
97 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.CreateSubKey("SOFTWARE\TFTPD32") |
98 |
|
|
End If |
99 |
|
|
If (objRegkey Is Nothing) Then GoTo ErrTFTPD32 |
100 |
|
|
objRegkey.SetValue("LastWindowPos", "60 49 860 642 ") |
101 |
|
|
objRegkey.SetValue("BaseDirectory", Globals.strTFTPdir) |
102 |
|
|
objRegkey.SetValue("TftpPort", 69) |
103 |
|
|
objRegkey.SetValue("Hide", 0) |
104 |
|
|
objRegkey.SetValue("WinSize", 0) |
105 |
|
|
objRegkey.SetValue("Negociate", 1) |
106 |
|
|
objRegkey.SetValue("PXECompatibility", 0) |
107 |
|
|
objRegkey.SetValue("DirText", 0) |
108 |
|
|
objRegkey.SetValue("ShowProgressBar", 0) |
109 |
|
|
objRegkey.SetValue("Timeout", 3) |
110 |
|
|
objRegkey.SetValue("MaxRetransmit", 6) |
111 |
|
|
objRegkey.SetValue("SecurityLevel", 1) |
112 |
|
|
objRegkey.SetValue("UnixStrings", 1) |
113 |
|
|
objRegkey.SetValue("Beep", 0) |
114 |
|
|
objRegkey.SetValue("VirtualRoot", 1) |
115 |
|
|
If Globals.intNoOfValidAdapters = 1 Then |
116 |
|
|
objRegkey.SetValue("LocalIP", AtsDhcp.strTftpd32IP) |
117 |
|
|
Else |
118 |
|
|
objRegkey.SetValue("LocalIP", AtsDhcp.strTftpd32IP) |
119 |
|
|
End If |
120 |
|
|
If bolDHCP Then |
121 |
|
|
objRegkey.SetValue("Services", 5) 'DHCP + TFTP |
122 |
|
|
Else |
123 |
|
|
objRegkey.SetValue("Services", 1) 'TFTP only |
124 |
|
|
End If |
125 |
|
|
objRegkey.SetValue("TftpLogFile", "") |
126 |
|
|
objRegkey.SetValue("SaveSyslogFile", "") |
127 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\TFTPD32\DHCP", True) |
128 |
|
|
If (objRegkey Is Nothing) Then |
129 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.CreateSubKey("SOFTWARE\TFTPD32\DHCP") |
130 |
|
|
End If |
131 |
|
|
If (objRegkey Is Nothing) Then GoTo ErrTFTPD32 |
132 |
|
|
objRegkey.SetValue("IP_Pool", &H1400DF0A) |
133 |
|
|
objRegkey.SetValue("PoolSize", &HC8) |
134 |
|
|
objRegkey.SetValue("BootFile", "client.zpxe") |
135 |
|
|
objRegkey.SetValue("DNS", &H100DF0A) |
136 |
|
|
objRegkey.SetValue("Mask", &HFFFF) |
137 |
|
|
objRegkey.SetValue("Gateway", &H100DF0A) |
138 |
|
|
objRegkey.SetValue("DomainName", "") |
139 |
|
|
objRegkey.SetValue("AddOptionNumber1", 0) |
140 |
|
|
objRegkey.SetValue("AddOptionValue1", "") |
141 |
|
|
objRegkey.SetValue("AddOptionNumber2", 0) |
142 |
|
|
objRegkey.SetValue("AddOptionValue2", "") |
143 |
|
|
Return |
144 |
|
|
|
145 |
|
|
ErrTFTPD32: |
146 |
|
|
On Error GoTo -1 |
147 |
|
|
MessageBox.Show("Failed to write to registry. Aborting.", "AnywhereTS", MessageBoxButtons.OK, MessageBoxIcon.Asterisk) |
148 |
|
|
Application.Exit() |
149 |
|
|
End Sub |
150 |
|
|
'Set the dhcp_check registry key to the intDHCPcheck global variable value |
151 |
|
|
Public Sub WriteDHCPRegkey(ByVal intDHCPvalue As Integer) |
152 |
|
|
Dim objRegkey As Microsoft.Win32.RegistryKey |
153 |
|
|
|
154 |
|
|
On Error GoTo NoRegWrite |
155 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\AnywhereTS\ts-config", True) |
156 |
|
|
If (objRegkey Is Nothing) Then |
157 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.CreateSubKey("SOFTWARE\AnywhereTS\ts-config") |
158 |
|
|
End If |
159 |
|
|
If (objRegkey Is Nothing) Then GoTo NoRegWrite |
160 |
|
|
objRegkey.SetValue("dhcp_check", intDHCPvalue) |
161 |
|
|
Return |
162 |
|
|
|
163 |
|
|
NoRegWrite: |
164 |
|
|
On Error GoTo -1 |
165 |
|
|
MessageBox.Show("Failed to write to registry. Aborting.", "AnywhereTS", MessageBoxButtons.OK, MessageBoxIcon.Asterisk) |
166 |
|
|
Application.Exit() |
167 |
|
|
End Sub |
168 |
|
|
|
169 |
|
|
'Set the CheckUpdate registry key to the intCheckForUpdates global variable value |
170 |
|
|
Public Sub WriteCheckUpdatesRegkey() |
171 |
|
|
Dim objRegkey As Microsoft.Win32.RegistryKey |
172 |
|
|
|
173 |
|
|
On Error GoTo NoRegWrite |
174 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\AnywhereTS\ts-config", True) |
175 |
|
|
If (objRegkey Is Nothing) Then |
176 |
|
|
objRegkey = Microsoft.Win32.Registry.LocalMachine.CreateSubKey("SOFTWARE\AnywhereTS\ts-config") |
177 |
|
|
End If |
178 |
|
|
If (objRegkey Is Nothing) Then GoTo NoRegWrite |
179 |
|
|
If Globals.bolCheckForUpdates = False Then |
180 |
|
|
objRegkey.SetValue("CheckUpdate", 0) |
181 |
|
|
Else |
182 |
|
|
objRegkey.SetValue("CheckUpdate", 1) |
183 |
|
|
End If |
184 |
|
|
Return |
185 |
|
|
|
186 |
|
|
NoRegWrite: |
187 |
|
|
On Error GoTo -1 |
188 |
|
|
MessageBox.Show("Failed to write to registry. Aborting.", "AnywhereTS", MessageBoxButtons.OK, MessageBoxIcon.Asterisk) |
189 |
|
|
Application.Exit() |
190 |
|
|
End Sub |
191 |
|
|
|
192 |
|
|
End Module |