本文整理汇总了Python中pykolab.auth.Auth.get_user_attributes方法的典型用法代码示例。如果您正苦于以下问题:Python Auth.get_user_attributes方法的具体用法?Python Auth.get_user_attributes怎么用?Python Auth.get_user_attributes使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类pykolab.auth.Auth
的用法示例。
在下文中一共展示了Auth.get_user_attributes方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: PolicyRequest
# 需要导入模块: from pykolab.auth import Auth [as 别名]
# 或者: from pykolab.auth.Auth import get_user_attributes [as 别名]
class PolicyRequest(object):
email_address_keys = [ 'sender', 'recipient' ]
recipients = []
auth = None
sasl_domain = None
sasl_user = None
sender_domain = None
sender_user = None
sasl_user_uses_alias = False
sasl_user_is_delegate = False
def __init__(self, policy_request={}):
"""
Creates a new policy request object. Pass it a policy_request
dictionary as described in the Postfix documentation on:
http://www.postfix.org/SMTPD_POLICY_README.html
"""
for key in policy_request.keys():
# Normalize email addresses (they may contain recipient delimiters)
if key in self.email_address_keys:
policy_request[key] = normalize_address(policy_request[key])
if not key == 'recipient':
if policy_request[key] == '':
setattr(self, key, None)
else:
setattr(self, key, policy_request[key])
else:
if not policy_request['recipient'].strip() == '':
self.recipients = list(set(self.recipients + [policy_request['recipient']]))
def add_request(self, policy_request={}):
"""
Add subsequent policy requests to the existing policy request.
All data in the request should be the same as the initial policy
request, but for the recipient - with destination limits set over
1, Postfix may attempt to deliver messages to more then one
recipient during a single delivery attempt, and during submission,
the policy will receive one policy request per recipient.
"""
# Check instance. Not sure what to do if the instance is not the same.
if hasattr(self, 'instance'):
if not policy_request['instance'] == self.instance:
# TODO: We need to empty our pockets
pass
log.debug(
_("Adding policy request to instance %s") % (self.instance),
level=8
)
# Normalize email addresses (they may contain recipient delimiters)
if policy_request.has_key('recipient'):
policy_request['recipient'] = normalize_address(
policy_request['recipient']
)
if not policy_request['recipient'].strip() == '':
self.recipients = list(set(self.recipients + [policy_request['recipient']]))
def parse_ldap_dn(self, dn):
"""
See if parameter 'dn' is a basestring LDAP dn, and if so, return
the results we can obtain from said DN. Return a list of relevant
attribute values.
If not a DN, return None.
"""
values = []
try:
import ldap.dn
ldap_dn = ldap.dn.explode_dn(dn)
except ldap.DECODING_ERROR:
# This is not a DN.
return None
if len(ldap_dn) > 0:
search_attrs = conf.get_list(
'kolab_smtp_access_policy',
'address_search_attrs'
)
rule_subject = self.auth.get_user_attributes(
self.sasl_domain,
{ 'dn': dn },
search_attrs + [ 'objectclass' ]
)
for search_attr in search_attrs:
#.........这里部分代码省略.........