[lib] ajout des fichiers non suivis

darcs-hash:20090609134320-bd074-f4df3e57ff2a6e60f07e25cda773524c8e20de3c.gz
This commit is contained in:
Antoine Durand-Gasselin 2009-06-09 15:43:20 +02:00
parent dce8ccb6da
commit c2535c1f04
17 changed files with 2346 additions and 0 deletions

0
lib/gestion/__init__.py Normal file
View file

80
lib/gestion/authentification.py Executable file
View file

@ -0,0 +1,80 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# #############################################################
# ..
# .... ............ ........
# . ....... . .... ..
# . ... .. .. .. .. ..... . ..
# .. .. ....@@@. .. . ........ .
# .. . .. ..@.@@..@@. .@@@@@@@ @@@@@@. ....
# .@@@@. .@@@@. .@@@@..@@.@@..@@@..@@@..@@@@.... ....
# @@@@... .@@@.. @@ @@ .@..@@..@@...@@@. .@@@@@. ..
# .@@@.. . @@@. @@.@@..@@.@@..@@@ @@ .@@@@@@.. .....
# ...@@@.... @@@ .@@.......... ........ ..... ..
# . ..@@@@.. . .@@@@. .. ....... . .............
# . .. .... .. .. . ... ....
# . . .... ............. .. ...
# .. .. ... ........ ... ...
# ................................
#
# #############################################################
# authentification.py
#
# Fonction de login et petite classe utilisateur
#
# Auteur: Grégoire Détrez <gdetrez@crans.org>
# Copyright (c) 2008 by www.crans.org
# #############################################################
import ldap
#import cransldap
import models
import fields
LDAP_SERVER = "ldap.adm.crans.org"
# Petite classe Avec les infos de base de l'utilisateur
class User(models.Model):
prenom = fields.stringField( "Prénom" )
nom = fields.stringField( "Nom" )
mail = fields.stringField( "Couriel" )
uid = fields.loginField( "Identifiant" )
aid = fields.intField( "aid" )
droits = fields.listField( "Droits", fields.stringField(None) )
def is_nounou(self):
return u"Nounou" in self.droits
class AuthentificationFailed(Exception):
def __str__(self):
return "Oups, auth failed"
def login( id, password ):
""" returns a User object """
con = ldap.open( LDAP_SERVER )
try:
user_dn = get_dn_from_id( id, con )
except ValueError:
raise AuthentificationFailed
try:
con.bind_s(user_dn, password)
except ldap.INVALID_CREDENTIALS, e:
raise AuthentificationFailed
data = con.search_s(user_dn, ldap.SCOPE_SUBTREE)
con.unbind()
data = data[0][1]
return User(data)
def get_dn_from_id( id, ldap_connexion=None ):
if ldap_connexion == None:
ldap_connexion = ldap.open( LDAP_SERVER )
try:
aid = int( id )
user_dn = "aid=%d,ou=data,dc=crans,dc=org" % aid
return user_dn
except ValueError:
data = ldap_connexion.search_s("ou=data,dc=crans,dc=org",
ldap.SCOPE_SUBTREE,
"uid=%s" % id)
if len(data) != 1:
raise ValueError, "Id invalid"
else: return data[0][0]

225
lib/gestion/fields.py Executable file
View file

