Trees | Indices | Help |
---|
|
1 # -*- Mode: Python; test-case-name: flumotion.test.test_htpasswdcrypt -*- 2 # vi:si:et:sw=4:sts=4:ts=4 3 # 4 # Flumotion - a streaming media server 5 # Copyright (C) 2004,2005,2006,2007 Fluendo, S.L. (www.fluendo.com). 6 # All rights reserved. 7 8 # This file may be distributed and/or modified under the terms of 9 # the GNU General Public License version 2 as published by 10 # the Free Software Foundation. 11 # This file is distributed without any warranty; without even the implied 12 # warranty of merchantability or fitness for a particular purpose. 13 # See "LICENSE.GPL" in the source distribution for more information. 14 15 # Licensees having purchased or holding a valid Flumotion Advanced 16 # Streaming Server license may use this file in accordance with the 17 # Flumotion Advanced Streaming Server Commercial License Agreement. 18 # See "LICENSE.Flumotion" in the source distribution for more information. 19 20 # Headers in this file shall remain intact. 21 22 """ 23 an htpasswd-backed bouncer with crypt passwords 24 """ 25 26 import md5 27 import random 28 29 from twisted.python import components 30 from twisted.internet import defer 31 32 from flumotion.common import interfaces, keycards, log, config 33 from flumotion.component import component 34 from flumotion.component.bouncers import bouncer 35 from flumotion.twisted import credentials, checkers 36 37 __all__ = ['HTPasswdCrypt'] 3840 41 logCategory = 'htpasswdcrypt' 42 # challenger type first, because it's more secure thus preferable 43 keycardClasses = (keycards.KeycardUACPCC, keycards.KeycardUACPP) 44 challengeResponseClasses = (keycards.KeycardUACPCC,) 458347 conf = self.config 48 49 # we need either a filename or data 50 filename = None 51 data = None 52 props = conf['properties'] 53 if props.has_key('filename'): 54 filename = props['filename'] 55 self.debug('using file %s for passwords', filename) 56 elif props.has_key('data'): 57 data = props['data'] 58 self.debug('using in-line data for passwords') 59 else: 60 return defer.fail(config.ConfigError( 61 'HTPasswdCrypt needs either a <data> or <filename> entry')) 62 # FIXME: generalize to a start method, possibly linked to mood 63 if filename: 64 try: 65 lines = open(filename).readlines() 66 except IOError, e: 67 return defer.fail(config.ConfigError(str(e))) 68 else: 69 lines = data.split("\n") 70 71 self.setChecker(checkers.CryptChecker()) 72 for line in lines: 73 if not ':' in line: continue 74 # when coming from a file, it ends in \n, so strip. 75 # for data, we already splitted, so no \n, but strip is fine. 76 name, cryptPassword = line.strip().split(':') 77 self.addUser(name, cryptPassword[:2], cryptPassword) 78 79 self.debug('parsed %s, %d lines' % (filename or '<memory>', 80 len(lines))) 81 82 return defer.succeed(None)
Trees | Indices | Help |
---|
Generated by Epydoc 3.0.1 on Thu Aug 7 15:45:44 2008 | http://epydoc.sourceforge.net |