Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar

This commit is contained in:
Marco Pesenti Gritti 2007-10-31 12:56:50 +01:00
commit 6278f8207e
6 changed files with 97 additions and 52 deletions

3
NEWS
View File

@ -1,3 +1,6 @@
* #4518: Encode nickname in UTF-8 when writing it out to .sugar/*/config (smcv)
* sugar-control: Use NM for radio on/off, check for superuser (erikos)
Snapshot b72f00e30b Snapshot b72f00e30b
* #4517 Do not require a TakeScreenshot method on the dbus service (marco) * #4517 Do not require a TakeScreenshot method on the dbus service (marco)

View File

@ -20,9 +20,11 @@
import sys import sys
import getopt import getopt
from sugar import env
sys.path.insert(0, env.get_shell_path()) sys.path.insert(0, env.get_shell_path())
import control from controlpanel import control
def cmd_help(): def cmd_help():
print 'Usage: sugar-control [ option ] key [ args ... ] \n\ print 'Usage: sugar-control [ option ] key [ args ... ] \n\

View File

@ -87,7 +87,7 @@ class Profile(object):
parsed = cp.read([self._config_path]) parsed = cp.read([self._config_path])
if self.nick_name: if self.nick_name:
_set_key(cp, 'Buddy', 'NickName', self.nick_name) _set_key(cp, 'Buddy', 'NickName', self.nick_name.encode('utf8'))
if self.color: if self.color:
_set_key(cp, 'Buddy', 'Color', self.color.to_string()) _set_key(cp, 'Buddy', 'Color', self.color.to_string())
if self.backup1: if self.backup1:

View File

@ -1,2 +1,4 @@
sugardir = $(pkgdatadir)/shell/controlpanel sugardir = $(pkgdatadir)/shell/controlpanel
sugar_PYTHON = control.py sugar_PYTHON = \
__init__.py \
control.py

View File

@ -0,0 +1,16 @@
# Copyright (C) 2006-2007, Red Hat, Inc.
#
# 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA

View File