@ -0,0 +1,225 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# #############################################################
# ..
# .... ............ ........
# . ....... . .... ..
# . ... .. .. .. .. ..... . ..
# .. .. ....@@@. .. . ........ .
# .. . .. ..@.@@..@@. .@@@@@@@ @@@@@@. ....
# .@@@@. .@@@@. .@@@@..@@.@@..@@@..@@@..@@@@.... ....
# @@@@... .@@@.. @@ @@ .@..@@..@@...@@@. .@@@@@. ..
# .@@@.. . @@@. @@.@@..@@.@@..@@@ @@ .@@@@@@.. .....
# ...@@@.... @@@ .@@.......... ........ ..... ..
# . ..@@@@.. . .@@@@. .. ....... . .............
# . .. .... .. .. . ... ....
# . . .... ............. .. ...
# .. .. ... ........ ... ...
# ................................
#
# #############################################################
# __init__.py
#
# Fields: outils pour passer les informations de la base
# vers les objets python et vice-versa
#
# Auteur: Grégoire Détrez <gdetrez@crans.org>
# Copyright (c) 2008 by www.crans.org
# #############################################################
import re
class baseField(object):
def __init__(self, name):
self.name = name
def _save_field( self, data ):
return data
def _load_field( self, data ):
return str(data)
def load( self, ldap_data ):
if ldap_data == None: return None
return self._load_field( ldap_data[0] )
def save( self, field_data ):
return [ self._save_field( field_data )]
class stringField( baseField ):
pass
class reField( stringField ):
def __init__( self, name, expr ):
baseField.__init__(self, name)
self.expr = re.compile(expr)
def _save_field(self, field_data):
if self.expr.match( field_data ):
return field_data
else:
raise ValueError, "Incorect value for field %s" % self.name
class macField( reField ):
def __init__( self, name ):
self = reField.__init__(self, name, "^([0-9a-fA-F]{2}:){5}[0-9a-fA-F]{2}$")
def _save_field( self, data ):
data = data.lower()
if not self.expr.match( data ):
data = re.sub( "[^0-9a-fA-F]", "", data )
if len(data) == 12:
data = data[0:2] + ":" + data[2:4] + ":" + data [4:6] + ":" + data[6:8] + ":" + data[8:10] + ":" + data[10:12]
return reField._save_field( self, data )
class ipField( reField ):
def __init__( self, name ):
self = reField.__init__(self, name, "^(\d{1,3}\.){3}\d{1,3}$")
class emailField( reField ):
def __init__( self, name, suffix=None ):
stringField.__init__( self, name)
self.expr = re.compile("^(?P<prefix>[\w\+]+)(@(?P<suffix>[\w\.]+\.\w{1,3}))?$" )
self.suffix = suffix
def _load_field(self, data):
if self.suffix:
m = self.expr.match( data )
if m.group('suffix'):
return data
else:
return data + u"@" + self.suffix
else:
return data
def _save_field(self, data):
m = self.expr.match( data )
if m:
if self.suffix and m.group("suffix") == self.suffix:
return m.group("prefix")
return data
else:
raise ValueError, "Mail invalid"
class loginField( reField ):
def __init__( self, name ):
self = reField.__init__(self, name, "^[a-z]{4,}$")
class listField( baseField ):
def __init__( self, name, type_field ):
baseField.__init__(self, name)
self.type_field = type_field
def load( self, ldap_data ):
if ldap_data == None: return []
return map( self.type_field._load_field, ldap_data )
def save( self, field_data ):
return map( self.type_field._save_field, field_data )
class historyField( baseField ):
pass
class pathField( baseField ):
pass
class intField( baseField ):
def _load_field( self, ldap_data ):
return int( ldap_data )
def _save_field(self, field_data ):
return str( field_data )
class booleanField( baseField ):
def _load_field( self, ldap_data ):
return ldap_data == 'TRUE'
def _save_field( self, field_Data ):
if field_data: return 'TRUE'
else: return 'FALSE'
class telField( reField ):
def __init__(self, name ):
reField.__init__( self, name, "^\d{10}$")
def _save_field( self, data ):
return reField._save_field( self, re.sub("[\ \.,]", "", data ) )
if __name__ == "__main__":
import unittest
class TestFields(unittest.TestCase):
def setUp(self):
pass
def testBaseField( self ):
field = baseField( "Un nom" )
assert field.load(["un test"]) == "un test"
assert field.save("un test") == ["un test"]
def testStringField( self ):
field = stringField( "Un nom" )
assert field.load(["une string"]) == "une string"
assert field.save("une string") == ["une string"]
def testReField( self ):
field = reField( "Un nom", "^[A-Z][a-z]+$" )
assert field.load(["Coucou"]) == "Coucou"
assert field.save("Coucou") == ["Coucou"]
self.assertRaises(ValueError, field.save, "")
self.assertRaises(ValueError, field.save, "coucou")
self.assertRaises(ValueError, field.save, "coucou monde")
self.assertRaises(ValueError, field.save, "Coucou monde")
def testMacField( self ):
field = macField( "Un nom" )
assert field.load(["00:0f:20:57:6e:81"]) == "00:0f:20:57:6e:81"
assert field.save("00:0f:20:57:6e:81") == ["00:0f:20:57:6e:81"]
assert field.save("00:0F:20:57:6E:81") == ["00:0f:20:57:6e:81"]
assert field.save("000f20576e81") == ["00:0f:20:57:6e:81"]
assert field.save("00 0f 20 57 6e 81") == ["00:0f:20:57:6e:81"]
self.assertRaises(ValueError, field.save, "00:0f:20:57:6e:81:34")
self.assertRaises(ValueError, field.save, "00:0f:20:57:6e:8")
self.assertRaises(ValueError, field.save, "00:0f:20:57:6e")
self.assertRaises(ValueError, field.save, "00:0f:20:57:6k:81")
def testIpField( self ):
field = ipField( "Un nom" )
assert field.load(["129.168.0.34"]) == "129.168.0.34"
assert field.save("129.168.0.34") == ["129.168.0.34"]
self.assertRaises(ValueError, field.save, "192.16.8")
self.assertRaises(ValueError, field.save, "192.16.8.2.3")
self.assertRaises(ValueError, field.save, "192.16.8.e")
self.assertRaises(ValueError, field.save, "125.34..56")
def testEmailField( self ):
field = emailField( "Un email", suffix="crans.org" )
assert field.load(["toto@exemple.com"]) == "toto@exemple.com"
assert field.save("toto@exemple.com") == ["toto@exemple.com"]
assert field.load(["toto@crans.org"]) == "toto@crans.org"
assert field.load(["toto"]) == "toto@crans.org"
assert field.save("toto") == ["toto"]
assert field.save("toto@crans.org") == ["toto"]
self.assertRaises(ValueError, field.save, "toto@")
self.assertRaises(ValueError, field.save, "toto@test")
self.assertRaises(ValueError, field.save, "test.com")
def testLoginField( self ):
field = loginField( "Un nom" )
assert field.load(["toto"]) == "toto"
assert field.save("toto") == ["toto"]
# def testHistoryField( self ):
# field = baseField( "Un nom" )
# assert field.load(["un test"]) == "un test"
# assert field.save("un test") == ["un test"]
def testListField( self ):
field = listField( "Un nom", stringField(None) )
assert field.load(["un test"]) == ["un test"]
assert field.load(["un test", "un autre"]) == ["un test", "un autre"]
def testTelField( self ):
field = telField( "Un nom" )
assert field.load(["0606060606"]) == "0606060606"
assert field.save("0606060606") == ["0606060606"]
assert field.save("06 060 606 06") == ["0606060606"]
assert field.save("06 06 06 06 06") == ["0606060606"]
self.assertRaises(ValueError, field.save, "06060606")
self.assertRaises(ValueError, field.save, "06060606060606")
unittest.main()

