mirror of https://github.com/jumpserver/jumpserver
				
				
				
			分离juser方法
							parent
							
								
									33c624c76f
								
							
						
					
					
						commit
						fd5041965b
					
				| 
						 | 
				
			
			@ -0,0 +1,176 @@
 | 
			
		|||
# coding: utf-8
 | 
			
		||||
 | 
			
		||||
from Crypto.PublicKey import RSA
 | 
			
		||||
 | 
			
		||||
from jumpserver.api import *
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def group_add_user(group, user_id=None, username=None):
 | 
			
		||||
    """
 | 
			
		||||
    用户组中添加用户
 | 
			
		||||
    UserGroup Add a user
 | 
			
		||||
    """
 | 
			
		||||
    if user_id:
 | 
			
		||||
        user = get_object(User, id=user_id)
 | 
			
		||||
    else:
 | 
			
		||||
        user = get_object(User, username=username)
 | 
			
		||||
 | 
			
		||||
    if user:
 | 
			
		||||
        group.user_set.add(user)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def db_add_group(**kwargs):
 | 
			
		||||
    """
 | 
			
		||||
    add a user group in database
 | 
			
		||||
    数据库中添加用户组
 | 
			
		||||
    """
 | 
			
		||||
    name = kwargs.get('name')
 | 
			
		||||
    group = get_object(UserGroup, name=name)
 | 
			
		||||
    users = kwargs.pop('users_id')
 | 
			
		||||
 | 
			
		||||
    if not group:
 | 
			
		||||
        group = UserGroup(**kwargs)
 | 
			
		||||
        group.save()
 | 
			
		||||
        for user_id in users:
 | 
			
		||||
            group_add_user(group, user_id)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def db_add_user(**kwargs):
 | 
			
		||||
    """
 | 
			
		||||
    add a user in database
 | 
			
		||||
    数据库中添加用户
 | 
			
		||||
    """
 | 
			
		||||
    groups_post = kwargs.pop('groups')
 | 
			
		||||
    user = User(**kwargs)
 | 
			
		||||
    user.save()
 | 
			
		||||
    if groups_post:
 | 
			
		||||
        group_select = []
 | 
			
		||||
        for group_id in groups_post:
 | 
			
		||||
            group = UserGroup.objects.filter(id=group_id)
 | 
			
		||||
            group_select.extend(group)
 | 
			
		||||
        user.group = group_select
 | 
			
		||||
    return user
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def db_update_user(**kwargs):
 | 
			
		||||
    """
 | 
			
		||||
    update a user info in database
 | 
			
		||||
    数据库更新用户信息
 | 
			
		||||
    """
 | 
			
		||||
    groups_post = kwargs.pop('groups')
 | 
			
		||||
    user_id = kwargs.pop('user_id')
 | 
			
		||||
    user = User.objects.filter(id=user_id)
 | 
			
		||||
    if user:
 | 
			
		||||
        user.update(**kwargs)
 | 
			
		||||
        user = User.objects.get(id=user_id)
 | 
			
		||||
        user.save()
 | 
			
		||||
 | 
			
		||||
    if groups_post:
 | 
			
		||||
        group_select = []
 | 
			
		||||
        for group_id in groups_post:
 | 
			
		||||
            group = UserGroup.objects.filter(id=group_id)
 | 
			
		||||
            group_select.extend(group)
 | 
			
		||||
        user.group = group_select
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def db_del_user(username):
 | 
			
		||||
    """
 | 
			
		||||
    delete a user from database
 | 
			
		||||
    从数据库中删除用户
 | 
			
		||||
    """
 | 
			
		||||
    try:
 | 
			
		||||
        user = User.objects.get(username=username)
 | 
			
		||||
        user.delete()
 | 
			
		||||
    except ObjectDoesNotExist:
 | 
			
		||||
        pass
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def gen_ssh_key(username, password=None, length=2048):
 | 
			
		||||
    """
 | 
			
		||||
    generate a user ssh key in a property dir
 | 
			
		||||
    生成一个用户密钥
 | 
			
		||||
    """
 | 
			
		||||
    private_key_dir = os.path.join(BASE_DIR, 'keys/jumpserver/')
 | 
			
		||||
    private_key_file = os.path.join(private_key_dir, username+".pem")
 | 
			
		||||
    public_key_dir = '/home/%s/.ssh/' % username
 | 
			
		||||
    public_key_file = os.path.join(public_key_dir, 'authorized_keys')
 | 
			
		||||
    is_dir(private_key_dir)
 | 
			
		||||
    is_dir(public_key_dir, username, mode=0700)
 | 
			
		||||
 | 
			
		||||
    key = RSA.generate(length)
 | 
			
		||||
    with open(private_key_file, 'w') as pri_f:
 | 
			
		||||
        pri_f.write(key.exportKey('PEM', password))
 | 
			
		||||
    os.chmod(private_key_file, 0600)
 | 
			
		||||
 | 
			
		||||
    pub_key = key.publickey()
 | 
			
		||||
    with open(public_key_file, 'w') as pub_f:
 | 
			
		||||
        pub_f.write(pub_key.exportKey('OpenSSH'))
 | 
			
		||||
    os.chmod(public_key_file, 0600)
 | 
			
		||||
    bash('chown %s:%s %s' % (username, username, public_key_file))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def server_add_user(username, password, ssh_key_pwd):
 | 
			
		||||
    """
 | 
			
		||||
    add a system user in jumpserver
 | 
			
		||||
    在jumpserver服务器上添加一个用户
 | 
			
		||||
    """
 | 
			
		||||
    bash("useradd '%s'; echo '%s' | passwd --stdin '%s'" % (username, password, username))
 | 
			
		||||
    gen_ssh_key(username, ssh_key_pwd)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def server_del_user(username):
 | 
			
		||||
    """
 | 
			
		||||
    delete a user from jumpserver linux system
 | 
			
		||||
    删除系统上的某用户
 | 
			
		||||
    """
 | 
			
		||||
    bash('userdel -r %s' % username)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def ldap_add_user(username, ldap_pwd):
 | 
			
		||||
    """
 | 
			
		||||
    add a user in ldap database
 | 
			
		||||
    在LDAP中添加用户
 | 
			
		||||
    """
 | 
			
		||||
    user_dn = "uid=%s,ou=People,%s" % (username, LDAP_BASE_DN)
 | 
			
		||||
    password_sha512 = PyCrypt.gen_sha512(PyCrypt.gen_rand_pwd(6), ldap_pwd)
 | 
			
		||||
    user = User.objects.filter(username=username)
 | 
			
		||||
    if user:
 | 
			
		||||
        user = user[0]
 | 
			
		||||
    else:
 | 
			
		||||
        raise ServerError(u'用户 %s 不存在' % username)
 | 
			
		||||
 | 
			
		||||
    user_attr = {'uid': [str(username)],
 | 
			
		||||
                 'cn': [str(username)],
 | 
			
		||||
                 'objectClass': ['account', 'posixAccount', 'top', 'shadowAccount'],
 | 
			
		||||
                 'userPassword': ['{crypt}%s' % password_sha512],
 | 
			
		||||
                 'shadowLastChange': ['16328'],
 | 
			
		||||
                 'shadowMin': ['0'],
 | 
			
		||||
                 'shadowMax': ['99999'],
 | 
			
		||||
                 'shadowWarning': ['7'],
 | 
			
		||||
                 'loginShell': ['/bin/bash'],
 | 
			
		||||
                 'uidNumber': [str(user.id)],
 | 
			
		||||
                 'gidNumber': [str(user.id)],
 | 
			
		||||
                 'homeDirectory': [str('/home/%s' % username)]}
 | 
			
		||||
 | 
			
		||||
    group_dn = "cn=%s,ou=Group,%s" % (username, LDAP_BASE_DN)
 | 
			
		||||
    group_attr = {'objectClass': ['posixGroup', 'top'],
 | 
			
		||||
                  'cn': [str(username)],
 | 
			
		||||
                  'userPassword': ['{crypt}x'],
 | 
			
		||||
                  'gidNumber': [str(user.id)]}
 | 
			
		||||
 | 
			
		||||
    ldap_conn.add(user_dn, user_attr)
 | 
			
		||||
    ldap_conn.add(group_dn, group_attr)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def ldap_del_user(username):
 | 
			
		||||
    """
 | 
			
		||||
    delete a user in ldap database
 | 
			
		||||
    在ldap中删除某用户
 | 
			
		||||
    """
 | 
			
		||||
    user_dn = "uid=%s,ou=People,%s" % (username, LDAP_BASE_DN)
 | 
			
		||||
    group_dn = "cn=%s,ou=Group,%s" % (username, LDAP_BASE_DN)
 | 
			
		||||
    sudo_dn = 'cn=%s,ou=Sudoers,%s' % (username, LDAP_BASE_DN)
 | 
			
		||||
 | 
			
		||||
    ldap_conn.delete(user_dn)
 | 
			
		||||
    ldap_conn.delete(group_dn)
 | 
			
		||||
    ldap_conn.delete(sudo_dn)
 | 
			
		||||
		Loading…
	
		Reference in New Issue