@ -27,10 +27,15 @@ import os
import string import string
import shutil import shutil
from gettext import gettext as _ from gettext import gettext as _
import dbus
from sugar import profile from sugar import profile
from sugar.graphics.xocolor import XoColor from sugar.graphics.xocolor import XoColor
NM_SERVICE_NAME = 'org.freedesktop.NetworkManager'
NM_SERVICE_PATH = '/org/freedesktop/NetworkManager'
NM_SERVICE_IFACE = 'org.freedesktop.NetworkManager'
NM_ASLEEP = 1
_COLORS = {'red': {'dark':'#b20008', 'medium':'#e6000a', 'light':'#ffadce'}, _COLORS = {'red': {'dark':'#b20008', 'medium':'#e6000a', 'light':'#ffadce'},
'orange': {'dark':'#9a5200', 'medium':'#c97e00', 'light':'#ffc169'}, 'orange': {'dark':'#9a5200', 'medium':'#c97e00', 'light':'#ffc169'},
@ -184,25 +189,16 @@ _LANGUAGES = {
'Zulu/South_Africa': ('zu_ZA.UTF-8', 'latarcyrheb-sun16') 'Zulu/South_Africa': ('zu_ZA.UTF-8', 'latarcyrheb-sun16')
} }
_timezones = []
def _initialize(): def _initialize():
_timezones = _read_zonetab() timezones = _read_zonetab()
j=0 j=0
for timezone in _timezones: for timezone in timezones:
set_timezone.__doc__ += timezone+', ' set_timezone.__doc__ += timezone+', '
j+=1 j+=1
if j%3 == 0: if j%3 == 0:
set_timezone.__doc__ += '\n' set_timezone.__doc__ += '\n'
if not os.access(_TIMEZONE_CONFIG, os.R_OK):
#Theres no /etc/sysconfig/clock file, so make one
fd = open(_TIMEZONE_CONFIG, 'w')
f.write(' The ZONE parameter is only evaluated by sugarcontrol.\n')
f.write('The timezone of the system' +
' is defined by the contents of /etc/localtime.\n')
f.write('ZONE="America/NEW_York"\n')
f.close()
keys = _LANGUAGES.keys() keys = _LANGUAGES.keys()
keys.sort() keys.sort()
@ -222,7 +218,7 @@ def print_jabber():
def set_jabber(server): def set_jabber(server):
"""Set the jabber server """Set the jabber server
server : 'olpc.collabora.co.uk' server : e.g. 'olpc.collabora.co.uk'
""" """
pro = profile.get_profile() pro = profile.get_profile()
pro.jabber_server = server pro.jabber_server = server
@ -243,11 +239,11 @@ def print_color():
print 'fill: color=%s hue=%s'%(color, hue) print 'fill: color=%s hue=%s'%(color, hue)
def set_color(stroke, fill, modstroke='medium', modfill='medium'): def set_color(stroke, fill, modstroke='medium', modfill='medium'):
"""Set the system color. """Set the system color by setting a fill and stroke color.
fill : 'red, orange, yellow, blue, purple' fill : [red, orange, yellow, blue, purple]
stroke : 'red, orange, yellow, blue, purple' stroke : [red, orange, yellow, blue, purple]
modstroke : 'dark, medium, light' hue stroke : [dark, medium, light] (optional)
modfill : ''dark, medium, light' hue fill : [dark, medium, light] (optional)
""" """
if modstroke not in _MODIFIERS or modfill not in _MODIFIERS: if modstroke not in _MODIFIERS or modfill not in _MODIFIERS:
@ -276,36 +272,56 @@ def print_nick():
def set_nick(nick): def set_nick(nick):
"""Set the nickname. """Set the nickname.
nick : 'erikos' nick : e.g. 'walter'
""" """
pro = profile.get_profile() pro = profile.get_profile()
pro.nick_name = nick pro.nick_name = nick
pro.save() pro.save()
def get_radio(state): def get_radio():
return '' bus = dbus.SystemBus()
proxy = bus.get_object(NM_SERVICE_NAME, NM_SERVICE_PATH)
nm = dbus.Interface(proxy, NM_SERVICE_IFACE)
state = nm.state()
if state:
if state == NM_ASLEEP:
return _('off')
else:
return _('on')
return _('State is unknown.')
def print_radio(self): def print_radio():
print get_radio() print get_radio()
def set_radio(state): def set_radio(state):
"""Turn Radio off """Turn Radio 'on' or 'off'
state : 'on/off' state : 'on/off'
""" """
# TODO: NM 0.6.x does not return a reply yet
# so we ignore it for the moment
if state == 'on': if state == 'on':
cmd = '/sbin/iwconfig eth0 txpower on' dbus.SystemBus().call_async(NM_SERVICE_NAME, NM_SERVICE_PATH,
handle = os.popen(cmd, 'r') NM_SERVICE_IFACE, 'wake', '', (),
print string.join(handle.readlines()) None, None)
handle.close()
elif state == 'off': elif state == 'off':
cmd = '/sbin/iwconfig eth0 txpower off' dbus.SystemBus().call_async(NM_SERVICE_NAME, NM_SERVICE_PATH,
handle = os.popen(cmd, 'r') NM_SERVICE_IFACE, 'sleep', '', (),
print string.join(handle.readlines()) None, None)
handle.close()
else: else:
print (_("Error in specified radio argument use on/off.")) print (_("Error in specified radio argument use on/off."))
def _check_for_superuser():
if os.getuid():
print _("Permission denied. You need to be root to run this method.")
return False
return True
def get_timezone(): def get_timezone():
if not os.access(_TIMEZONE_CONFIG, os.R_OK):
# this is what the default is for the /etc/localtime
return "America/New_York"
fd = open(_TIMEZONE_CONFIG, "r") fd = open(_TIMEZONE_CONFIG, "r")
lines = fd.readlines() lines = fd.readlines()
fd.close() fd.close()
@ -331,12 +347,30 @@ def print_timezone():
print (_("Error in reading timezone")) print (_("Error in reading timezone"))
else: else:
print timezone print timezone
def _read_zonetab(fn='/usr/share/zoneinfo/zone.tab'):
fd = open (fn, 'r')
lines = fd.readlines()
fd.close()
timezones = []
for line in lines:
if line.startswith('#'):
continue
line = line.split()
if len(line) > 1:
timezones.append(line[2])
timezones.sort()
return timezones
def set_timezone(timezone): def set_timezone(timezone):
"""Set the system timezone """Set the system timezone
timezone : timezone :
""" """
if timezone in _timezones: if not _check_for_superuser():
return
timezones = _read_zonetab()
if timezone in timezones:
fromfile = os.path.join("/usr/share/zoneinfo/", timezone) fromfile = os.path.join("/usr/share/zoneinfo/", timezone)
try: try:
shutil.copyfile(fromfile, "/etc/localtime") shutil.copyfile(fromfile, "/etc/localtime")
@ -358,20 +392,6 @@ def set_timezone(timezone):
fd.close() fd.close()
else: else:
print (_("Error timezone does not exist.")) print (_("Error timezone does not exist."))
def _read_zonetab(fn='/usr/share/zoneinfo/zone.tab'):
fd = open (fn, 'r')
lines = fd.readlines()
fd.close()
timezones = []
for line in lines:
if line.startswith('#'):
continue
line = line.split()
if len(line) > 1:
timezones.append(line[2])
timezones.sort()
return timezones
def _writeI18N(lang, sysfont): def _writeI18N(lang, sysfont):
path = '/etc/sysconfig/i18n' path = '/etc/sysconfig/i18n'
@ -418,11 +438,13 @@ def set_language(language):
"""Set the system language. """Set the system language.
languages : languages :
""" """
if not _check_for_superuser():
return
if language in _LANGUAGES: if language in _LANGUAGES:
_writeI18N(_LANGUAGES[language][0], _LANGUAGES[language][1]) _writeI18N(_LANGUAGES[language][0], _LANGUAGES[language][1])
else: else:
print (_("Sorry I do not speak \'%s\'.")%language) print (_("Sorry I do not speak \'%s\'.")%language)
# inilialize the docstrings for the timezone and language # inilialize the docstrings for the timezone and language
_initialize() _initialize()