root/tags/REL-0.0.9beta/trunk/tool/renetcolGUI_0_0_7.py @ 38

Revision 38, 46.8 KB (checked in by andreu, 16 years ago)

ticket #9 correction

  • Property svn:eol-style set to native
Line 
1
2##  File: renetcolGUI_0_0_7.py
3 
4##  Authors: ANDREU Francois-Xavier
5 
6##  Copyright (C) 2005 GIP RENATER
7 
8
9##   This file is part of renetcol.
10 
11##   renetcol is free software; you can redistribute it and/or modify
12##   it under the terms of the GNU General Public License as published by
13##   the Free Software Foundation; either version 2 of the License, or
14##   (at your option) any later version.
15 
16##   renetcol is distributed in the hope that it will be useful,
17##   but WITHOUT ANY WARRANTY; without even the implied warranty of
18##   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19##   GNU General Public License for more details.
20 
21##   You should have received a copy of the GNU General Public License
22##   along with renetcol; if not, write to the Free Software
23##   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
24 
25
26# Make Windows actually find the stuff installed
27# You must check up if it's the good path to GTK
28gtkdir = 'C:/Program Files/Fichiers communs/GTK/'
29
30import os
31import binascii
32import struct
33import time
34os.environ['PATH'] += ";%s/lib;%s/bin" % (gtkdir, gtkdir)
35
36import threading
37import string
38import re
39import socket
40import sys
41import gtk
42import traceback
43import pango
44import commands
45
46########### DEFAULT VALUES, YOU MUST CHANGE IT ###############################
47IPversion = 4
48localAddr = ''
49localAddr6 = '2001:660:3001:4012:30ec:9207:2a75:1583'
50localPort = 2222
51collectorAddr = "193.51.183.225"
52collectorAddr6 = "2001:660:3000:1011:10::"
53collectorPort = 52571  # if you change it, apply the modification on
54                       # the renetcolSender.h file and recompil the collector
55##############################################################################
56
57myInputControlThread = None
58printValue =      [ 0,1,1,0,1,0,0,1,1,0,
59                    0,1,1,0,0,0,0,0,0,0,
60                    1,0,0,0,0,0,0,1,1,0,
61                    0,0,0,0,0,0,0,0,0,0,
62                    0,0,0,0,0,0,1,1,0,0,
63                    0,0,0,0,0,0,0,0,0,0,
64                    0,0,0,0,0,0,0,0,0,0,
65                    1,1,1,1,1,1,1,1,1,1,
66                    0,0,0,0,0,0,0,0,0,0
67                    ]
68firstParseValue = [ 0,0,0,0,0,0,0,0,0,0,
69                    0,0,0,0,0,0,0,0,0,0,
70                    0,0,0,0,0,0,0,0,0,0,
71                    0,0,0,0,0,0,0,0,0,0,
72                    0,0,0,0,0,0,0,0,0,0,
73                    0,0,0,0,0,0,0,0,0,0,
74                    0,0,0,0,0,0,0,0,0,0,
75                    0,0,0,0,0,0,0,0,0,0,
76                    0,0,0,0,0,0,0,0,0,0
77                    ]
78checkUpValues =   [ 0,0,0,0,0,0,0,0,0,0,
79                    0,0,0,0,0,0,0,0,0,0,
80                    0,0,0,0,0,0,0,0,0,0,
81                    0,0,0,0,0,0,0,0,0,0,
82                    0,0,0,0,0,0,0,0,0,0,
83                    0,0,0,0,0,0,0,0,0,0,
84                    0,0,0,0,0,0,0,0,0,0,
85                    0,0,0,0,0,0,0,0,0,0,
86                    0,0,0,0,0,0,0,0,0,0
87                    ]
88fieldsName =  [ "","IN_BYT","IN_PKTS","","PROT","TOS","TCP_FL","S_PORT","IPv4@S","S_MASK",
89                "InSNMP","D_PORT","IPv4@D","D_MASK","OutSNMP","NextHop","S_AS","D_AS","","",
90                "","Time","","","","","","IPv6@S","IPv6@D","",
91                "","","","","","","","","","",
92                "","","","","","","M_T_L_T","M_T_L_@","","",
93                "","","","","","","","","","",
94                "","","","","","","","","","ROUTER",
95                "M_L_1","M_L_2","M_L_3","M_L_4","M_L_5","M_L_6","M_L_7","M_L_8","M_L_9","M_L_10",
96                "","","","","","","","","",""
97                ]
98flowCpt = 0
99mask = [ 0,0,0 ]
100spaceSep = " "
101tabSep = "\t"
102freeze = 0
103record = 0
104record_file_name = ""
105record_file = None
106is_already_see = 0
107collectorRule=""
108coll_window = gtk.Window()
109router=0
110tpl_def = {}
111os_type = 0
112oldTpl = 0
113fromRouter = ""
114
115class InputControl(threading.Thread):
116    def kill(self, timeout):
117        self.imRunning = 0
118        time.sleep(1)
119        print "\n.\n..\n..."
120        time.sleep(1)
121        print "....\n.....\n......"       
122        time.sleep(1)
123        if self.myFlowInput:
124            self.myFlowInput.socket_close()
125        self.join(timeout)
126       
127    def __init__(self, address, port):
128        self.imRunning = 1
129        self.currentflow = None
130        threading.Thread.__init__(self)
131        self.myFlowInput = FlowInput(address, port)
132
133    def run(self):
134        global freeze, record
135        while self.imRunning:
136            if self.myFlowInput:
137                tmp = self.myFlowInput.get_flow()
138                if (tmp[0]!=None):
139                    self.currentflow = Flow(tmp)
140                    if (freeze==0) & self.currentflow.enable():
141                        self.currentflow.print_flow2()
142                    if (record==1) & self.currentflow.enable():
143                        self.currentflow.write_flow2()
144##                else:
145##                    self.myFlowInput = None
146   
147class Flow:
148    def __init__(self, data):
149        self.flow = [ data[0], data[1] ]
150
151    def enable(self):
152        global firstParseValue, checkUpValues, tpl_def
153        res = 1
154        ctrl = 0
155        portS = 0
156        portD = 0
157        for i in range (0, len(tpl_def[self.flow[0]])):
158            f = tpl_def[self.flow[0]][i][0]
159            if ( f==8 or f==12 or f==15 or f==18 or f==47) and ( checkUpValues[f]==1 ):
160                res = res & ( ((struct.unpack('>L',(socket.inet_aton(self.flow[1][i])))[0] & mask[1-1]) == firstParseValue[f])| ((struct.unpack('>L',(socket.inet_aton(self.flow[1][i])))[0] & mask[1-1]) == firstParseValue[f]) )
161            elif ( i==27 or i==28 ):
162                pass
163            elif ( f==7 ) and ( checkUpValues[f]==1 ):
164                if (ctrl == 1):                   
165                    res = res & (((self.flow[1][i] >= firstParseValue[f])&(self.flow[1][i] <= firstParseValue[11])) or ((portD >= firstParseValue[f])&(portD <= firstParseValue[11])))
166                else:
167                    ctrl = 1
168                    portS = self.flow[1][i]
169            elif ( f==11 ) and ( checkUpValues[f]==1 ):
170                if (ctrl == 1):
171                    res = res & (((self.flow[1][i] <= firstParseValue[f])&(self.flow[1][i] >= firstParseValue[7])) or ((portS >= firstParseValue[7])&(portS <= firstParseValue[f])))
172                else:
173                    ctrl = 1
174                    portD = self.flow[1][i]
175            elif (checkUpValues[f]==1):
176                res = res & (self.flow[1][i] == firstParseValue[f])
177        return res
178               
179    def print_flow2(self):
180        global printValue, tpl_def, flowCpt, fieldsName, oldTpl, os_type, fromRouter
181        myliste = []
182        myTpl = []
183        strFlow = ""
184        strField = ""
185        underscore_line = ""
186        flowCpt+=1
187        if (flowCpt%20 == 0 or oldTpl != self.flow[0]):
188            flowCpt = 0
189            for i in range (0, len(tpl_def[self.flow[0]])):
190                f = tpl_def[self.flow[0]][i][0]
191                if printValue[f]:
192                    if ( f==27 or f==28 or f==62 or f==63 ):
193                        strField += str(fieldsName[f])
194                        l = len(str(fieldsName[f]))
195                        if ((40-l)%8 == 0):
196                            tabNb = int((40-l)/8)
197                        else:
198                            tabNb = int((40-l)/8) + 1
199                        for j in range (0, tabNb):
200                            strField += "\t"
201                        for k in range (0, 40):
202                            underscore_line += "-"
203                    elif ( f==8 or f==15 or f==12 or f==18 or f==47 ):
204                        strField += str(fieldsName[f])
205                        l = len(str(fieldsName[f]))
206                        if ((16-l)%8 == 0):
207                            tabNb = int((16-l)/8)
208                        else:
209                            tabNb = int((16-l)/8) + 1
210                        for j in range (0, tabNb):
211                            strField += "\t"
212                        for k in range (0, 16):
213                            underscore_line += "-"
214                    else:
215                        strField += str(fieldsName[f])
216                        strField += "\t"
217                        for k in range (0, 8):
218                            underscore_line += "-"
219            if (oldTpl != self.flow[0]):
220                print " "
221            if (os_type == 0):
222                esc = '\x1b['
223                sep = ';'
224                end = 'm'
225                if (printValue[69]):
226                    rt = str(fieldsName[69])
227                    toprint = esc+"37"+sep+"44"+end+strField+rt+esc+"0"+end
228                else:
229                    toprint = esc+"37"+sep+"44"+end+strField+esc+"0"+end
230                print toprint
231            else:
232                if (printValue[69]):
233                    strField += str(fieldsName[69])
234                print strField
235                print underscore_line
236        for i in range (0, len(tpl_def[self.flow[0]])):
237            f = tpl_def[self.flow[0]][i][0]
238            if printValue[f]:
239                if ( f==27 or f==28 or f==62 or f==63 ):
240                    strFlow += str(self.flow[1][i])
241                    l = len(str(self.flow[1][i]))
242                    if ((40-l)%8 == 0):
243                        tabNb = int((40-l)/8)
244                    else:
245                        tabNb = int((40-l)/8) + 1
246                    for j in range (0, tabNb):
247                        strFlow += "\t"
248                elif ( f==8 or f==12 or f==15 or f==18 or f==47 ):
249                    strFlow += str(self.flow[1][i])
250                    l = len(str(self.flow[1][i]))
251                    if ((16-l)%8 == 0):
252                        tabNb = int((16-l)/8)
253                    else:
254                        tabNb = int((16-l)/8) + 1
255                    for j in range (0, tabNb):
256                        strFlow += "\t"
257                elif (f==21):
258                    myliste += [str(self.flow[1][i]-self.flow[1][i+1])]
259                    strFlow += str(self.flow[1][i]-self.flow[1][i+1])
260                    strFlow += "\t"
261                elif (f==22):
262                    pass
263                else:
264                    myliste += [str(self.flow[1][i])]
265                    strFlow += str(self.flow[1][i])
266                    for k in range (len(str(self.flow[1][i])), 7):
267                        strFlow += " "
268                    strFlow += "\t"
269        if (printValue[69]):
270            strFlow += fromRouter
271        print strFlow
272        oldTpl = self.flow[0]
273
274    def write_flow2(self):
275        global printValue, record_file, tpl_def
276        myliste = []
277        for i in range (0, len(tpl_def[self.flow[0]])):
278            f = tpl_def[self.flow[0]][i][0]
279            if printValue[f]:
280                if (f==21):
281                    myliste += [str(self.flow[1][i]-self.flow[1][i+1])]
282                elif (f==22):
283                    pass
284                else:
285                    myliste += [str(self.flow[1][i])]
286        theflow = string.join(myliste, "\t")+"\n" 
287        record_file.write(theflow)
288       
289class FlowInput:
290    def __init__(self, h, p):
291        self.HOST = h
292        self.PORT = p
293        if (IPversion == 4):
294            self.socketnumber = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
295        elif (IPversion == 6):
296            self.socketnumber = socket.socket(socket.AF_INET6, socket.SOCK_DGRAM)
297        else:
298            print "IP protocol ", IPversion ," not supported"
299            exit(0)
300        self.socketnumber.bind((self.HOST, self.PORT))
301   
302    def get_flow(self):
303        global collectorRule, tpl_def, os_type, fromRouter
304        if (self.socketnumber!=None):
305            data = self.socketnumber.recvfrom(1024)
306            flow = data[0]
307            code = struct.unpack('<H', flow[0:2])
308            if (code[0] == 1): ## a def packet
309                routerSrc = struct.unpack('<L', flow[2:6])
310                sourceId = struct.unpack('<L', flow[6:10])
311                tplId = struct.unpack('<H', flow[10:12])
312                mykeylst = []
313                mykeylst += [str(routerSrc[0])]
314                mykeylst += [str(sourceId[0])]
315                mykeylst += [str(tplId[0])]
316                mykeystr = string.join(mykeylst,"");
317                fields = []
318                fieldNb = struct.unpack('<H', flow[12:14])
319                for i in range(0, fieldNb[0]):
320                    fd = struct.unpack('<H',flow[14+(i*4):16+(i*4)])
321                    tp = struct.unpack('<H',flow[14+(2+i*4):16+(2+i*4)])
322                    fields.insert(i,(fd[0],tp[0]))
323                tpl_def[mykeystr] = fields
324                return ( None, None)
325            if (code[0]==11): ## a data packet
326                routerSrc = struct.unpack('<L', flow[4:8])
327                tmp =  struct.unpack('<L', flow[4:8])
328                fromRouter = socket.inet_ntoa(struct.pack('>L', tmp[0]))
329                sourceId = struct.unpack('<L', flow[8:12])
330                tplId = struct.unpack('<H', flow[12:14])
331                mykeylst = []
332                mykeylst += [str(routerSrc[0])]
333                mykeylst += [str(sourceId[0])]
334                mykeylst += [str(tplId[0])]
335                mykeystr = string.join(mykeylst,"")
336                if (tpl_def.has_key(mykeystr)== True):
337                    field_list = []
338                    index = 0
339                    for i in range (0, len(tpl_def[mykeystr])):
340                        if (tpl_def[mykeystr][i][1]==1):
341                            value = struct.unpack('<B',flow[14+index:15+index])
342                            field_list.insert(i,value[0])
343                        if (tpl_def[mykeystr][i][1]==2):
344                            value = struct.unpack('>H',flow[14+index:16+index])
345                            field_list.insert(i,value[0])
346                        if (tpl_def[mykeystr][i][1]==3):
347                            value = struct.unpack('<BBB',flow[14+index:17+index])
348                            valueTmp = struct.pack('<BBBB',value[2],value[1],value[0],0)
349                            valueFinal = struct.unpack('<L', valueTmp)
350                            valueFinal2 = (valueFinal[0])>>4
351                            field_list.insert(i,valueFinal2)
352                        if (tpl_def[mykeystr][i][1]==4):
353                            if (tpl_def[mykeystr][i][0]==8 or tpl_def[mykeystr][i][0]==12 or tpl_def[mykeystr][i][0]==15 or tpl_def[mykeystr][i][0]==18 or tpl_def[mykeystr][i][0]==47):
354                                value = socket.inet_ntoa(flow[14+index:18+index])
355                                field_list.insert(i,value)
356                            else:
357                                value = struct.unpack('<L', flow[14+index:18+index])
358                                value = struct.unpack('>L', flow[14+index:18+index])
359                                field_list.insert(i,value[0])
360                        if (tpl_def[mykeystr][i][1]==16):
361                            if (os_type==1):
362                                field_list.insert(i,nt_inet_ntop(flow[14+index:30+index]))
363                            else:
364                                tmp = socket.inet_ntop(socket.AF_INET6,flow[14+index:30+index])
365                                field_list.insert(i,tmp)
366                        index += tpl_def[mykeystr][i][1]
367                    return mykeystr, field_list
368##                else:
369##                  print "I'm waiting the tpl def for the key", mykeystr
370##                return (routerSrc[0], field_list)
371            return ( None, None)
372        return ( None, None)
373
374    def socket_close(self):
375        if self.socketnumber:
376           try :
377               self.socketnumber.shutdown(2)
378               self.socketnumber = None
379           except socket.error:
380              pass
381
382class FileSel:
383    def file_ok_sel(self, w):
384        global record, record_file, record_file_name
385        record = 1
386        record_file_name = self.fileSel.get_filename()
387        record_file = file(record_file_name, 'w')
388        print "%s" % self.fileSel.get_filename()
389        self.fileSel.destroy()
390
391    def destroy(self, widget):
392        self.fileSel.destroy()
393
394    def __init__(self):
395        self.fileSel = gtk.FileSelection("File Selection")
396        self.fileSel.connect("destroy", self.destroy)
397        self.fileSel.ok_button.connect("clicked", self.file_ok_sel)
398        self.fileSel.cancel_button.connect("clicked",
399                                           lambda w: self.fileSel.destroy())
400        self.fileSel.set_filename("flow_record.txt")
401        self.fileSel.show()
402
403def print_hello(widget, event):
404    print "Hello, World!"
405
406def nt_inet_ntop(packed_ip):
407    cpt = 0
408    double = 0
409    string_ip = ""
410    tmp = binascii.hexlify(packed_ip[0:2])
411    if ( int(tmp,16)!=0 ):
412        string_ip += tmp
413        tmp = binascii.hexlify(packed_ip[2:4])
414        if ( int(tmp,16)==0 ):
415            cpt+=1
416            double = 1
417            if (cpt==1):
418                string_ip += ":"
419        else:
420            cpt=0
421            string_ip += ":"+tmp
422        tmp = binascii.hexlify(packed_ip[4:6])
423        if ( int(tmp,16)==0 ):
424            cpt+=1
425            double = 1
426            if (cpt==1):
427                string_ip += ":"
428        else:
429            cpt=0
430            string_ip += ":"+tmp
431        tmp = binascii.hexlify(packed_ip[6:8])
432        if ( int(tmp,16)==0 ):
433            if (double==1 and cpt==0):
434                string_ip += ":0"
435            else:
436                cpt+=1
437                double = 1
438                if (cpt==1):
439                    string_ip += ":"
440        else:
441            cpt=0
442            string_ip += ":"+tmp
443        tmp = binascii.hexlify(packed_ip[8:10])
444        if ( int(tmp,16)==0 ):
445            if (double==1 and cpt==0):
446                string_ip += ":0"
447            else:
448                cpt+=1
449                double = 1
450                if (cpt==1):
451                    string_ip += ":"
452        else:
453            cpt=0
454            string_ip += ":"+tmp
455        tmp = binascii.hexlify(packed_ip[10:12])
456        if ( int(tmp,16)==0 ):
457            if (double==1 and cpt==0):
458                string_ip += ":0"
459            else:
460                cpt+=1
461                double = 1
462                if (cpt==1):
463                    string_ip += ":"
464        else:
465            cpt=0
466            string_ip += ":"+tmp
467        tmp = binascii.hexlify(packed_ip[12:14])
468        if ( int(tmp,16)==0 ):
469            if (double==1 and cpt==0):
470                string_ip += ":0"
471            else:
472                cpt+=1
473                double = 1
474                if (cpt==1):
475                    string_ip += ":"
476        else:
477            cpt=0
478            string_ip += ":"+tmp
479        tmp = binascii.hexlify(packed_ip[14:16])
480        if ( int(tmp,16) != 0 ):
481            string_ip += ":"+tmp
482        else:
483            string_ip += ":"
484    else:
485        string_ip = "::"
486    return string_ip
487
488def get_main_menu(self, window):
489    accel_group = gtk.AccelGroup()
490    item_factory = gtk.ItemFactory(gtk.MenuBar, "<main>", accel_group)
491    item_factory.create_items(menu_items)
492    window.add_accel_group(accel_group)
493    item_factory = item_factory
494    return item_factory.get_widget("<main>")
495
496def reception(widget, event):
497    global myInputControlThread
498    global localAddr, localPort
499    myInputControlThread = InputControl(localAddr, localPort)
500    myInputControlThread.start()
501
502def close_recept(widget, event):
503    global myInputControlThread
504    if myInputControlThread != None:
505        myInputControlThread.kill(1)
506        myInputControlThread = None
507        print "\n\n\n\n\n Input Stream closed. \n\n\n\n\n"
508
509def about_dialog(widget, event):
510    dialog = gtk.MessageDialog(
511        parent         = None,
512        flags          = gtk.DIALOG_MODAL,
513        type           = gtk.MESSAGE_INFO,
514        buttons        = gtk.BUTTONS_OK,
515        message_format = "Author : FX Andreu\nemail andreu@renater.fr\nCopyright (C) 2005 GIP RENATER\n\nThis file is part of renetcol.\n\nrenetcol 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 2 of the License, or (at your option) any later version.\n\nrenetcol 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.\n\nYou should have received a copy of the GNU General Public License along with renetcol; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA ")
516    dialog.set_title('About')
517    dialog.connect('response', lambda dialog, response: dialog.destroy())
518    dialog.show()
519
520def check_dialog(widget, event, text):
521    dialog = gtk.MessageDialog(
522        parent         = None,
523        flags          = gtk.DIALOG_MODAL,
524        type           = gtk.MESSAGE_INFO,
525        buttons        = gtk.BUTTONS_OK,
526        message_format = text)
527    dialog.set_title('Value check ')
528    dialog.connect('response', lambda dialog, response: dialog.destroy())
529    dialog.show()
530
531def info_dialog(widget, event, text):
532    dialog = gtk.MessageDialog(
533        parent         = None,
534        flags          = gtk.DIALOG_MODAL,
535        type           = gtk.MESSAGE_INFO,
536        buttons        = gtk.BUTTONS_OK,
537        message_format = text)
538    dialog.set_title('Information ')
539    dialog.connect('response', lambda dialog, response: dialog.destroy())
540    dialog.show()
541
542def callback_freeze(widget, data=None):
543    global freeze
544    if widget.get_active() == 1:
545        freeze = 1
546        print "FREEZE ACTIF"
547    if widget.get_active() == 0:
548        freeze = 0
549        print "FREEZE NOT ACTIF"
550
551def wind_destroy(widget, data=None):
552    widget.destroy()
553   
554def callback_record(widget, data=None):
555    global record, record_file, record_file_name
556    if widget.get_active() == 1:
557        FileSel()
558    if widget.get_active() == 0:
559        record = 0
560        time.sleep(2)
561        record_file.close()
562
563def strsend(target, message):
564   global collectorAddr, collectorPort
565   s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
566   s.connect((collectorAddr, collectorPort))
567   s.send(message)
568   s.close()
569
570def callback_refresh(widget, parent):
571    global collectorAddr
572    strsend(collectorAddr, 'REFRESH')
573    parent.destroy()
574   
575def callback_delete_rule(widget, parent):
576    global collectorAddr, collectorPort
577    if widget.get_active() == 1:
578        sent_rule(widget, "DELETE")
579        widget.set_active(0)
580        parent.destroy()
581
582def callback_check_rule(widget, data=None):
583    global router
584    if widget.get_active()==1:
585        router=1
586
587def callback_collector(widget, controlWindow):
588    global is_already_see, collectorRule, myInputControlThread, coll_window, collectorAddr
589    if ((myInputControlThread == None) and (widget.get_active() == 1)):
590        info_dialog(widget, None, "You must before activated the stream reception ! (File menu)")
591        widget.set_active(0)
592    else:
593        if widget.get_active() == 1:
594            widget.set_active(0)
595            coll_window.connect("destroy", wind_destroy)
596            coll_window.set_title("Collector control ")
597            coll_window.set_size_request(500, 250)
598            coll_vbox = gtk.VBox(False, 1)
599            coll_vbox.set_border_width(1)
600            coll_window.add(coll_vbox)
601            coll_frame = gtk.Frame("The prefix/IP address/router, validate by enter")
602            coll_vbox.pack_start(coll_frame, False, False, 5)
603            coll_hbox = gtk.VBox(False, 0)
604            coll_hbox.set_border_width(5)
605            coll_frame.add(coll_hbox)
606            button = gtk.CheckButton(" router ")
607            button.connect("toggled", callback_check_rule, None)
608            coll_hbox.pack_start(button, False, False, 0)
609            mainTT.set_tip(button, "Check it to capture all flows from one router and enter the IPv4 address of this router. IN TEST")
610            button.show()
611            coll_pbbox = gtk.HButtonBox()
612            coll_hbox.pack_start(coll_pbbox, False, True, 5)
613            prefix_entry(45, "Required Format : \n <field> <operation> <address>\nlike 8 = 10.0.0.1 \nor 8 = 10.0.1.0/24 \nor 27 = 2001::1 \nor 27 = 2001::/64 (IPv6 address only on Linux system)\nonly '=' operator for the moment\n------------------------------\nIn this version 0.0.7, you can compare the following fields:\nROUTER_SRC_ADDR: 0\nIPV4_SRC_ADDR: 8\nIPV4_DST_ADDR: 12\nIPV4_NEXT_HOP: 15\nBGP_IPV4_NEXT_HOP: 18\nIPV6_SRC_ADDR: 27\nIPV6_DST_ADDR: 28\nIPV6_NEXT_HOP: 62\nBPG_IPV6_NEXT_HOP: 63\nIP_PROTOCOL_VERSION: 60\n---------------------------", coll_pbbox, "", 0)
614            coll_frame2 = gtk.Frame("Disable rules")
615            coll_vbox.pack_start(coll_frame2, False, False, 5)
616            coll_hbox2 = gtk.VBox(False, 0)
617            coll_hbox2.set_border_width(5)
618            coll_frame2.add(coll_hbox2)
619            coll_pbbox2 = gtk.HButtonBox()
620            coll_hbox2.pack_start(coll_pbbox2, False, True, 5)
621            buttondelete = gtk.ToggleButton("Delete")
622            buttondelete.connect("toggled", callback_delete_rule, coll_window)
623            mainTT.set_tip(buttondelete, "Delete all your rules of the collector configuration.")
624            coll_hbox2.pack_start(buttondelete, False, False, 2)
625            buttondelete.show()
626            coll_vbox.show()
627            coll_window.show_all()
628            if (is_already_see==0):
629                info_dialog(widget, None, "You should registered only one rule for each GUI parser ! Think of using the DELETE button !")
630                is_already_see=1
631
632def callback_fields_printed( widget, data=None):
633    global printValue
634    printValue[data] = widget.get_active()
635
636def callback_check_ip( widget, data=None):
637    global src_Or_Dst_IP
638    if widget.get_active()==1:
639        if checkUpValues[1]:
640            src_Or_Dst_IP = 1
641        else:
642            widget.set_active(0)
643            check_dialog(widget, None, "First, enter a source address.")
644    else:
645            src_Or_Dst_IP = 0
646
647def callback_comboR(widget, data=None):
648    global comboRouter, routerHash
649    nop = 0
650    print struct.unpack('>L',socket.inet_aton(routerHash[comboRouter.entry.get_text()]))
651   
652def callback_src_mask(widget, data=None):
653    nop = 0
654
655def callback_dst_mask(widget, data=None):
656    nop = 0
657
658def callback_tos(widget, data=None):
659    nop = 0
660
661def callback_prot(widget, data=None):
662    nop = 0
663
664def create_button(title, state, callback_function, ptr_var, parent, tooltip_Text):
665    global mainTT
666    button = gtk.ToggleButton(title)
667    if state==1:
668        button.set_active(True)
669    else:
670        button.set_active(False)
671    button.connect("toggled", callback_function, ptr_var)
672    if tooltip_Text!=None:
673        mainTT.set_tip(button, tooltip_Text)
674    parent.pack_start(button, False, True, 2)
675    button.show()
676
677def create_entry(maxLen, tooltip_Text, parent, lab, id):
678    global mainTT
679    vbox = gtk.VBox(False, 0)
680    parent.pack_start(vbox, False, True, 0)
681    label = gtk.Label(lab)
682    label.set_alignment(0, 0.5)
683    vbox.pack_start(label, False, True, 0)
684    entry = gtk.Entry(max=maxLen)
685    entry.set_max_length(maxLen)
686    entry.connect("activate", enter_callback, entry, id)
687    entry.set_text("")
688    entry.select_region(0, len(entry.get_text()))
689    if tooltip_Text!=None:
690        mainTT.set_tip(entry, tooltip_Text)
691    vbox.pack_start(entry, False, True, 0)
692    entry.show()
693
694def sent_rule(widget, msg):
695    global collectorAddr, collectorPort, collectorAddr6, IPversion
696    s = None
697    if (IPversion==4):
698        tmpaf =  socket.AF_INET
699        addr = collectorAddr
700        port = collectorPort
701    elif (IPversion == 6):
702        tmpaf =  socket.AF_INET6
703        addr = collectorAddr6
704        port = collectorPort
705    else:
706        print "Wrong IP version : ", IPversion
707        exit(0)
708    for res in socket.getaddrinfo(addr, port, tmpaf, socket.SOCK_STREAM):
709        af, socktype, proto, canonname, sa = res
710        try:
711            s = socket.socket(af, socktype, proto)
712        except socket.error, msg:
713            s = None
714            continue
715        try:
716            s.connect(sa)
717        except socket.error, msg:
718            s.close()
719            s = None
720            continue
721        break
722    if s is None:
723        check_dialog( widget, None, "could not open socket")
724    else:
725        s.send(msg)
726        check_dialog( widget, None, "Action was sent")
727        s.close()
728
729def prefix_callback( widget, entry, id):
730    global collPrefix, coll_window, router, localPort
731    entry_text = entry.get_text()
732    is_good = 0
733    if (id == 0):
734        if ( entry_text==""):
735            collPrefix = 0
736        else:
737            rule = entry_text.split(' ')
738            field = rule[0]
739            operator = rule[1]
740            value = rule[2]
741            if (field=='0' or field=='8' or field=='12' or field=='15' or field=='18' or field=='47'):
742                if (re.match('^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}(/\d{1,2})?$',value)):
743                    splitter = value.split('/')
744                    adip = struct.unpack('>L',socket.inet_aton(splitter[0]))[0]
745                    if len(splitter)>1:
746                        bits = int(splitter[1])
747                        if bits <= 32 and bits > 0:
748                            mask[1] = 0xffffffffL << (32 - bits)
749                            is_good = 1
750                        else:
751                            check_dialog( widget, None, "Wrong value in mask!")
752                            is_good = 0
753                    else:
754                        mask[1] = 0xffffffffL
755                        is_good = 1
756                else:
757                    check_dialog( widget, None, "Wrong value !")
758            if (field=='27' or field=='28' or field=='62'):
759                ipv6ad_mask = value.split('/')
760                if len(ipv6ad_mask)==1:
761                    try:
762                        socket.gethostbyaddr(value)
763                        is_good = 1
764                    except socket.gaierror:
765                        check_dialog( widget, None, "Wrong value !")
766                    except socket.herror: ## can't resolv
767                        check_dialog( widget, None, "I can't resolv !")
768                    except socket.error:
769                        check_dialog( widget, None, "Error in gethostbyaddr()!")
770                else:
771                    is_good = 1
772                ##here, check the prefix value?
773            if (field=='60' or field=='46'):
774                if (int(value) < 256):
775                    is_good = 1
776            if (is_good==1):
777                ##collPrefix = adip & mask[1]
778                ## Here tcp exchange between collector & client
779                msg = str(localPort) +" "+ field +" "+ operator+" "+ value
780                sent_rule(widget, msg)
781                widget.set_editable(False)
782                coll_window.destroy()
783    else:
784        check_dialog( widget, None, "Internal program error ;) !")
785
786def prefix_entry(maxLen, tooltip_Text, parent, lab, id):
787    global mainTT
788    vbox = gtk.VBox(False, 0)
789    parent.pack_start(vbox, False, True, 0)
790    label = gtk.Label(lab)
791    label.set_alignment(0, 0.5)
792    vbox.pack_start(label, False, True, 0)
793    entry = gtk.Entry(max=maxLen)
794    entry.set_max_length(maxLen)
795    entry.connect("activate", prefix_callback, entry, id)
796    entry.set_text("")
797    entry.select_region(0, len(entry.get_text()))
798    if tooltip_Text!=None:
799        mainTT.set_tip(entry, tooltip_Text)
800    vbox.pack_start(entry, False, True, 0)
801    entry.show()
802
803def user_quit(widget, data=None):
804    global myInputControlThread, localPort, record_file
805    if myInputControlThread != None:
806        myInputControlThread.kill(1)
807        myInputControlThread = None
808        s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
809        s.connect(('localhost', localPort))
810        s.send("FIN")
811        s.close()
812        if (record_file!=None):
813            record_file.close()
814        print "\n\n\n\n\n Input Stream closed. \n\n\n\n\n By :-) \n\n\n\n"
815    gtk.main_quit()
816
817def enter_callback( widget, entry, id):
818    global firstParseValue
819    entry_text = entry.get_text()
820    if id == 0:
821        if (entry_text==""):
822            checkUpValues[0] = 0
823        else:
824            if (re.search('\D',entry_text)) or (int(entry_text) >= 99) or (int(entry_text) <= 0):
825                check_dialog( widget, None, "Wrong value !")
826            else:
827                firstParseValue[0] = int(entry_text)
828                checkUpValues[0] = 1
829    if id == 1:
830        if ( entry_text==""):
831            checkUpValues[8] = 0
832            checkUpValues[12] = 0
833        else:
834            if (re.match('^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}(/\d{1,2})?$',entry_text)):
835                splitter = entry_text.split('/')
836                adip = struct.unpack('>L',socket.inet_aton(splitter[0]))[0]
837                if len(splitter)>1:
838                    bits = int(splitter[1])
839                    if bits <= 32 and bits > 0:
840                        mask[0] = 0xffffffffL << (32 - bits)
841                    else:
842                        check_dialog( widget, None, "Wrong value in mask!")
843                else:
844                    mask[0] = 0xffffffffL
845                firstParseValue[8] = adip & mask[0]
846                checkUpValues[8] = 1
847                firstParseValue[12] = adip & mask[0]
848                checkUpValues[12] = 1
849            else:
850                check_dialog( widget, None, "Wrong value !")
851    if id == 2:
852        if ( entry_text==""):
853            checkUpValues[2] = 0
854        else:
855            check_dialog( widget, None, "NOT YET IMPLEMEMTED")
856            ## pb with IPv6 and getaddrinfo() ??
857##            splitter = entry_text.split('/')
858##            try:
859##                socket.gethostbyaddr(splitter[0])
860##            except socket.gaierror:
861##                check_dialog( widget, None, "Wrong value !")
862##            except socket.herror: ## can't resolv
863##                pass
864##            except socket.error:
865##                pass
866    if id == 3:
867        if ( entry_text==""):
868            checkUpValues[15] = 0
869        else:
870            if (re.match('^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}(/\d{1,2})?$',entry_text)):
871                splitter = entry_text.split('/')
872                adip = struct.unpack('>L',socket.inet_aton(splitter[0]))[0]
873                if len(splitter)>1:
874                    bits = int(splitter[1])
875                    if bits <= 32 and bits > 0:
876                        mask[2] = 0xffffffffL << (32 - bits)
877                    else:
878                        check_dialog( widget, None, "Wrong value in mask!")
879                else:
880                    mask[2] = 0xffffffffL
881                firstParseValue[15] = adip & mask[2]
882                checkUpValues[15] = 1
883            else:
884                check_dialog( widget, None, "Wrong value !")
885    if id == 4: ## In|Out
886        if ( entry_text==""):
887            checkUpValues[10] = 0
888            checkUpValues[14] = 0
889        else:
890            if (re.search('\D',entry_text)) or (int(entry_text) > 65535) or (int(entry_text) < 0):
891                check_dialog( widget, None, "Wrong value !")
892            else:
893                firstParseValue[10] = int(entry_text)
894                checkUpValues[10] = 1
895                firstParseValue[14] = int(entry_text)
896                checkUpValues[14] = 1
897    if id == 6: ## bytes
898        if ( entry_text==""):
899            checkUpValues[1] = 0
900        else:
901            size_list = string.split(entry_text)
902            if (len(size_list)!=2)or((re.search('\D',size_list[0]))or(int(size_list[0])>999999999)or(int(size_list[0])<=0) or (re.search('\D',size_list[1]))or(int(size_list[1])>999999999)or(int(size_list[1])<=0)):
903                check_dialog( widget, None, "Wrong value !")
904            else:
905                firstParseValue[1] = int(size_list[0])
906                if ( int(size_list[1]) == 999999999 ):
907                    firstParseValue[1] = 100000000000
908                else:
909                    firstParseValue[1] = int(size_list[1])
910                checkUpValues[1] = 1
911    if id == 7: ## pkts
912        if ( entry_text==""):
913            checkUpValues[2] = 0
914        else:
915            if (re.search('\D',entry_text)) or (int(entry_text) > 9999) or (int(entry_text) <= 0):
916                check_dialog( widget, None, "Wrong value !")
917            else:
918                firstParseValue[2] = int(entry_text)
919                checkUpValues[2] = 1
920    if id == 8: ## time no concordance with nfv9 field number
921        if ( entry_text==""):
922            checkUpValues[0] = 0
923        else:
924            if (re.search('\D',entry_text)) or (int(entry_text) > 99) or (int(entry_text) < 0):
925                check_dialog( widget, None, "Wrong value !")
926            else:
927                firstParseValue[0] = int(entry_text)
928                checkUpValues[0] = 1
929    if id == 9: ## port range
930        if ( entry_text==""):
931            checkUpValues[7] = 0
932            checkUpValues[11] = 0
933        else:
934            port_list = string.split(entry_text)
935            if (len(port_list)!=2)or((re.search('\D',port_list[0])) or (int(port_list[0]) > 65535) or (int(port_list[0]) <= 0) or (re.search('\D',port_list[1])) or (int(port_list[1]) > 65535) or (int(port_list[1]) <= 0)):
936                check_dialog( widget, None, "Wrong value !")
937            else:
938                firstParseValue[7] = int(port_list[0])
939                firstParseValue[11] = int(port_list[1])
940                checkUpValues[7] = 1
941                checkUpValues[11] = 1
942    if id == 11: ## tcp flags
943        if ( entry_text==""):
944            checkUpValues[6] = 0
945        else:
946            if (re.search('\D',entry_text)) or (int(entry_text) > 255) or (int(entry_text) <= 0):
947                check_dialog( widget, None, "Wrong value !")
948            else:
949                firstParseValue[6] = int(entry_text)
950                checkUpValues[6] = 1
951    if id == 12: ## prot
952        if ( entry_text==""):
953            checkUpValues[4] = 0
954        else:
955            if (re.search('\D',entry_text)) or (int(entry_text) > 255) or (int(entry_text) <= 0):
956                check_dialog( widget, None, "Wrong value !")
957            else:
958                firstParseValue[4] = int(entry_text)
959                checkUpValues[4] = 1
960    if id == 13: ## tos
961        if ( entry_text==""):
962            checkUpValues[5] = 0
963        else:
964            if (re.search('\D',entry_text)) or (int(entry_text) > 255) or (int(entry_text) < 0):
965                check_dialog( widget, None, "Wrong value !")
966            else:
967                firstParseValue[5] = int(entry_text)
968                checkUpValues[5] = 1
969    if id == 14: ## src AS
970        if ( entry_text==""):
971            checkUpValues[16] = 0
972        else:
973            if (re.search('\D',entry_text)) or (int(entry_text) > 65535) or (int(entry_text) < 0):
974                check_dialog( widget, None, "Wrong value !")
975            else:
976                firstParseValue[16] = int(entry_text)
977                checkUpValues[16] = 1
978    if id == 15: ## dst AS
979        if ( entry_text==""):
980            checkUpValues[17] = 0
981        else:
982            if (re.search('\D',entry_text)) or (int(entry_text) > 65535) or (int(entry_text) < 0):
983                check_dialog( widget, None, "Wrong value !")
984            else:
985                firstParseValue[17] = int(entry_text)
986                checkUpValues[17] = 1
987    if id == 18: ## from router
988        if ( entry_text==""):
989            checkUpValues[69] = 0
990        else:
991            if (re.match('^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}?$',entry_text)):
992                adip = struct.unpack('>L',socket.inet_aton(entry_text))[0]
993                firstParseValue[69] = adip
994                checkUpValues[69] = 1
995            else:
996                check_dialog( widget, None, "Wrong value !")
997   
998if __name__ == "__main__":
999    global window, mainTT, comboRouter, os_type, printShit
1000   
1001    gtk.threads_init()
1002   
1003    if (os.name =="nt"):
1004        os_type = 1
1005    elif (os.name =="posix"):
1006        os_type = 0
1007    else:
1008        os_type = 3
1009
1010    print "---------------------------------------------------------------"
1011    print "In this version 0.0.7, you can apply rules on the collector based on the following fields:"
1012    print "IPV4_SRC_ADDR: 8,"
1013    print "IPV4_DST_ADDR: 12,"
1014    print "IPV4_NEXT_HOP: 15,"
1015    print "BGP_IPV4_NEXT_HOP: 18,"
1016    print "IPV6_SRC_ADDR: 27,"
1017    print "IPV6_DST_ADDR: 28,"
1018    print "MPLS_TOP_LABEL_TYPE: 46,"
1019    print "IPV6_NEXT_HOP: 62,"
1020    print "BPG_IPV6_NEXT_HOP: 63,"
1021    print "IP_PROTOCOL_VERSION: 60, please note that the IPv4 template don't have this field"
1022    print "ROUTER_SRC_ADDR: 0, !!! it's not a real number for a field, but it's a great function"
1023    print "----------------------------------------------------------------"
1024   
1025    mainTT = gtk.Tooltips()
1026    window = gtk.Window(gtk.WINDOW_TOPLEVEL)   
1027    window.connect("destroy", gtk.main_quit, "WM destroy")
1028    window.set_title("RenetcolGUI")
1029    window.set_size_request(850, 550)
1030   
1031    main_vbox = gtk.VBox(False, 1)
1032    main_vbox.set_border_width(1)
1033    window.add(main_vbox)
1034
1035##  menu
1036    file_menu = gtk.Menu()
1037    receive_item = gtk.MenuItem("Receive Stream")
1038    stop_item = gtk.MenuItem("Stop Stream")
1039    quit_item  = gtk.MenuItem("Quit")
1040    file_menu.append(receive_item)
1041    file_menu.append(stop_item)
1042    file_menu.append(quit_item)
1043    receive_item.connect("activate", reception, None)
1044    stop_item.connect("activate", close_recept, None)
1045    quit_item.connect("activate", user_quit, None)
1046    receive_item.show()
1047    stop_item.show()
1048    quit_item.show()
1049
1050    help_menu = gtk.Menu()
1051    about_item = gtk.MenuItem("About")
1052    help_menu.append(about_item)
1053    about_item.connect("activate", about_dialog, None)
1054    about_item.show()
1055
1056    menu_bar = gtk.MenuBar()
1057    main_vbox.pack_start(menu_bar, False, False, 0)
1058    menu_bar.show()
1059    file_item = gtk.MenuItem("File")
1060    file_item.show()
1061    help_item = gtk.MenuItem("Help")
1062    help_item.show()
1063
1064    file_item.set_submenu(file_menu)
1065    menu_bar.append(file_item)
1066    menu_bar.append(file_menu)
1067    file_item.set_right_justified(0)
1068
1069    help_item.set_submenu(help_menu)
1070    menu_bar.append(help_item)
1071    menu_bar.append(help_menu)
1072    help_item.set_right_justified(1)
1073
1074##  first frame
1075    frame = gtk.Frame("Input Stream Control")
1076    main_vbox.pack_start(frame, False, True, 0)
1077    hbox = gtk.HBox(False, 0)
1078    hbox.set_border_width(5)
1079    frame.add(hbox)
1080
1081    ## freeze button
1082    buttonfreeze = gtk.ToggleButton("Freeze")
1083    buttonfreeze.connect("toggled", callback_freeze, None)
1084    mainTT.set_tip(buttonfreeze, "Stop/Start the output in the window.")
1085    hbox.pack_start(buttonfreeze, False, False, 2)
1086    buttonfreeze.show()
1087    ## record button
1088    buttonrecord = gtk.ToggleButton("Record")
1089    buttonrecord.connect("toggled", callback_record, None)
1090    mainTT.set_tip(buttonrecord, "Stop/Start the record in a text file.")
1091    hbox.pack_start(buttonrecord, False, False, 2)
1092    buttonrecord.show()
1093    ## control collector button
1094    buttoncollector = gtk.ToggleButton("Collector Control")
1095    buttoncollector.connect("toggled", callback_collector, None)
1096    mainTT.set_tip(buttoncollector, "Change the rule which is applied on the collector. You must have activated the input stream before.")
1097    hbox.pack_start(buttoncollector, False, False, 2)
1098    buttoncollector.show()
1099
1100    ipv4_vbox = gtk.VBox(False, 1)
1101    ipv4_vbox.set_border_width(1)
1102    main_vbox.add(ipv4_vbox)
1103##  second frame
1104    frame = gtk.Frame("Select printed fields")
1105    ipv4_vbox.pack_start(frame, False, False, 0)
1106   
1107    vbox = gtk.VBox(False, 0)
1108    vbox.set_border_width(5)
1109    frame.add(vbox)
1110    bbox = gtk.HButtonBox()
1111    vbox.pack_start(bbox, False, True, 5)
1112   
1113    create_button("Src \n IP", 1, callback_fields_printed, 8, bbox, "Source IP")
1114    create_button("Dst\n IP", 1, callback_fields_printed, 12, bbox, "Destination IP")
1115    create_button("Flw\n IP", 0, callback_fields_printed, 15, bbox, "Following IP")
1116    create_button("Index\n In", 0, callback_fields_printed, 10, bbox, "SNMP Index Input")
1117    create_button("Index\n Out", 0, callback_fields_printed, 14, bbox, "SNMP Index Output")
1118    create_button("Size (P)", 1, callback_fields_printed, 2, bbox, "Packets number")
1119    create_button("Size (B)", 1, callback_fields_printed, 1, bbox, "Size in Bytes")
1120    create_button("Time", 0, callback_fields_printed, 0, bbox, "Age of flow")
1121
1122    b2box = gtk.HButtonBox()
1123    vbox.pack_start(b2box, False, True, 5)
1124    create_button("Src\n Port", 1, callback_fields_printed, 7, b2box, "TCP/UDP source port")
1125    create_button("Dst\n Port", 1, callback_fields_printed, 11, b2box, "TCP/UDP destination port")
1126    create_button("TCP\n Flags", 0, callback_fields_printed, 6, b2box, "TCP Flags")
1127    create_button("Prot", 1, callback_fields_printed, 4, b2box, "Protocol")
1128    create_button("Tos", 0, callback_fields_printed, 5, b2box, "Type of service")
1129    create_button("Src\nAs", 0, callback_fields_printed, 16, b2box, "Source AS")
1130    create_button("Dst\nAs", 0, callback_fields_printed, 17, b2box, "Destination AS")
1131    create_button("Src\nMask", 0, callback_fields_printed, 9, b2box, "Source Mask")
1132    create_button("Dst\nMask", 0, callback_fields_printed, 13, b2box, "Destination Mask")
1133
1134    b3box = gtk.HButtonBox()
1135    vbox.pack_start(b3box, False, True, 5)
1136    create_button("Router", 0, callback_fields_printed, 69, b3box, "Router address")
1137
1138##  third frame
1139    frame = gtk.Frame("Parsing values")
1140    ipv4_vbox.pack_start(frame, False, False, 5)
1141    hbox = gtk.VBox(False, 0)
1142    hbox.set_border_width(5)
1143    frame.add(hbox)
1144    pbbox = gtk.HButtonBox()
1145    hbox.pack_start(pbbox, False, True, 5)
1146##  here entry button
1147    create_entry(18, "Required Format : \n an IPv4 address like x.x.x.x \n or a network address like x.x.x.x/x", pbbox, "IPv4 address :", 1)
1148    create_entry(39, "Required Format : \n an IPv6 address like x:x:x:x:x::x \n or a network address like x:x:x/x NOT YET SUPPORTED", pbbox, "(IPv6 address :)", 2)
1149    create_entry(18, "Required Format : \n an IP address like x.x.x.x \n or a network address like x.x.x.x/x", pbbox, "Flw IP ad. :", 3)
1150    dbbox = gtk.HButtonBox()
1151    hbox.pack_start(dbbox, False, True, 5)
1152    create_entry(5, "Required Format : a number less than 65535", dbbox, "SNMP Index In|Out :", 4)
1153    create_entry(4, "Required Format : a number less than 9999", dbbox, "Packet NB :", 7)
1154    create_entry(17, "Required Format : a range, each number less than 999999999 and space as separator: \"48 54\"", dbbox, "Bytes :", 6)
1155    tbbox = gtk.HButtonBox()
1156    hbox.pack_start(tbbox, False, True, 5)
1157    create_entry(2, "Required Format : a number less than 99", tbbox, "Time :", 8)
1158    create_entry(11, "Port Source or Destination selection, required Format : a range, each number less than 65535 and space as separator: \"6881 6889\"", tbbox, "Port :", 9)
1159    #create_entry(5, "Required Format : a number less than 65535", tbbox, "Dst port :", 10)
1160    create_entry(3, "Required Format : a number less than 255", tbbox, "TCP Flag :", 11)
1161    fbbox = gtk.HButtonBox()
1162    hbox.pack_start(fbbox, False, True, 5)
1163    create_entry(5, "Required Format : a number less than 65535", fbbox, "Protocol :", 12)
1164    create_entry(3, "Required Format : a number less than 255", fbbox, "ToS :", 13)
1165    create_entry(5, "Required Format : a number less than 65535", fbbox, "Src AS :", 14)
1166    create_entry(5, "Required Format : a number less than 65535", fbbox, "Dst AS :", 15)
1167    kbbox = gtk.HButtonBox()
1168    hbox.pack_start(kbbox, False, True, 5)
1169    create_entry(18, "Required Format : \n an IP address like x.x.x.x", kbbox, "The flows from this Router :", 18)
1170
1171##  Show
1172    vbox.show()
1173    main_vbox.show()
1174    window.show_all()
1175    mainTT.enable()
1176
1177##  gtk main loop
1178    gtk.threads_enter()
1179    gtk.main()
1180    gtk.threads_leave()
Note: See TracBrowser for help on using the browser.