doc-string based docs
This commit is contained in:
		
							
								
								
									
										126
									
								
								Doc/ldapurl.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								Doc/ldapurl.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| .. % $Id: ldapurl.rst,v 1.9 2011/07/22 13:27:01 stroeder Exp $ | ||||
|  | ||||
| ################################### | ||||
| :py:mod:`ldapurl` LDAP URL handling | ||||
| ################################### | ||||
|  | ||||
| .. py:module:: ldapurl | ||||
|    :synopsis: Parses and generates LDAP URLs | ||||
| .. moduleauthor:: python-ldap project (see http://www.python-ldap.org/) | ||||
|  | ||||
|  | ||||
| This module parses and generates LDAP URLs.    It is implemented in pure Python | ||||
| and does not rely on any  non-standard modules. Therefore it can be used stand- | ||||
| alone without  the rest of the python-ldap package.    Compability note: This | ||||
| module has been solely tested on Python 2.x and above. | ||||
|  | ||||
| .. seealso:: | ||||
|  | ||||
|    :rfc:`4516` - The LDAP URL Format | ||||
|  | ||||
|  | ||||
| Constants | ||||
| ========= | ||||
|  | ||||
| The :mod:`ldapurl` module exports the following constants: | ||||
|  | ||||
| .. py:data:: SEARCH_SCOPE | ||||
|  | ||||
|    This dictionary maps a search scope string identifier  to the corresponding | ||||
|    integer value used with search operations  in :mod:`ldap`. | ||||
|  | ||||
|  | ||||
| .. py:data:: SEARCH_SCOPE_STR | ||||
|  | ||||
|    This dictionary is the inverse to :const:`SEARCH_SCOPE`. It  maps a search scope | ||||
|    integer value to the corresponding string identifier  used in a LDAP URL string | ||||
|    representation. | ||||
|  | ||||
|  | ||||
| .. py:data:: LDAP_SCOPE_BASE | ||||
|  | ||||
|  | ||||
| .. py:data:: LDAP_SCOPE_ONELEVEL | ||||
|  | ||||
|  | ||||
| .. py:data:: LDAP_SCOPE_SUBTREE | ||||
|  | ||||
|  | ||||
| Functions | ||||
| ========= | ||||
|  | ||||
| .. autofunction:: ldapurl.isLDAPUrl | ||||
|  | ||||
|  | ||||
| .. autofunction:: ldapurl.ldapUrlEscape | ||||
|  | ||||
|  | ||||
| Classes | ||||
| ======= | ||||
|  | ||||
| .. _ldapurl-ldapurl: | ||||
|  | ||||
| LDAP URLs | ||||
| ^^^^^^^^^ | ||||
|  | ||||
| A :py:class:`LDAPUrl` object represents a complete LDAP URL. | ||||
|  | ||||
| .. autoclass:: ldapurl.LDAPUrl  | ||||
|  | ||||
|  | ||||
| LDAP URL extensions | ||||
| ^^^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| A :py:class:`LDAPUrlExtension` object represents a single LDAP URL extension | ||||
| whereas :py:class:`LDAPUrlExtensions` represents a list of LDAP URL extensions. | ||||
|  | ||||
|  | ||||
| .. _ldapurl-ldapurlextension: | ||||
|  | ||||
| .. autoclass:: ldapurl.LDAPUrlExtension | ||||
|  | ||||
| .. _ldapurl-ldapurlextensions: | ||||
|  | ||||
| .. autoclass:: ldapurl.LDAPUrlExtensions | ||||
|  | ||||
|  | ||||
| .. _ldapurl-example: | ||||
|  | ||||
| Example | ||||
| ^^^^^^^ | ||||
|  | ||||
| Important security advice: | ||||
| For security reasons you shouldn't specify passwords in LDAP URLs | ||||
| unless you really know what you are doing. | ||||
|  | ||||
| The following example demonstrates how to parse a LDAP URL | ||||
| with :mod:`ldapurl` module. | ||||
|  | ||||
|  | ||||
| >>> import ldapurl | ||||
| >>> ldap_url = ldapurl.LDAPUrl('ldap://localhost:1389/dc=stroeder,dc=com?cn,mail???bindname=cn=Michael%2cdc=stroeder%2cdc=com,X-BINDPW=secret') | ||||
| >>> # Using the parsed LDAP URL by reading the class attributes | ||||
| >>> ldap_url.dn | ||||
| 'dc=stroeder,dc=com' | ||||
| >>> ldap_url.hostport | ||||
| 'localhost:1389' | ||||
| >>> ldap_url.attrs | ||||
| ['cn','mail'] | ||||
| >>> ldap_url.filterstr | ||||
| '(objectclass=*)' | ||||
| >>> ldap_url.who | ||||
| 'cn=Michael,dc=stroeder,dc=com' | ||||
| >>> ldap_url.cred | ||||
| 'secret' | ||||
| >>> ldap_url.scope | ||||
| 0 | ||||
|  | ||||
|  | ||||
| The following example demonstrates how to generate a LDAP URL | ||||
| with \module{ldapurl} module. | ||||
|  | ||||
| >>> import ldapurl | ||||
| >>> ldap_url = ldapurl.LDAPUrl(hostport='localhost:1389',dn='dc=stroeder,dc=com',attrs=['cn','mail'],who='cn=Michael,dc=stroeder,dc=com',cred='secret') | ||||
| >>> ldap_url.unparse() | ||||
| 'ldap://localhost:1389/dc=stroeder,dc=com?cn,mail?base?(objectclass=*)?bindname=cn=Michael%2Cdc=stroeder%2Cdc=com,X-BINDPW=secret' | ||||
|  | ||||
							
								
								
									
										74
									
								
								Lib/ldap/extop/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								Lib/ldap/extop/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,74 @@ | ||||
| """ | ||||
| controls.py - support classes for LDAPv3 extended operations | ||||
|  | ||||
| See http://www.python-ldap.org/ for details. | ||||
|  | ||||
| \$Id: __init__.py,v 1.4 2011/07/22 13:27:02 stroeder Exp $ | ||||
|  | ||||
| Description: | ||||
| The ldap.extop module provides base classes for LDAPv3 extended operations. | ||||
| Each class provides support for a certain extended operation request and | ||||
| response. | ||||
| """ | ||||
|  | ||||
| from ldap import __version__ | ||||
|  | ||||
|  | ||||
| class ExtendedRequest: | ||||
|   """ | ||||
|   Generic base class for a LDAPv3 extended operation request | ||||
|  | ||||
|   requestName | ||||
|       OID as string of the LDAPv3 extended operation request | ||||
|   requestValue | ||||
|       value of the LDAPv3 extended operation request | ||||
|       (here it is the BER-encoded ASN.1 request value) | ||||
|   """ | ||||
|  | ||||
|   def __init__(self,requestName,requestValue): | ||||
|     self.requestName = requestName | ||||
|     self.requestValue = requestValue | ||||
|  | ||||
|   def __repr__(self): | ||||
|     return '%s(%s,%s)' % (self.__class__.__name__,self.requestName,self.requestValue) | ||||
|  | ||||
|   def encodedRequestValue(self): | ||||
|     """ | ||||
|     returns the BER-encoded ASN.1 request value composed by class attributes | ||||
|     set before | ||||
|     """ | ||||
|     return self.requestValue | ||||
|  | ||||
|  | ||||
| class ExtendedResponse: | ||||
|   """ | ||||
|   Generic base class for a LDAPv3 extended operation response | ||||
|  | ||||
|   requestName | ||||
|       OID as string of the LDAPv3 extended operation response | ||||
|   encodedResponseValue | ||||
|       BER-encoded ASN.1 value of the LDAPv3 extended operation response | ||||
|   """ | ||||
|  | ||||
|   def __init__(self,responseName,encodedResponseValue): | ||||
|     self.responseName = responseName | ||||
|     self.responseValue = self.decodeResponseValue(encodedResponseValue) | ||||
|  | ||||
|   def __repr__(self): | ||||
|     return '%s(%s,%s)' % (self.__class__.__name__,self.responseName,self.responseValue) | ||||
|  | ||||
|   def decodeResponseValue(self,value): | ||||
|     """ | ||||
|     decodes the BER-encoded ASN.1 extended operation response value and | ||||
|     sets the appropriate class attributes | ||||
|     """ | ||||
|     return value | ||||
|  | ||||
|  | ||||
| # Optionally import sub-modules which need pyasn1 et al | ||||
| try: | ||||
|   import pyasn1,pyasn1_modules.rfc2251 | ||||
| except ImportError: | ||||
|   pass | ||||
| else: | ||||
|   from ldap.extop.dds import * | ||||
		Reference in New Issue
	
	Block a user
	 stroeder
					stroeder