def delete_email(request, username, email): # the ID we are to delete auth_id = 'email:%s' % email user = User.get_by_auth_id('twitter:%s' % username) e_user = User.get_by_auth_id(auth_id) if user is None or e_user is None: raise Http404("User not found") if user != request.user or user != e_user: http403 = HttpResponse("This ain't you!") http403.status = 403 return http403 if request.method == "POST": # delete the email from the user user.auth_ids.remove(auth_id) user.unique_model.delete_multi(['User.auth_id:%s' % auth_id]) user.put() return HttpResponseRedirect( reverse('member-profile', kwargs={'username':request.user.username}) ) return render_to_response('people/delete_email.html', {'email': email}, context_instance=RequestContext(request))
def delete_email(request, username, email): # the ID we are to delete auth_id = 'email:%s' % email user = User.get_by_auth_id('own:%s' % username) e_user = User.get_by_auth_id(auth_id) if user is None or e_user is None: raise Http404("User not found") if user != request.user or user != e_user: http403 = HttpResponse("This ain't you!") http403.status = 403 return http403 if request.method == "POST": # delete the email from the user user.auth_ids.remove(auth_id) user.unique_model.delete_multi(['User.auth_id:%s' % auth_id]) user.put() return HttpResponseRedirect( reverse('member-profile', kwargs={'username':request.user.username}) ) return render_to_response('people/delete_email.html', {'email': email}, context_instance=RequestContext(request))
def post(self): """Create a project from the api. Example:: { "url": "http://github.com/defunkt/github", "name": "github", "description": "You're lookin' at it.", "watchers": 5, "forks": 2, "private": 1, "email": "*****@*****.**", "account": "twitter_name", }, """ form = self.parse_form() if not form.is_valid(): return self.respond_json(form.errors, status_code=400) # Lookup the user by email or account email = form.cleaned_data.pop('email', None) account = form.cleaned_data.pop('account', None) user = None if email: user = User.get_by_auth_id('email:%s' % email) elif account: user = User.get_by_auth_id('twitter:%s' % account) created = False project_url = form.cleaned_data['url'] project_key = Project.make_key(project_url) project = project_key.get() if project is None: created = True project = Project(key=project_key, **form.cleaned_data) project.put() @ndb.transactional def txn(): count = getattr(user, 'total', 0) projects = set(getattr(user, 'projects', [])) user.total = count + 10 user.projects = list(projects.add(project_url)) user.put() return user if created and user: txn() self.respond_json({'project': self.serialize(project)}, status_code=201 if created else 200)
def edit_profile(request, username, template_name='people/edit.html'): from forms import EditUserForm user = User.get_by_auth_id('twitter:%s' % username) if user == None: raise Http404("User not found") if user.key != request.user.key: http403 = HttpResponse("This ain't you!") http403.status = 403 return http403 form = EditUserForm(request.POST or None, user=request.user) if form.is_valid(): for key in form.cleaned_data: if key == 'email': continue setattr(user, key, form.cleaned_data.get(key)) slugify(user.location) user.put() return HttpResponseRedirect( reverse('member-profile', kwargs={'username':request.user.username} ) ) return render_to_response(template_name, {'form':form}, context_instance=RequestContext(request))
def test_project_url(self): user = self.make_user('marcus') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/bitbucket', self.POST) user = User.get_by_auth_id('email:[email protected]') self.assertTrue( 'https://some.other.org/marcus/project-x/' in user.projects)
def edit_address(request, username, template_name='people/edit_address.html'): from forms import EditAddressForm user = User.get_by_auth_id('own:%s' % username) if user == None: raise Http404("User not found") if user.key != request.user.key: http403 = HttpResponse("This ain't you!") http403.status = 403 return http403 form = EditAddressForm(request.POST or None, user=user) if form.is_valid(): for key, value in form.cleaned_data.iteritems(): setattr(user,key,value) user.put() return HttpResponseRedirect( reverse('member-profile', kwargs={'username':request.user.username} ) ) return render_to_response(template_name, {'form':form}, context_instance=RequestContext(request))
def test_testing_mode_off_user_points(self): settings.TESTING = False user = self.make_user('chris') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/github', self.POST) u = User.get_by_auth_id('email:[email protected]') total = getattr(u, 'total', None) self.assertEqual(total, None)
def test_testing_mode_off_user_points(self): settings.TESTING = False user = self.make_user('marcus') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/bitbucket', self.POST) u = User.get_by_auth_id('email:[email protected]') total = getattr(u, 'total', None) self.assertEqual(total, None)
def test_testing_mode_off(self): settings.TESTING = False user = self.make_user('marcus') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/bitbucket', self.POST) u = User.get_by_auth_id('email:[email protected]') p_key = Project.make_key('https://bitbucket.org/marcus/project-x/') # project should not be created self.assertEqual(p_key.get(), None)
def fix_player_counts(auth_id): """Fix a single user counts.""" user = User.get_by_auth_id(auth_id) ranges = _get_date_ranges() for start, end in ranges: count = Commit.query(ancestor=user.key).filter(Commit.timestamp >= start, Commit.timestamp < end).count(1000) Accumulator.add_count('own:%s' % user.username, start, count, reset=True)
def user_profile(request, username): user = User.get_by_auth_id('twitter:%s' % username) if user == None: raise Http404("User not found") commits = Commit.query(ancestor=user.key).order(-Commit.timestamp).fetch(100) return render_to_response('people/profile.html', {"commits":commits, 'profile':user}, context_instance=RequestContext(request))
def user_profile(request, username): user = User.get_by_auth_id('own:%s' % username) if user == None: raise Http404("User not found") commits = Commit.query(ancestor=user.key).order(-Commit.timestamp).fetch(100) return render_to_response('people/profile.html', {"commits":commits, 'profile':user}, context_instance=RequestContext(request))
def wrapper(self, *args, **kwargs): if login_required: if self.auth is None: abort(401) if registration_required: # check to see if the user is registered. user = User.get_by_auth_id(self.auth) if not user: abort(403) return func(self, *args, **kwargs)
def fix_player_counts(auth_id): """Fix a single user counts.""" user = User.get_by_auth_id(auth_id) ranges = _get_date_ranges() for start, end in ranges: count = Commit.query(ancestor=user.key).filter( Commit.timestamp >= start, Commit.timestamp < end).count(1000) Accumulator.add_count('own:%s' % user.username, start, count, reset=True)
def people_projects(request, username): user = User.get_by_auth_id('twitter:%s' % username) if user == None: raise Http404("User not found") if getattr(user, 'projects', None) == None: projects = [] else: projects = user.projects projects = [Project.get_or_create(url=project)[1] for project in projects] return render_to_response('people/people_projects.html', {"projects":projects, 'profile':user}, context_instance=RequestContext(request))
def people_projects(request, username): user = User.get_by_auth_id('own:%s' % username) if user == None: raise Http404("User not found") if getattr(user, 'projects', None) == None: projects = [] else: projects = user.projects projects = ndb.get_multi([Project.make_key(project) for project in projects]) return render_to_response('people/people_projects.html', {"projects":projects, 'profile':user}, context_instance=RequestContext(request))
def edit_profile(request, username, template_name='people/edit.html'): from forms import EditUserForm user = User.get_by_auth_id('own:%s' % username) if user == None: raise Http404("User not found") if user.key != request.user.key: http403 = HttpResponse("This ain't you!") http403.status = 403 return http403 existing_slug = str(user.location_slug) existing_team = str(getattr(user, 'team_slug', '')) form = EditUserForm(request.POST or None, user=request.user) if form.is_valid(): for key, value in form.cleaned_data.iteritems(): if key == 'email': # Don't save the email to the profile continue if key == 'team': # slugify the team to allow easy lookups setattr(user, 'team_slug', slugify(value)) setattr(user, key, value) user.put() if user.location_slug != existing_slug: # Defer a couple tasks to update the locations deferred.defer(fix_location, str(user.location_slug)) deferred.defer(fix_location, existing_slug) if getattr(user, 'team_slug', '') != existing_team: # Defer a couple tasks to update the teams deferred.defer(fix_team, str(user.team_slug)) deferred.defer(fix_team, existing_team) return HttpResponseRedirect( reverse('member-profile', kwargs={'username':request.user.username} ) ) return render_to_response(template_name, {'form':form}, context_instance=RequestContext(request))
def handle_filter(self, query, filter_string): """Allow for filtering by user or project""" if filter_string.startswith('#'): # we're looking for a project strip the hash tag first project_name = filter_string[1:] logging.error('Handle Projects!!! %s', project_name) raise elif filter_string.startswith('@'): username = '******' % filter_string[1:] else: username = filter_string logging.info('looking up commits for user: %s', username) user = User.get_by_auth_id(username) if user is None: abort(404) return self.model.query(ancestor=user.key)
def create_by_auth_id(cls, auth_id, commits, project=None): user = User.get_by_auth_id(auth_id) if user: return cls.create_by_user(user, commits, project=project) return cls.create_orphan(commits, project=project)
def test_post_adds_points_to_user(self): user = self.make_user('marcus') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/bitbucket', self.POST) u = User.get_by_auth_id('email:[email protected]') self.assertEqual(u.total, 11)
def user(self): """Check the authorization header for a username to lookup""" if self.auth: return User.get_by_auth_id(self.auth) return None
def test_post_adds_points_to_user(self): user = self.make_user('chris') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/github', self.POST) u = User.get_by_auth_id('email:[email protected]') self.assertEqual(u.total, 12)
def test_project_url(self): user = self.make_user('marcus') user.add_auth_id('email:[email protected]') self.app.post('/api/v1/bitbucket', self.POST) user = User.get_by_auth_id('email:[email protected]') self.assertTrue('https://some.other.org/marcus/project-x/' in user.projects)