Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar
This commit is contained in:
commit
6278f8207e
3
NEWS
3
NEWS
@ -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)
|
||||||
|
@ -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\
|
||||||
|
@ -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:
|
||||||
|
@ -1,2 +1,4 @@
|
|||||||
sugardir = $(pkgdatadir)/shell/controlpanel
|
sugardir = $(pkgdatadir)/shell/controlpanel
|
||||||
sugar_PYTHON = control.py
|
sugar_PYTHON = \
|
||||||
|
__init__.py \
|
||||||
|
control.py
|
||||||
|
16
shell/controlpanel/__init__.py
Normal file
16
shell/controlpanel/__init__.py
Normal 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
|
||||||
|
|
@ -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,26 +189,17 @@ _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()
|
||||||
i = 0
|
i = 0
|
||||||
@ -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()
|
||||||
@ -332,11 +348,29 @@ def print_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")
|
||||||
@ -359,20 +393,6 @@ def set_timezone(timezone):
|
|||||||
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'
|
||||||
if os.access(path, os.R_OK) == 0:
|
if os.access(path, os.R_OK) == 0:
|
||||||
@ -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()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user