Отключено использование clt шаблонов при вводе/выводе из домена Добавлено шифрование Удаление профиля пользователя на локальной машине при отсутствии его в домене Исправлена проверка наличия samba ресурсов на сервере Исправлено монтирование samba ресурсов от пользователя и от системы Исправлена упаковка симлинковmaster3.3
parent
30693225f3
commit
0489e5c32a
File diff suppressed because it is too large
Load Diff
@ -1,148 +0,0 @@
|
|||||||
#-*- coding: utf-8 -*-
|
|
||||||
|
|
||||||
# Copyright 2010 Calculate Ltd. http://www.calculate-linux.org
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
from cl_client import client, __app__, __version__
|
|
||||||
from cl_opt import opt
|
|
||||||
import sys
|
|
||||||
from cl_share_cmd import share_cmd
|
|
||||||
|
|
||||||
# Перевод сообщений для программы
|
|
||||||
from cl_lang import lang
|
|
||||||
lang().setLanguage(sys.modules[__name__])
|
|
||||||
|
|
||||||
# Использование программы
|
|
||||||
USAGE = _("%prog [options] user")
|
|
||||||
|
|
||||||
# Коментарии к использованию программы
|
|
||||||
COMMENT_EXAMPLES = _("Mount resources and synchronize the user profile")
|
|
||||||
|
|
||||||
# Пример использования программы
|
|
||||||
EXAMPLES = _("%prog user_name")
|
|
||||||
|
|
||||||
# Описание программы (что делает программа)
|
|
||||||
DESCRIPTION = _("Mount resources and synchronize the user profile")
|
|
||||||
|
|
||||||
# Опции командной строки
|
|
||||||
CMD_OPTIONS = [{'longOption':"login",
|
|
||||||
'help':_("mount all user resources and synchronize the "
|
|
||||||
"user profile")},
|
|
||||||
{'longOption':"logout",
|
|
||||||
'help':_("synchronize the user profile and unmount "
|
|
||||||
"user resource")},
|
|
||||||
{'longOption':"nosync",
|
|
||||||
'help':_("do not synchronize user preferences; used "
|
|
||||||
"in conjunction with 'login' or 'logout'")},
|
|
||||||
{'longOption':"set"},
|
|
||||||
{'longOption':"progress",
|
|
||||||
'help':_("show the progress bar at xdm startup")}]
|
|
||||||
|
|
||||||
class sync_cmd(share_cmd):
|
|
||||||
def __init__(self):
|
|
||||||
setpos = \
|
|
||||||
filter(lambda x:x[1].get('longOption')=="set",
|
|
||||||
enumerate(CMD_OPTIONS))[0][0]
|
|
||||||
CMD_OPTIONS[setpos] = opt.variable_set[0]
|
|
||||||
# Объект опций командной строки
|
|
||||||
self.optobj = opt(\
|
|
||||||
package=__app__,
|
|
||||||
version=__version__,
|
|
||||||
usage=USAGE,
|
|
||||||
examples=EXAMPLES,
|
|
||||||
comment_examples=COMMENT_EXAMPLES,
|
|
||||||
description=DESCRIPTION,
|
|
||||||
option_list=CMD_OPTIONS + opt.variable_view+opt.color_control,
|
|
||||||
check_values=self.checkOpts)
|
|
||||||
# Создаем объект логики
|
|
||||||
self.logicObj = client()
|
|
||||||
# Создаем переменные
|
|
||||||
self.logicObj.createClVars()
|
|
||||||
# Названия несовместимых опций
|
|
||||||
self.optionsNamesIncompatible = ["login", "logout"]
|
|
||||||
# Названия обязательных опций
|
|
||||||
self.optionsNamesRequired = self.optionsNamesIncompatible
|
|
||||||
|
|
||||||
def getOptionsRequired(self, optObj):
|
|
||||||
"""Получаем обязательные опции"""
|
|
||||||
retList = []
|
|
||||||
for nameOpt in self.optionsNamesRequired:
|
|
||||||
retList.append(getattr(optObj, nameOpt))
|
|
||||||
return retList
|
|
||||||
|
|
||||||
def _getNamesAllSetOptions(self):
|
|
||||||
"""Выдает словарь измененных опций"""
|
|
||||||
setOptDict = self.optobj.values.__dict__.items()
|
|
||||||
defaultOptDict = self.optobj.get_default_values().__dict__.items()
|
|
||||||
return dict(set(setOptDict) - set(defaultOptDict)).keys()
|
|
||||||
|
|
||||||
def getStringIncompatibleOptions(self):
|
|
||||||
"""Форматированная строка несовместимых опций разделенных ','"""
|
|
||||||
listOpt = list(set(self.optionsNamesIncompatible) &\
|
|
||||||
set(self._getNamesAllSetOptions()))
|
|
||||||
return ", ".join(map(lambda x: len(x) == 1 and "'-%s'"%x or "'--%s'"%x,\
|
|
||||||
listOpt))
|
|
||||||
|
|
||||||
def checkOpts(self, optObj, args):
|
|
||||||
"""Проверка опций командной строки"""
|
|
||||||
optionsRequired = self.getOptionsRequired(optObj)
|
|
||||||
if not args:
|
|
||||||
options = [optObj.color, optObj.v, optObj.filter, optObj.xml]
|
|
||||||
if not filter(lambda x: x, options):
|
|
||||||
errMsg = _("no such argument")+":"+" %s" %USAGE.split(" ")[-1]
|
|
||||||
self.optobj.error(errMsg)
|
|
||||||
return False
|
|
||||||
elif len(filter(lambda x: x, optionsRequired))>1:
|
|
||||||
errMsg = _("incompatible options")+":"+" %s"\
|
|
||||||
%self.getStringIncompatibleOptions()
|
|
||||||
self.optobj.error(errMsg)
|
|
||||||
return False
|
|
||||||
elif not filter(lambda x: x, optionsRequired):
|
|
||||||
errMsg = _("required option")+":"+" %s"\
|
|
||||||
%" or ".join(map(lambda x:\
|
|
||||||
len(x) == 1 and "'-%s'"%x or "'--%s'"%x,\
|
|
||||||
self.optionsNamesRequired))
|
|
||||||
self.optobj.error(errMsg)
|
|
||||||
return False
|
|
||||||
if len(args)>1:
|
|
||||||
errMsg = _("incorrect argument") + ":" + " %s" %" ".join(args)
|
|
||||||
self.optobj.error(errMsg)
|
|
||||||
return False
|
|
||||||
if not optObj.v:
|
|
||||||
if optObj.filter:
|
|
||||||
errMsg = _("incorrect option") + ":" + " %s" %"--filter" +\
|
|
||||||
": " + _("used with option '-v'")
|
|
||||||
self.optobj.error(errMsg)
|
|
||||||
return False
|
|
||||||
if optObj.xml:
|
|
||||||
errMsg = _("incorrect option") + ":" + " %s" %"--xml" +\
|
|
||||||
": " + _("used with option '-v'")
|
|
||||||
self.optobj.error(errMsg)
|
|
||||||
return False
|
|
||||||
return optObj, args
|
|
||||||
|
|
||||||
def setUserName(self, userName):
|
|
||||||
"""Установка имени пользователя"""
|
|
||||||
self.logicObj.clVars.Set("ur_login", userName, True)
|
|
||||||
|
|
||||||
def mountUserResAndSync(self, sync=True, progress=False):
|
|
||||||
"""Монтирование ресурсов и синхронизация при входе"""
|
|
||||||
userName = self.logicObj.clVars.Get("ur_login")
|
|
||||||
return self.logicObj.mountUserResAndSync(userName, sync=sync,
|
|
||||||
progress=progress)
|
|
||||||
|
|
||||||
def umountUserResAndSync(self, sync=True, progress=False):
|
|
||||||
"""Отмонтирование ресурсов и синхронизация при выходе"""
|
|
||||||
userName = self.logicObj.clVars.Get("ur_login")
|
|
||||||
return self.logicObj.umountUserResAndSync(userName, sync=sync,
|
|
||||||
progress=progress)
|
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in new issue