def site_forgot_password(request): back=request.values.get('back', '') if request.method == 'POST': back = request.form.get('back', '') # create token otoken = PasswordToken(site=request.site._id) otoken.save() if request.site.alias: site_url = "http://%s.%s" % (request.site.alias, settings.SERVER_NAME) else: site_url = "http://%s/%s" % (settings.SERVER_NAME, request.site.cname) # send email mail_subject = u"Password to your couchit site" mail_content = render_template('site/forgot_password.txt', url=site_url, token=otoken._id) send_mail(mail_subject, mail_content, "CouchIt <*****@*****.**>", [request.site.email], fail_silently=True) request.session['notify'] = u"We've sent out the secret link. Go check your email!" redirect_url = url_for('site_login', back=back) return redirect(redirect_url) return render_response('site/forgot_password.html', back=back)
def site_claim(request): if request.method == "POST": site = get_site(request.site.cname) site.password = make_hash(request.form['password']) site.email = request.form['email'] site.privacy = request.form['privacy'] site.claimed = True site.save() request.site = site if site.alias: site_url = "http://%s.%s" % (site.alias, settings.SERVER_NAME) else: site_url = "http://%s/%s" % (settings.SERVER_NAME, site.cname) mail_subject = u"You claimed %s" % site_url mail_content = render_template("site/email_claimed.txt", url=site_url) send_mail(mail_subject, mail_content, "CouchIt <*****@*****.**>", [site.email], fail_silently=True) if local.site_url: redirect_url = local.site_url else: redirect_url = '/' request.session['%s_authenticated' % site.cname] = True; return redirect(redirect_url) return render_response('site/claim.html')