summaryrefslogtreecommitdiff
path: root/ndb/src/cw/cpcc-win32/vb6/Module1.bas
blob: ae8ed444a41be8f83f21f1bc56e2980ea30b03b6 (plain)
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
Attribute VB_Name = "Module1"
Option Explicit
Public fMainForm As frmMain
Public g_computers As New Collection
Public g_databases As New Collection

Sub Main()
    If False Then
        Dim fLogin As New frmLogin
        fLogin.Show vbModal
        If Not fLogin.OK Then
            'Login Failed so exit app
            End
        End If
        Unload fLogin

        frmSplash.Show
        frmSplash.Refresh
    End If
    
    init
    
    Set fMainForm = New frmMain
    Load fMainForm
    Unload frmSplash

    fMainForm.Show
End Sub

Private Sub init()
    Dim c As Computer
    Dim p As Process
        
    ' ---
    ' One node configuration
    '
    Set c = New Computer
    With c
        .m_ip = "130.100.232.31"
        .m_name = "ndb-client31"
        .m_status = "Connected"
        Set .m_processes = New Collection
    End With
    addComputer c
    
    Set p = New Process
    With p
        .m_id = "1"
        .m_name = "mgm-1"
        .m_database = "elathal"
        .m_status = "Running"
        .m_owner = "elathal"
        Set .m_computer = c
    End With
    addProcess c, p
        
    Set p = New Process
    With p
        .m_id = "2"
        .m_name = "ndb-2"
        .m_database = "elathal"
        .m_status = "Running"
        .m_owner = "elathal"
        Set .m_computer = c
    End With
    addProcess c, p

    Set p = New Process
    With p
        .m_id = "3"
        .m_name = "api-3"
        .m_database = "elathal"
        .m_status = "Running"
        .m_owner = "elathal"
        Set .m_computer = c
    End With
    addProcess c, p

    ' ---
    ' Two node configuration
    '
    Set p = New Process
    With p
        .m_id = "4"
        .m_name = "mgm-1"
        .m_database = "ejonore-2-node"
        .m_status = "Running"
        .m_owner = "ejonore"
        Set .m_computer = c
    End With
    addProcess c, p
        
    Set c = New Computer
    With c
        .m_ip = "10.0.1.1"
        .m_name = "cluster-1"
        .m_status = "Connected"
        Set .m_processes = New Collection
    End With
    addComputer c
    
    Set p = New Process
    With p
        .m_id = "1"
        .m_name = "ndb-2"
        .m_database = "ejonore-2-node"
        .m_status = "Running"
        .m_owner = "ejonore"
        Set .m_computer = c
    End With
    addProcess c, p

    Set c = New Computer
    With c
        .m_ip = "10.0.2.1"
        .m_name = "cluster-2"
        .m_status = "Connected"
        Set .m_processes = New Collection
    End With
    addComputer c
    
    Set p = New Process
    With p
        .m_id = "1"
        .m_name = "ndb-3"
        .m_database = "ejonore-2-node"
        .m_status = "Running"
        .m_owner = "ejonore"
        Set .m_computer = c
    End With
    addProcess c, p
    
    Set c = New Computer
    With c
        .m_ip = "10.0.3.1"
        .m_name = "cluster-3"
        .m_status = "Connected"
        Set .m_processes = New Collection
    End With
    addComputer c
    
    Set p = New Process
    With p
        .m_id = "1"
        .m_name = "api-4"
        .m_database = "ejonore-2-node"
        .m_status = "Running"
        .m_owner = "ejonore"
        Set .m_computer = c
    End With
    addProcess c, p
    
    Set c = New Computer
    With c
        .m_ip = "10.0.4.1"
        .m_name = "cluster-4"
        .m_status = "Connected"
        Set .m_processes = New Collection
    End With
    addComputer c
    
    Set p = New Process
    With p
        .m_id = "1"
        .m_name = "api-5"
        .m_database = "ejonore-2-node"
        .m_status = "Running"
        .m_owner = "ejonore"
        Set .m_computer = c
    End With
    addProcess c, p
    
    Set c = New Computer
    With c
        .m_ip = "130.100.232.5"
        .m_name = "ndbs05"
        .m_status = "Not connected"
        Set .m_processes = New Collection
    End With
    addComputer c
    
    Set c = New Computer
    With c
        .m_ip = "130.100.232.7"
        .m_name = "ndb-srv7"
        .m_status = "No contact"
        Set .m_processes = New Collection
    End With
    addComputer c
    
End Sub

Public Sub addComputer(ByRef c As Computer)
    g_computers.Add c, "_" & c.m_name
End Sub

Private Sub addProcess(ByRef c As Computer, ByRef p As Process)
    c.m_processes.Add p, "_" & p.m_id
        
    Dim cl As Database_
    If Not Exists(g_databases, "_" & p.m_database) Then
        Set cl = New Database_
        With cl
            .m_name = p.m_database
            .m_status = "Unknown"
            Set .m_processes = New Collection
        End With
        g_databases.Add cl, "_" & p.m_database
    Else
        Set cl = g_databases("_" & p.m_database)
    End If
    cl.m_processes.Add p, "_" & p.m_computer.m_name & "_" & p.m_id
End Sub

Public Function Exists(ByRef c As Collection, ByVal k As String) As Boolean
    Dim r As Boolean
    Dim o As Object
    
    r = True
    
    On Error GoTo NotFound
    Set o = c.Item(k)
    GoTo Continue
NotFound:
    If Err.Number <> 5 Then
        Err.Raise Err.Number, Err.Source, Err.Description
    End If
    
    r = False
Continue:
    Exists = r
End Function