mirror of
https://github.com/Pardus-LiderAhenk/ahenk
synced 2025-01-12 09:12:20 +03:00
130 lines
6.8 KiB
Python
130 lines
6.8 KiB
Python
#!/usr/bin/python3
|
||
# -*- coding: utf-8 -*-
|
||
# Author:Mine DOGAN <mine.dogan@agem.com.tr>
|
||
# Author:Tuncay ÇOLAK <tuncay.colak@tubitak.gov.tr>
|
||
|
||
import json
|
||
from pathlib import Path
|
||
|
||
from base.plugin.abstract_plugin import AbstractPlugin
|
||
|
||
class GetUsers(AbstractPlugin):
|
||
def __init__(self, task, context):
|
||
super(GetUsers, self).__init__()
|
||
self.task = task
|
||
self.context = context
|
||
self.logger = self.get_logger()
|
||
self.message_code = self.get_message_code()
|
||
self.script = '/bin/bash ' + self.Ahenk.plugins_path() + 'local-user/scripts/{0}'
|
||
|
||
self.command_users = 'awk -F: \'{print $1 ":" $6 ":" $7}\' /etc/passwd | grep /bin/bash'
|
||
self.command_user_groups = 'groups {}'
|
||
self.command_not_active = 'egrep \':\!\' /etc/shadow |awk -F: \'{print $1}\''
|
||
self.command_get_groups = 'cut -d: -f1 /etc/group'
|
||
self.xfce4_session = "/usr/bin/xfce4-session"
|
||
self.gnome_session = "/usr/bin/gnome-session"
|
||
self.desktop_env = None
|
||
self.logger.debug('Parameters were initialized.')
|
||
|
||
def handle_task(self):
|
||
|
||
try:
|
||
user_list = []
|
||
result_code, p_out, p_err = self.execute(self.command_users)
|
||
lines = p_out.split('\n')
|
||
lines.pop()
|
||
|
||
self.desktop_env = self.get_desktop_env()
|
||
self.logger.info("Get desktop environment is {0}".format(self.desktop_env))
|
||
|
||
for line in lines:
|
||
detail = line.split(':')
|
||
|
||
result_code, p_out, p_err = self.execute(self.command_user_groups.format(str(detail[0]).strip()))
|
||
groups = p_out.split(':')
|
||
groups[1] = str(groups[1]).strip()
|
||
groups[1] = groups[1].replace("'", "").replace(" ", ", ")
|
||
is_active = 'true'
|
||
result_code, p_out, p_err = self.execute(self.command_not_active)
|
||
users = p_out.split('\n')
|
||
|
||
if str(detail[0]).strip() in users:
|
||
is_active = 'false'
|
||
|
||
self.desktop_path = ''
|
||
if self.is_exist("{0}/Masaüstü/".format(str(detail[1]).strip())):
|
||
self.desktop_path = "{0}/Masaüstü/".format(str(detail[1]).strip())
|
||
self.logger.debug("Desktop path for user '{0}' : {1}".format(str(detail[0]).strip(), self.desktop_path))
|
||
elif self.is_exist("{0}/Desktop/".format(str(detail[1]).strip())):
|
||
self.desktop_path = "{0}/Desktop/".format(str(detail[1]).strip())
|
||
self.logger.debug("Desktop path for user '{0}' : {1}".format(str(detail[0]).strip(), self.desktop_path))
|
||
else:
|
||
self.logger.debug(
|
||
'Desktop write permission could not get. Desktop path not found for user "{0}"'.format(
|
||
str(detail[0]).strip()))
|
||
|
||
result_code, p_out, p_err = self.execute(' stat -c "%a %n" ' + self.desktop_path)
|
||
self.logger.debug('sudo stat -c "%a %n" ' + self.desktop_path)
|
||
is_desktop_write_permission_exists = 'false'
|
||
if result_code == 0:
|
||
permission_codes = p_out.split()
|
||
self.logger.debug("permission codes : " + str(permission_codes))
|
||
if len(permission_codes) > 0:
|
||
permission_code = permission_codes[0].strip()
|
||
self.logger.debug("permission code is : " + permission_code)
|
||
if permission_code == "775":
|
||
is_desktop_write_permission_exists = 'true'
|
||
|
||
if self.desktop_env == "xfce":
|
||
is_kiosk_mode_on = 'false'
|
||
self.logger.debug('Kiosk mode info will be taken')
|
||
file_xfce4_panel = Path("/etc/xdg/xfce4/xfconf/xfce-perchannel-xml/xfce4-panel.xml")
|
||
if not file_xfce4_panel.exists():
|
||
self.logger.error(
|
||
'PANEL XML NOT FOUND COPY')
|
||
source_path = "{0}local-user/panelconf/xfce4-panel.xml".format(self.Ahenk.plugins_path())
|
||
self.logger.info("----->>>>" + source_path)
|
||
self.copy_file(source_path, "/etc/xdg/xfce4/xfconf/xfce-perchannel-xml/xfce4-panel.xml")
|
||
self.logger.error(
|
||
'FILE IS COPIED')
|
||
result_code, p_out, p_err = self.execute(self.script.format('find_locked_users.sh'), result=True)
|
||
if result_code != 0:
|
||
self.logger.error(
|
||
'Error occurred while finding locked users.')
|
||
if p_out:
|
||
self.logger.debug('locked users are {0}'.format(str(p_out)))
|
||
locked_users = p_out.strip().split(';')
|
||
# self.logger.debug("user is " + str(detail[0]).strip())
|
||
# self.logger.debug("locked users are " + str(locked_users))
|
||
if str(detail[0]).strip() in locked_users:
|
||
is_kiosk_mode_on = 'true'
|
||
self.logger.debug('Desktop environ is XFCE. Kiosk mode info is taken')
|
||
else:
|
||
is_kiosk_mode_on = "true"
|
||
self.logger.info("Desktop environ is GNOME. Return kiok mode TRUE")
|
||
|
||
user = {'user': str(detail[0]).strip(), 'groups': groups[1], 'home': detail[1], 'is_active': is_active, 'is_desktop_write_permission_exists': is_desktop_write_permission_exists, 'is_kiosk_mode_on': is_kiosk_mode_on}
|
||
user_list.append(user)
|
||
self.logger.debug('user: {0}, groups: {1}, home: {2}, is_active: {3}'.format(str(detail[0]).strip(), groups[1], detail[1], is_active))
|
||
self.logger.info('Local User task is handled successfully')
|
||
#
|
||
# get all groups
|
||
#
|
||
result_code, p_out, p_err = self.execute(self.command_get_groups)
|
||
all_groups = p_out.split('\n')
|
||
all_groups.pop()
|
||
|
||
self.context.create_response(code=self.message_code.TASK_PROCESSED.value,
|
||
message='Kullanıcı listesi başarıyla getirildi.',
|
||
data=json.dumps({'users': user_list, 'all_groups': all_groups}),
|
||
content_type=self.get_content_type().APPLICATION_JSON.value)
|
||
|
||
except Exception as e:
|
||
self.logger.error('A problem occurred while handling Local-User task: {0}'.format(str(e)))
|
||
self.context.create_response(code=self.message_code.TASK_ERROR.value,
|
||
message='Local-User görevi çalıştırılırken bir hata oluştu.')
|
||
|
||
|
||
def handle_task(task, context):
|
||
get_users = GetUsers(task, context)
|
||
get_users.handle_task()
|