Ahenk/usr/share/ahenk/plugins/user-privilege/safe.py

74 lines
3 KiB
Python
Raw Permalink Normal View History

#!/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()