!C99Shell v. 1.0 pre-release build #16!

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

/usr/share/system-config-network/netconfpkg/   drwxr-xr-x
Free 3.85 GB of 27.03 GB (14.23%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     NCDevice.py (15.01 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
## Copyright (C) 2001-2005 Red Hat, Inc.
## Copyright (C) 2001, 2002 Than Ngo <than@redhat.com>
## Copyright (C) 2001-2005 Harald Hoyer <harald@redhat.com>
## Copyright (C) 2001, 2002 Philipp Knirsch <pknirsch@redhat.com>

## This program 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.

## This program 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 this program; if not, write to the Free Software
## Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

import sys
import string
import commands
import math
import NC_functions
from rhpl import Conf
from rhpl import ConfSMB
from NC_functions import *
from netconfpkg import Device_base
import NCDialup
import NCCipe
from rhpl.executil import gtkExecWithCaptureStatus

class ConfDevice(Conf.ConfShellVar):
    def __init__(self, name, dir = None):
        if dir == None:
            dir = netconfpkg.ROOT + SYSCONFDEVICEDIR
        new = false
        self.filename = dir + 'ifcfg-' + name
        if not os.access(self.filename, os.R_OK):
            new = true
            self.oldmode = 0644
        else:
            status = os.stat(self.filename)
            self.oldmode = status[0]
            #print status
            
        Conf.ConfShellVar.__init__(self, self.filename)
        
        if new:
            self.rewind()
            self.insertline("# Please read /usr/share/doc/"
                            "initscripts-*/sysconfig.txt")
            self.nextline()
            self.insertline("# for the documentation of these parameters.");
            self.rewind()
    
    def write(self):
        self.chmod(self.oldmode)
        log.log(2, "chmod %#o %s" % (self.oldmode & 03777, self.filename))
        #if ((self.oldmode & 0044) != 0044):
        #    ask = NC_functions.generic_yesno_dialog(\
        #        _("May I change\n%s\nfrom mode %o to %o?") % \
        #        (self.filename, self.oldmode & 03777, 0644))
        #    if ask != RESPONSE_YES:
        #        self.chmod(self.oldmode)
        Conf.ConfShellVar.write(self)
            
class ConfRoute(Conf.ConfShellVar):
    def __init__(self, name):
        Conf.ConfShellVar.__init__(self, netconfpkg.ROOT + SYSCONFDEVICEDIR + 'route-' + name)
        self.chmod(0644)

class Device(Device_base):
    keydict = { 'Device' : 'DEVICE',
                'IP' : 'IPADDR',
                'Netmask' : 'NETMASK',
                'Gateway' : 'GATEWAY',
                'Hostname' : 'DHCP_HOSTNAME',
                'Domain' : 'DOMAIN',
                'BootProto' : 'BOOTPROTO',
                'Type' : 'TYPE',
                'HardwareAddress' : 'HWADDR',
                }

    boolkeydict = { 'OnBoot' : 'ONBOOT',
                    'AllowUser' : 'USERCTL',
                    'AutoDNS' : 'PEERDNS',
                    'Slave' : 'SLAVE',
                    'IPv6Init' : 'IPV6INIT',
                    }
        
    def __init__(self, list = None, parent = None):
        Device_base.__init__(self, list, parent)        
        self.oldname = None

    def getDialog(self):
        return None

    def getWizard(self):
        return None

    def isType(self, device):
        return None

    def testDeviceId(self, value, child = None):
        if re.search(r"^[a-z|A-Z|0-9\_:]+$", value):
            return true
        return false

    def getDeviceAlias(self):
        devname = self.Device
        if self.Alias != None and self.Alias != "":
            devname = devname + ':' + str(self.Alias)
        return devname

    def load(self, name):
        conf = ConfDevice(name)

        self.oldname = name

        if not conf.has_key("DEVICE"):
            aliaspos = string.find(name, ':')
            if aliaspos != -1:
                from netconfpkg.NCDeviceList import getDeviceList
                # ok, we have to inherit all other data from our master
                for dev in getDeviceList():
                    if dev.Device == name[:aliaspos]:
                        self.apply(dev)
                        break

            self.Device = name
         
        self.DeviceId = name
        for selfkey in self.keydict.keys():
            confkey = self.keydict[selfkey]
            if conf.has_key(confkey):
                self.__dict__[selfkey] = conf[confkey]

        for selfkey in self.boolkeydict.keys():
            confkey = self.boolkeydict[selfkey]
            if conf.has_key(confkey):
                if conf[confkey] == 'yes':
                    self.__dict__[selfkey] = true
                else:
                    self.__dict__[selfkey] = false            
            elif not self.__dict__.has_key(selfkey):
                self.__dict__[selfkey] = false                            
            
        if not conf.has_key("PEERDNS"):
            self.AutoDNS = None
            
        if not self.Gateway:
            try:
                cfg = Conf.ConfShellVar(netconfpkg.ROOT + SYSCONFNETWORK)
                if cfg.has_key('GATEWAY'):
                    gw = cfg['GATEWAY']
                    
                    if gw and self.Netmask:
                        try:
                            network = commands.getoutput('ipcalc --network '+\
                                                         str(self.IP) + \
                                                         ' ' + \
                                                         str(self.Netmask) +\
                                                         ' 2>/dev/null')
                            
                            out = commands.getoutput('ipcalc --network ' + \
                                                     str(gw) + ' ' \
                                                     + str(self.Netmask) + \
                                                     ' 2>/dev/null')
                            if out == network:
                                self.Gateway = str(gw)
                        except:
                            pass
                        
                            
            except EnvironmentError, msg:
                NC_functions.generic_error_dialog(str(msg))
                pass

        try:
            aliaspos = string.find(self.Device, ':')
            if aliaspos != -1:
                self.Alias = int(self.Device[aliaspos+1:])
                self.Device = self.Device[:aliaspos]
        except TypeError:
            NC_functions.generic_error_dialog(_("%s, "
                                                "Device not specified "
                                                "or alias not a number!") % \
                                              self.DeviceId)
            #raise TypeError, _("Device not specified or alias not a number!")

        if not self.Type or self.Type == "" or self.Type == _("Unknown"):
            import NCHardwareList
            hwlist = NCHardwareList.getHardwareList()
            for hw in hwlist:
                if hw.Name == self.Device:
                    self.Type = hw.Type
                    break
            else:
                self.Type = NC_functions.getDeviceType(self.Device)

        if conf.has_key("RESOLV_MODS"):
            if conf["RESOLV_MODS"] != "no":
                self.AutoDNS = true
            else:
                self.AutoDNS = false

        if self.Type == CTC or self.Type == IUCV:
            if conf.has_key("MTU") and conf['MTU']:
                try:
                    self.Mtu = int(conf['MTU'])
                except:
                    pass

        # move old <id>.route files to route-<id>
        file = netconfpkg.ROOT + SYSCONFDEVICEDIR + \
                                self.DeviceId + '.route'
        if os.path.isfile(file):
            NC_functions.rename(file,
                                netconfpkg.ROOT + SYSCONFDEVICEDIR + \
                                'route-' + self.DeviceId )
        # load routes
        rconf = ConfRoute(name)
        num = len(rconf.keys())
        self.createStaticRoutes()

        # XXX fixme
        if math.fmod(num, 3) != 0:
             NC_functions.generic_error_dialog((_("Static routes file %s "
                                                  "is invalid")) % name)
        else:
            for p in xrange(0, int(num/3)):
                i = self.StaticRoutes.addRoute()
                route = self.StaticRoutes[i]
                route.Address = rconf['ADDRESS' + str(p)]
                route.Netmask = rconf['NETMASK' + str(p)]
                route.Gateway = rconf['GATEWAY' + str(p)]
        
        self.commit(changed=false)
                
    def save(self):
        # Just to be safe...
        os.umask(0022)
        self.commit()

        if self.oldname and (self.oldname != self.DeviceId):
            for prefix in [ 'ifcfg-', 'route-', 'keys-' ]:
                NC_functions.rename(netconfpkg.ROOT + SYSCONFDEVICEDIR + \
                                    prefix + self.oldname,
                                    netconfpkg.ROOT + SYSCONFDEVICEDIR + \
                                    prefix + self.DeviceId)            

        conf = ConfDevice(self.DeviceId)
        conf.fsf()
        
        if not self.Cipe and self.BootProto == None \
           and (self.IP == None or self.IP == ""):
            self.BootProto = 'dhcp'
                
        if self.BootProto:
            self.BootProto = string.lower(self.BootProto)

        if self.BootProto == "static":
            self.BootProto = "none"

        for selfkey in self.keydict.keys():
            confkey = self.keydict[selfkey]
            if self.__dict__[selfkey]:
                conf[confkey] = str(self.__dict__[selfkey])
            else: conf[confkey] = ""

        if self.Alias != None:
            conf['DEVICE'] = str(self.Device) + ':' + str(self.Alias)

        for selfkey in self.boolkeydict.keys():
            confkey = self.boolkeydict[selfkey]
            if self.__dict__[selfkey] == true:
                conf[confkey] = 'yes'
           elif self.__dict__[selfkey] == false:
                conf[confkey] = 'no'

        # Recalculate BROADCAST and NETWORK values if IP and netmask are
        # present (#51462)
        # obsolete
        if self.IP and self.Netmask and conf.has_key('BROADCAST'):
            try:
                broadcast = commands.getoutput('ipcalc --broadcast ' + \
                                               str(self.IP) + \
                                               ' ' + str(self.Netmask) + \
                                               ' 2>/dev/null')
                if broadcast:
                    conf['BROADCAST'] = broadcast[10:]
            except:
                pass

        if self.IP and self.Netmask and conf.has_key('NETWORK'):
            try:
                network = commands.getoutput('ipcalc --network ' + \
                                             str(self.IP) + \
                                             ' ' + str(self.Netmask) + \
                                             ' 2>/dev/null')
                if network:
                    conf['NETWORK'] = network[8:]
            except:
                pass                
        else:
            del conf['NETWORK']
            del conf['BROADCAST']

        if self.Type == CTC or self.Type == IUCV:                
            conf['MTU'] = str(self.Mtu)
            if conf.has_key("GATEWAY") and conf['GATEWAY']:
                conf['REMIP'] = conf['GATEWAY']

        if self.Dialup:
            self.Dialup.save(conf)

        if self.Cipe:
            self.Cipe.save(conf)

        if self.Wireless:
            self.Wireless.save(conf)

        if self.StaticRoutes and len(self.StaticRoutes) > 0:
            rconf = ConfRoute(self.DeviceId)
            for key in rconf.keys():
                del rconf[key]
            p = 0
            for route in self.StaticRoutes:
                if route.Address:
                    rconf['ADDRESS'+str(p)] = route.Address
                if route.Netmask:
                    rconf['NETMASK'+str(p)] = route.Netmask
                if route.Gateway:
                    rconf['GATEWAY'+str(p)] = route.Gateway
                p = p + 1
            rconf.write()
        else:
            # remove route file, if no routes defined
            unlink(netconfpkg.ROOT + SYSCONFDEVICEDIR + self.DeviceId + '.route')
            unlink(netconfpkg.ROOT + SYSCONFDEVICEDIR + 'route-' + self.DeviceId )
            
        # Do not clear the non-filled in values for Wireless Devices
        # Bugzilla #52252
        if not self.Wireless:
            for i in conf.keys():
                if not conf[i] or conf[i] == "":
                    del conf[i]

        # RESOLV_MODS should be PEERDNS
        if conf.has_key('RESOLV_MODS'):
            del conf['RESOLV_MODS']

        conf.write()

        self.oldname = self.DeviceId
        
    def activate(self, dialog = None):        
        command = '/sbin/ifup'
        param = [command, self.DeviceId, "up"]

        try:
            (ret, msg) =  generic_run_dialog(\
                command,
                param,
                catchfd = (1,2),
                title = _('Network device activating...'),
                label = _('Activating network device %s, '
                          'please wait...') % (self.DeviceId),
                errlabel = _('Cannot activate '
                             'network device %s!\n') % (self.DeviceId),
                dialog = dialog)
            
        except RuntimeError, msg:
            ret = -1                

        return ret, msg

    def deactivate(self, dialog = None):
        command = '/sbin/ifdown'
        param = [command, self.DeviceId, "down"]
        
        try:
            (ret, msg) = generic_run_dialog(\
                command, param,
                catchfd = (1,2),
                title = _('Network device deactivating...'),
                label = _('Deactivating network device %s, '
                          'please wait...') % (self.DeviceId),
                errlabel = _('Cannot deactivate '
                             'network device %s!\n') % (self.DeviceId),
                dialog = dialog)
            
        except RuntimeError, msg:
            ret = -1

        return ret, msg

    def configure(self):        
        command = '/usr/bin/system-config-network'
        args = ''
        if not os.path.isfile(command) and getDebugLevel() > 0:
            command = os.getcwd() + '/system-config-network-gui'
            args = '-d'
            
        try:
            (ret, msg) =  generic_run(command,
                                      [command, args],
                                      catchfd = (1,2))
        except RuntimeError, msg:
            ret = -1
            
       return ret, msg

    def monitor(self):
        pass

    def getHWDevice(self):
        return self.Device

__author__ = "Harald Hoyer <harald@redhat.com>"

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0042 ]--