Source code for ldap3.extend.novell.nmasSetUniversalPassword

"""
"""

# Created on 2014.07.03
#
# Author: Giovanni Cannata
#
# Copyright 2014 - 2018 Giovanni Cannata
#
# This file is part of ldap3.
#
# ldap3 is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# ldap3 is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with ldap3 in the COPYING and COPYING.LESSER files.
# If not, see <http://www.gnu.org/licenses/>.

from ...extend.operation import ExtendedOperation
from ...protocol.novell import NmasSetUniversalPasswordRequestValue, NmasSetUniversalPasswordResponseValue, NMAS_LDAP_EXT_VERSION
from ...utils.dn import safe_dn


[docs]class NmasSetUniversalPassword(ExtendedOperation):
[docs] def config(self): self.request_name = '2.16.840.1.113719.1.39.42.100.11' self.response_name = '2.16.840.1.113719.1.39.42.100.12' self.request_value = NmasSetUniversalPasswordRequestValue() self.asn1_spec = NmasSetUniversalPasswordResponseValue() self.response_attribute = 'password'
def __init__(self, connection, user, new_password, controls=None): ExtendedOperation.__init__(self, connection, controls) # calls super __init__() if connection.check_names and user: user = safe_dn(user) self.request_value['nmasver'] = NMAS_LDAP_EXT_VERSION if user: self.request_value['reqdn'] = user if new_password: self.request_value['new_passwd'] = new_password
[docs] def populate_result(self): self.result['nmasver'] = int(self.decoded_response['nmasver']) self.result['error'] = int(self.decoded_response['err'])