~ajite/server-env-tools/7.0-server-env-tools-0001

« back to all changes in this revision

Viewing changes to users_ldap_groups/users_ldap_groups_operators.py

  • Committer: Stefan Rijnhart
  • Author(s): dgreis at sapo
  • Date: 2013-08-04 18:18:54 UTC
  • mfrom: (39.1.2 server-env-tools)
  • Revision ID: stefan@therp.nl-20130804181854-etly1posqhp6pezb
[MIG] Port of LDAP populate and group sync modules to 7.0

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# -*- coding: utf-8 -*-
 
2
##############################################################################
 
3
#
 
4
#    OpenERP, Open Source Management Solution
 
5
#    This module copyright (C) 2012 Therp BV (<http://therp.nl>).
 
6
#
 
7
#    This program is free software: you can redistribute it and/or modify
 
8
#    it under the terms of the GNU Affero General Public License as
 
9
#    published by the Free Software Foundation, either version 3 of the
 
10
#    License, or (at your option) any later version.
 
11
#
 
12
#    This program is distributed in the hope that it will be useful,
 
13
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
15
#    GNU Affero General Public License for more details.
 
16
#
 
17
#    You should have received a copy of the GNU Affero General Public License
 
18
#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
19
#
 
20
##############################################################################
 
21
from string import Template
 
22
 
 
23
class LDAPOperator:
 
24
  pass
 
25
 
 
26
class contains(LDAPOperator):
 
27
  def check_value(self, ldap_entry, attribute, value, ldap_config, company,
 
28
          logger):
 
29
    return (attribute in ldap_entry[1]) and (value in ldap_entry[1][attribute])
 
30
 
 
31
class equals(LDAPOperator):
 
32
  def check_value(self, ldap_entry, attribute, value, ldap_config, company,
 
33
          logger):
 
34
    return (attribute in ldap_entry[1]) and (str(value)==str(ldap_entry[1][attribute]))
 
35
 
 
36
class query(LDAPOperator):
 
37
  def check_value(self, ldap_entry, attribute, value, ldap_config, company,
 
38
          logger):
 
39
      query_string=Template(value).safe_substitute(dict([(attribute, 
 
40
          ldap_entry[1][attribute][0]) for attribute in ldap_entry[1]]))
 
41
      logger.debug('evaluating query group mapping, filter: %s'%query_string)
 
42
      results=company.query(ldap_config, query_string)
 
43
      logger.debug(results)
 
44
      return bool(results)