48
lib/gestion/models.py Executable file
View file

@ -0,0 +1,48 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# #############################################################
# ..
# .... ............ ........
# . ....... . .... ..
# . ... .. .. .. .. ..... . ..
# .. .. ....@@@. .. . ........ .
# .. . .. ..@.@@..@@. .@@@@@@@ @@@@@@. ....
# .@@@@. .@@@@. .@@@@..@@.@@..@@@..@@@..@@@@.... ....
# @@@@... .@@@.. @@ @@ .@..@@..@@...@@@. .@@@@@. ..
# .@@@.. . @@@. @@.@@..@@.@@..@@@ @@ .@@@@@@.. .....
# ...@@@.... @@@ .@@.......... ........ ..... ..
# . ..@@@@.. . .@@@@. .. ....... . .............
# . .. .... .. .. . ... ....
# . . .... ............. .. ...
# .. .. ... ........ ... ...
# ................................
#
# #############################################################
# models.py
#
# Classe de base pour mapper automatiquement des
# enregistrements ldap et des objets python
#
# Auteur: Grégoire Détrez <gdetrez@crans.org>
# Copyright (c) 2008 by www.crans.org
# #############################################################
import fields
class MetaModel(type):
def __init__(cls, name, bases, attrs):
super(type, cls).__init__(cls, name, bases, attrs)
_fields = {}
for item_name in attrs:
if isinstance(attrs[item_name], fields.baseField):
_fields[item_name] = attrs[item_name]
setattr(cls, "_model_fields", _fields)
class Model(object):
__metaclass__ = MetaModel
def __init__( self, data ):
k = self._model_fields
for a_field in self._model_fields:
val = self._model_fields[a_field].load(data.get(a_field, None))
setattr(self, a_field, val)