Changeset 10509
- Timestamp:
- 19 Aug 2013, 09:14:04 (11 years ago)
- Location:
- main/waeup.cas/trunk
- Files:
-
- 1 added
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
main/waeup.cas/trunk/setup.py
r10462 r10509 69 69 dummy = waeup.cas.authenticators:DummyAuthenticator 70 70 kofa1 = waeup.cas.authenticators:KofaAuthenticator 71 kofa_moodle1 = waeup.cas.authenticators:KofaMoodleAuthenticator 71 72 """, 72 73 ) -
main/waeup.cas/trunk/waeup/cas/authenticators.py
r10506 r10509 170 170 return (True, '') 171 171 return (False, 'Invalid username or password.') 172 173 class KofaMoodleAuthenticator(KofaAuthenticator): 174 """Authenticate against a running Kofa instance and transfer 175 data to Moodle. 176 177 Configuration of Moodle: 178 1. Set 'passwordpolicy' to No 179 2. Create external web service 'Kofa' with the following functions: 180 core_user_create_users, core_user_get_users, 181 core_user_update_users, enrol_manual_enrol_users 182 3. Create token for the admin user (no special web service user needed) 183 and for service 'Kofa' 184 4. Enable and configure CAS server authentication. 185 CAS protocol version is 1.0. Moodle expects SSL/TLS protocol. 186 """ 187 188 name = 'kofa_moodle1' 189 190 def check_credentials(self, username='', password=''): 191 """Do the real check. 192 """ 193 for backend_name, backend in self.backends.items(): 194 if not re.match(backend['marker'], username): 195 continue 196 # remove school marker 197 username = RE_SCHOOL_MARKER.sub('', username) 198 proxy = xmlrpclib.ServerProxy( 199 backend['url'], allow_none=True) 200 moodle = xmlrpclib.ServerProxy( 201 backend['moodle_url'], allow_none=True) 202 principal = proxy.check_applicant_credentials(username, password) 203 if principal is None: 204 principal = proxy.check_student_credentials(username, password) 205 if principal is not None: 206 if principal['type'] == 'student': 207 student = proxy.get_moodle_data(username) 208 try: 209 # Usernames in Moodle must not contain uppercase 210 # letters even if extendedusernamechars is set True. 211 result = moodle.core_user_create_users([ 212 {'username':username.lower(), 213 'password':'dummy', 214 'firstname':student['firstname'], 215 'lastname':student['lastname'], 216 'email':student['email']}]) 217 except xmlrpclib.Fault: 218 # user exists 219 pass 220 result = moodle.core_user_get_users([ 221 {'key':'username', 'value':username}]) 222 user_id = result['users'][0]['id'] 223 # Due to a lack of Moodle (Moodle requires an LDAP 224 # connection) the authentication method can't 225 # be set when the user is created. It must be updated 226 # after creation. 227 result = moodle.core_user_update_users([ 228 {'id':user_id,'auth':'cas'}]) 229 return (True, '') 230 return (False, 'Invalid username or password.')
Note: See TracChangeset for help on using the changeset viewer.