forked from jan/debianmemberportfolio
		
	Merge branch 'master' into pylons0.10
* master: use unquoted email address for MIA lookup mark all patterns that require optional information as optional update keyringanalyzer.py copyright information use email address for MIA pattern to catch non-DDs add support for automatic DM data lookup silence keyringanalyzer fix path handling in keyringanalyzer add flattr button add flattr button
This commit is contained in:
		
						commit
						d5c1fd1a34
					
				
					 6 changed files with 52 additions and 16 deletions
				
			
		|  | @ -149,12 +149,19 @@ developer name on all bug logs)'), | |||
|             return render('/showform.mako') | ||||
|         fields = dddatabuilder.build_data(form_result['email']) | ||||
|         rp = request.params.copy() | ||||
|         if fields['isdd']: | ||||
|             for tuple in (('name', 'name'), | ||||
| 
 | ||||
|         DM_TUPLES = (('name', 'name'), | ||||
|                      ('gpgfp', 'gpgfp'), | ||||
|                           ('username', 'username'), | ||||
|                           ('aliothusername', 'username'), | ||||
|                           ('nonddemail', 'email')): | ||||
|                      ('nonddemail', 'email')) | ||||
|         DD_TUPLES = (('username', 'username'), | ||||
|                      ('aliothusername', 'username')) | ||||
| 
 | ||||
|         if fields['type'] in (dddatabuilder.TYPE_DD, dddatabuilder.TYPE_DM): | ||||
|             for tuple in DM_TUPLES: | ||||
|                 if not tuple[0] in rp or not rp[tuple[0]]: | ||||
|                     rp[tuple[0]] = fields[tuple[1]] | ||||
|         if fields['type'] == dddatabuilder.TYPE_DD: | ||||
|             for tuple in DD_TUPLES: | ||||
|                 if not tuple[0] in rp or not rp[tuple[0]]: | ||||
|                     rp[tuple[0]] = fields[tuple[1]] | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| # -*- coding: utf-8 -*- | ||||
| # | ||||
| # DDPortfolio service DD data builder | ||||
| # Copyright (c) 2009 Jan Dittberner <jan@dittberner.info> | ||||
| # Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info> | ||||
| # | ||||
| # This file is part of DDPortfolio service. | ||||
| # | ||||
|  | @ -20,8 +20,14 @@ | |||
| # License along with this program.  If not, see | ||||
| # <http://www.gnu.org/licenses/>. | ||||
| # | ||||
| """This file contains code to build a representation of a person based | ||||
| on keyring data associated to a given email address.""" | ||||
| from ddportfolioservice.model import keyfinder | ||||
| 
 | ||||
| TYPE_NO = 0 | ||||
| TYPE_DM = 1 | ||||
| TYPE_DD = 2 | ||||
| 
 | ||||
| 
 | ||||
| def build_data(email_address): | ||||
|     """Build a DD data structure from a given email address.""" | ||||
|  | @ -32,7 +38,9 @@ def build_data(email_address): | |||
|                         ('username', keyfinder.getLoginByEmail)]]) | ||||
|     fields['email'] = email_address | ||||
|     if fields['username'] and fields['gpgfp'] and fields['name']: | ||||
|         fields['isdd'] = 1 | ||||
|         fields['type'] = TYPE_DD | ||||
|     elif fields['name'] and fields['gpgfp']: | ||||
|         fields['type'] = TYPE_DM | ||||
|     else: | ||||
|         fields['isdd'] = 0 | ||||
|         fields['type'] = TYPE_NO | ||||
|     return fields | ||||
|  |  | |||
|  | @ -54,6 +54,7 @@ patchtracker.pattern=http://patch-tracker.debian.org/email/%(email)s | |||
| [upload] | ||||
| urls=keylog | ||||
| keylog.pattern=http://merkel.debian.org/~enrico/keylog/%(gpgfp)s.html | ||||
| keylog.optional=true | ||||
| 
 | ||||
| [lists] | ||||
| urls=dolists,adolists,gmane | ||||
|  | @ -69,13 +70,17 @@ gmane.pattern=http://search.gmane.org/?email=%(name)s&group=gmane.linux.debi | |||
| [files] | ||||
| urls=people,alioth | ||||
| people.pattern=http://people.debian.org/~%(username)s/ | ||||
| people.optional=true | ||||
| alioth.pattern=http://alioth.debian.org/~%(aliothusername)s/ | ||||
| alioth.optional=true | ||||
| 
 | ||||
