mirror of
https://github.com/Pardus-LiderAhenk/ahenk
synced 2024-11-30 04:22:17 +03:00
74 lines
3 KiB
Python
74 lines
3 KiB
Python
|
#!/usr/bin/python3
|
||
|
# -*- coding: utf-8 -*-
|
||
|
# Author: Caner Feyzullahoglu <caner.feyzullahoglu@agem.com.tr>
|
||
|
"""
|
||
|
Style Guide is PEP-8
|
||
|
https://www.python.org/dev/peps/pep-0008/
|
||
|
"""
|
||
|
|
||
|
import json
|
||
|
import os
|
||
|
from base.plugin.abstract_plugin import AbstractPlugin
|
||
|
|
||
|
|
||
|
class UserPrivilegeSafeMode(AbstractPlugin):
|
||
|
def __init__(self, context):
|
||
|
super(AbstractPlugin, self).__init__()
|
||
|
self.username = str(context.get_username())
|
||
|
self.context = context
|
||
|
self.logger = self.get_logger()
|
||
|
|
||
|
def handle_safe_mode(self):
|
||
|
self.logger.debug('Handling safe mode.')
|
||
|
|
||
|
self.logger.debug('Getting plugin path.')
|
||
|
p_path = self.Ahenk.plugins_path()
|
||
|
privilege_file = p_path + 'user-privilege/privilege.changes/' + self.username + '.changes'
|
||
|
|
||
|
if self.is_exist(privilege_file):
|
||
|
self.logger.debug('Reading privilege_file: ' + privilege_file)
|
||
|
with open(privilege_file) as data_file:
|
||
|
self.logger.debug('Creating object from JSON data file.')
|
||
|
data = json.load(data_file)
|
||
|
|
||
|
command_path_list = data['command_path_list']
|
||
|
added_user_list = data['added_user_list']
|
||
|
deleted_user_list = data['deleted_user_list']
|
||
|
|
||
|
if len(command_path_list) != 0:
|
||
|
self.logger.debug('Removing wrapper files and renaming original files.')
|
||
|
|
||
|
for command_path in command_path_list:
|
||
|
if os.path.exists(command_path + '-ahenk'):
|
||
|
self.logger.debug('Executing: ' + '"rm ' + command_path + '"')
|
||
|
self.execute('rm ' + command_path)
|
||
|
self.logger.debug(
|
||
|
'Executing: ' + '"mv ' + command_path + '-ahenk ' + command_path + '"')
|
||
|
self.execute('mv ' + command_path + '-ahenk ' + command_path)
|
||
|
else:
|
||
|
self.logger.debug(
|
||
|
'File will not be deleted because ' + command_path + 'does not exists.')
|
||
|
|
||
|
if len(added_user_list) != 0:
|
||
|
self.logger.debug('Removing user from groups that it has been added in advance.')
|
||
|
|
||
|
for group_name in added_user_list:
|
||
|
self.logger.debug(
|
||
|
'Executing: ' + '"deluser ' + str(self.username) + ' ' + group_name + '"')
|
||
|
self.execute('deluser ' + str(self.username) + ' ' + group_name)
|
||
|
|
||
|
if len(deleted_user_list) != 0:
|
||
|
self.logger.debug('Adding user to groups that it has been removed in advance.')
|
||
|
|
||
|
for group_name in deleted_user_list:
|
||
|
self.logger.debug(
|
||
|
'Executing: ' + '"adduser ' + str(self.username) + ' ' + group_name + '"')
|
||
|
self.execute('adduser ' + str(self.username) + ' ' + group_name)
|
||
|
else:
|
||
|
self.logger.debug('Changes file not found for {} user.'.format(self.username))
|
||
|
|
||
|
|
||
|
def handle_mode(context):
|
||
|
user_privilege = UserPrivilegeSafeMode(context)
|
||
|
user_privilege.handle_safe_mode()
|