author | Pierre-Yves David <pierre-yves.david@logilab.fr> |
Tue, 11 Dec 2012 16:57:18 +0100 | |
branch | stable |
changeset 8611 | 51068fe1e39a |
parent 6387 | edbc53707bac |
child 9460 | a2a0bc984863 |
permissions | -rw-r--r-- |
6387
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
1 |
import base64 |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
2 |
from cubicweb.server.utils import crypt_password |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
3 |
|
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
4 |
dbdriver = config.sources()['system']['db-driver'] |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
5 |
from logilab.database import get_db_helper |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
6 |
dbhelper = get_db_helper(driver) |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
7 |
|
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
8 |
insert = ('INSERT INTO cw_cwuser (cw_creation_date,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
9 |
' cw_eid,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
10 |
' cw_modification_date,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
11 |
' cw_login,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
12 |
' cw_firstname,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
13 |
' cw_surname,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
14 |
' cw_last_login_time,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
15 |
' cw_upassword,' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
16 |
' cw_cwuri) ' |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
17 |
"VALUES (%(mtime)s, %(eid)s, %(mtime)s, %(login)s, " |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
18 |
" %(firstname)s, %(surname)s, %(mtime)s, %(pwd)s, 'foo');") |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
19 |
update = "UPDATE entities SET source='system' WHERE eid=%(eid)s;" |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
20 |
rset = sql("SELECT eid,type,source,extid,mtime FROM entities WHERE source!='system'", ask_confirm=False) |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
21 |
for eid, type, source, extid, mtime in rset: |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
22 |
if type != 'CWUser': |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
23 |
print "don't know what to do with entity type", type |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
24 |
continue |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
25 |
if not source.lower().startswith('ldap'): |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
26 |
print "don't know what to do with source type", source |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
27 |
continue |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
28 |
extid = base64.decodestring(extid) |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
29 |
ldapinfos = [x.strip().split('=') for x in extid.split(',')] |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
30 |
login = ldapinfos[0][1] |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
31 |
firstname = login.capitalize() |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
32 |
surname = login.capitalize() |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
33 |
args = dict(eid=eid, type=type, source=source, login=login, |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
34 |
firstname=firstname, surname=surname, mtime=mtime, |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
35 |
pwd=dbhelper.binary_value(crypt_password('toto'))) |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
36 |
print args |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
37 |
sql(insert, args) |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
38 |
sql(update, args) |
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
39 |
|
edbc53707bac
new script cwuser_ldap2system
Alexandre Fayolle <alexandre.fayolle@logilab.fr>
parents:
diff
changeset
|
40 |
commit() |