| [membership] | ||||
| urls=nm,db,alioth,wiki,forum | ||||
| nm.pattern=https://nm.debian.org/nmstatus.php?email=%(nonddemail)s | ||||
| db.pattern=http://db.debian.org/search.cgi?uid=%(username)s&dosearch=Search | ||||
| db.optional=true | ||||
| alioth.pattern=http://alioth.debian.org/users/%(aliothusername)s/ | ||||
| alioth.optional=true | ||||
| wiki.pattern=http://wiki.debian.org/%(wikihomepage)s | ||||
| forum.pattern=http://forums.debian.net/memberlist.php?mode=viewprofile&u=%(forumsid)d | ||||
| forum.optional=true | ||||
|  | @ -93,12 +98,14 @@ urls=owndndoms,miainfo,groupinfo | |||
| # owned *.debian.net domains | ||||
| owndndoms.pattern=ssh merkel.debian.org ldapsearch -u -x -H ldap://db.debian.org -b dc=debian,dc=org uid=%(username)s dnsZoneEntry | ||||
| owndndoms.type=ssh | ||||
| owndndoms.optional=true | ||||
| # MIA information | ||||
| miainfo.pattern=ssh merkel.debian.org /srv/qa.debian.org/mia/mia-query %(username)s | ||||
| miainfo.pattern=ssh merkel.debian.org /srv/qa.debian.org/mia/mia-query %(emailnoq)s | ||||
| miainfo.type=ssh | ||||
| # Group information | ||||
| groupinfo.pattern=ssh merkel.debian.org id %(username)s | ||||
| groupinfo.type=ssh | ||||
| groupinfo.optional=true | ||||
| 
 | ||||
| [ubuntu] | ||||
| urls=ubuntudiff | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| # -*- coding: utf-8 -*- | ||||
| # | ||||
| # DDPortfolio service application key ring analyzer tool | ||||
| # Copyright (c) 2009 Jan Dittberner <jan@dittberner.info> | ||||
| # Copyright © 2009, 2010 Jan Dittberner <jan@dittberner.info> | ||||
| # | ||||
| # This file is part of DDPortfolio service. | ||||
| # | ||||
|  | @ -31,6 +31,7 @@ import pkg_resources | |||
| import glob | ||||
| import ConfigParser | ||||
| import os | ||||
| import os.path | ||||
| 
 | ||||
| 
 | ||||
| def _get_keyrings(): | ||||
|  | @ -38,10 +39,9 @@ def _get_keyrings(): | |||
|     configured in ddportfolio.ini.""" | ||||
|     my_config = ConfigParser.ConfigParser() | ||||
|     my_config.readfp(pkg_resources.resource_stream(__name__, 'ddportfolio.ini')) | ||||
|     keyrings = glob.glob(my_config.get('DEFAULT', 'keyring.dir') + | ||||
|                          '/*.gpg') | ||||
|     keyrings.extend(glob.glob(my_config.get('DEFAULT', 'keyring.dir') + | ||||
|                               '/*.pgp')) | ||||
|     keyringdir = os.path.expanduser(my_config.get('DEFAULT', 'keyring.dir')) | ||||
|     keyrings = glob.glob(os.path.join(keyringdir, '*.gpg')) | ||||
|     keyrings.extend(glob.glob(os.path.join(keyringdir, '*.pgp'))) | ||||
|     keyrings.sort() | ||||
|     return keyrings | ||||
| 
 | ||||
|  |  | |||
|  | @ -76,6 +76,7 @@ def build_urls(fields): | |||
|         if fpr: | ||||
|             qfields['gpgfp'] = fpr[0] | ||||
|     qfields['firstchar'] = fields['email'][0].encode('utf8') | ||||
|     qfields['emailnoq'] = fields['email'].encode('utf8') | ||||
|     for section in [section.strip() for section in \ | ||||
|                         my_config.get('DEFAULT', | ||||
|                                       'urlbuilder.sections').split(',')]: | ||||
|  |  | |||
|  | @ -20,7 +20,7 @@ License along with this program.  If not, see | |||
| <http://www.gnu.org/licenses/>. | ||||
| </%doc>\ | ||||
| function updateFields(data, textStatus) { | ||||
|     if (data.isdd == 1) { | ||||
|     if (data.type == 2) { // DD | ||||
|         $('#name').attr('value', data.name).attr('readonly', 'readonly'); | ||||
|         $('#gpgfp').attr('value', data.gpgfp); | ||||
|         $('#username').attr('value', data.username).attr( | ||||
|  | @ -35,6 +35,19 @@ function updateFields(data, textStatus) { | |||
|         $('#aliothusernamefield').show(); | ||||
| 
 | ||||
|         $('#nonddemail').focus().select(); | ||||
|     } else if (data.type == 1) { // DM | ||||
|         $('#name').attr('value', data.name).attr('readonly', 'readonly'); | ||||
|         $('#gpgfp').attr('value', data.gpgfp); | ||||
|         $('#username').attr('value', ''); | ||||
|         $('#nonddemail').attr('value', data.email).focus(); | ||||
| 
 | ||||
|         $('#namefield').show(); | ||||
|         $('#gpgfpfield').show(); | ||||
|         $('#usernamefield').hide(); | ||||
|         $('#nonddemailfield').hide(); | ||||
|         $('#aliothusernamefield').show(); | ||||
| 
 | ||||
|         $('#aliothusername').focus().select(); | ||||
|     } else { | ||||
|         $('#nonddemail').attr('value', data.email); | ||||
|         $('#name').removeAttr('readonly'); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue