def signup_noncommercial(): """Sign up endpoint for non-commercial users.""" mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data(**{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_NONCOMMERCIAL, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = NonCommercialSignUpForm(default_email=mb_email) if form.validate_on_submit(): # Checking if this user already exists new_user = User.get(musicbrainz_id=mb_username) if not new_user: new_user = User.add( is_commercial=False, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, ) login_user(new_user) flash.success("Thanks for signing up!") send_mail( subject="[MetaBrainz] Sign up confirmation", text='Dear %s,\n\nThank you for signing up!\n\nYou can now generate ' 'an access token for the MetaBrainz API on your profile page.' % new_user.contact_name, recipients=[new_user.contact_email], ) return redirect(url_for('.profile')) return render_template("users/signup-non-commercial.html", form=form)
def signup_noncommercial(): """Sign up endpoint for non-commercial users.""" mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data(**{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_NONCOMMERCIAL, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = NonCommercialSignUpForm(default_email=mb_email) if form.validate_on_submit(): new_user = User.add( is_commercial=False, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, ) login_user(new_user) flash.success("Thanks for signing up!") send_mail( subject="[MetaBrainz] Sign up confirmation", text='Dear %s,\n\nThank you for signing up!\n\nYou can now generate ' 'an access token for the MetaBrainz API on your profile page.' % new_user.contact_name, recipients=[new_user.contact_email], ) return redirect(url_for('.profile')) return render_template("users/signup-non-commercial.html", form=form)
def musicbrainz_post(): """MusicBrainz OAuth2 callback endpoint.""" if not musicbrainz_login.validate_post_login(): raise BadRequest(gettext("Login failed!")) code = request.args.get('code') if not code: raise InternalServerError(gettext("Authorization code is missing!")) try: mb_username, mb_email = musicbrainz_login.get_user(code) except KeyError: raise BadRequest(gettext("Login failed!")) session.persist_data(**{ SESSION_KEY_MB_USERNAME: mb_username, SESSION_KEY_MB_EMAIL: mb_email, }) user = User.get(musicbrainz_id=mb_username) if user: # Checking if user is already signed up login_user(user) next = session.session.get('next') return redirect(next) if next else redirect(url_for('.profile')) else: flash.info( "This is the first time you've signed into metabrainz.org, please sign up!" ) return redirect(url_for('.signup'))
def get_authentication_uri(): """Prepare and return URL to authentication service login form.""" csrf = generate_string(20) session.persist_data(csrf=csrf) params = { 'response_type': 'code', 'redirect_uri': url_for( 'users.musicbrainz_post', _external=True, _scheme=current_app.config['PREFERRED_URL_SCHEME'], ), 'scope': 'profile email', 'state': csrf, } return _musicbrainz_service.get_authorize_url(**params)
def musicbrainz_post(): """MusicBrainz OAuth2 callback endpoint.""" if not musicbrainz_login.validate_post_login(): raise BadRequest("Login failed!") code = request.args.get('code') if not code: raise InternalServerError("Authorization code is missing!") mb_username, mb_email = musicbrainz_login.get_user(code) session.persist_data(**{ SESSION_KEY_MB_USERNAME: mb_username, SESSION_KEY_MB_EMAIL: mb_email, }) user = User.get(musicbrainz_id=mb_username) if user: # Checking if user is already signed up login_user(user) next = session.session.get('next') return redirect(next) if next else redirect(url_for('.profile')) else: return redirect(url_for('.signup'))
def signup_noncommercial(): """Sign up endpoint for non-commercial users.""" mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data(**{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_NONCOMMERCIAL, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = NonCommercialSignUpForm(default_email=mb_email) if form.validate_on_submit(): # Checking if this user already exists new_user = User.get(musicbrainz_id=mb_username) if not new_user: new_user = User.add( is_commercial=False, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, ) flash.success(gettext("Thanks for signing up!")) try: send_mail( subject="[MetaBrainz] Sign up confirmation", text='Dear %s,\n\nThank you for signing up!\n\nYou can now generate ' 'an access token for the MetaBrainz API on your profile page.' % new_user.contact_name, recipients=[new_user.contact_email], ) except MailException as e: logging.error(e) flash.warning(gettext( "Failed to send welcome email to you. We are looking into it. " "Sorry for inconvenience!" )) else: flash.info(gettext("You already have a MetaBrainz account!")) login_user(new_user) return redirect(url_for('.profile')) return render_template("users/signup-non-commercial.html", form=form, mb_username=mb_username)
def signup_noncommercial(): """Sign up endpoint for non-commercial users.""" mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data(**{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_NONCOMMERCIAL, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = NonCommercialSignUpForm(default_email=mb_email) if form.validate_on_submit(): new_user = User.add( is_commercial=False, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, ) login_user(new_user) flash.success("Thanks for signing up!") return redirect(url_for('.profile')) return render_template("users/signup-non-commercial.html", form=form)
def signup_commercial(): """Sign up endpoint for commercial users. Commercial users need to choose support tier before filling out the form. `tier_id` argument with ID of a tier of choice is required there. """ tier_id = request.args.get('tier_id') if not tier_id: flash.warn("You need to choose support tier before signing up!") return redirect(url_for('.account_type')) selected_tier = Tier.get(id=tier_id) if not selected_tier or not selected_tier.available: flash.error("You need to choose existing tier before signing up!") return redirect(url_for(".account_type")) mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data(**{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_COMMERCIAL, SESSION_KEY_TIER_ID: selected_tier.id, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = CommercialSignUpForm(default_email=mb_email) def custom_validation(f): if f.amount_pledged.data < selected_tier.price: flash.warning("Custom amount must be more than threshold amount" "for selected tier or equal to it!") return False # Complete address is required if payment method is invoicing if f.payment_method.data == PAYMENT_METHOD_INVOICING: if not (form.address_street.data and form.address_city.data and form.address_state.data and form.address_postcode.data and form.address_country.data): flash.warning("You need to fill in all address fields if your " "selected payment method is invoicing!") return False return True if form.validate_on_submit() and custom_validation(form): new_user = User.add( is_commercial=True, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, org_name=form.org_name.data, org_desc=form.org_desc.data, website_url=form.website_url.data, org_logo_url=form.logo_url.data, api_url=form.api_url.data, address_street=form.address_street.data, address_city=form.address_city.data, address_state=form.address_state.data, address_postcode=form.address_postcode.data, address_country=form.address_country.data, tier_id=tier_id, payment_method=form.payment_method.data, amount_pledged=form.amount_pledged.data, ) login_user(new_user) flash.success("Thanks for signing up! Your application will be reviewed " "soon. We will send you updates via email.") send_mail( subject="[MetaBrainz] Sign up confirmation", text="Dear %s,\n\nThank you for signing up!\n\nCurrently everyone is on " "a summer vacation until July 14. Your application will be reviewed " "as soon as we get back. We will send you updates via email. Sorry " "for the inconvenience." % new_user.contact_name, recipients=[new_user.contact_email], ) return redirect(url_for('.profile')) return render_template("users/signup-commercial.html", form=form, tier=selected_tier)
def signup_commercial(): """Sign up endpoint for commercial users. Commercial users need to choose support tier before filling out the form. `tier_id` argument with ID of a tier of choice is required there. """ tier_id = request.args.get('tier_id') if not tier_id: flash.warn("You need to choose support tier before signing up!") return redirect(url_for('.account_type')) selected_tier = Tier.get(id=tier_id) if not selected_tier or not selected_tier.available: flash.error("You need to choose existing tier before signing up!") return redirect(url_for(".account_type")) mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data(**{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_COMMERCIAL, SESSION_KEY_TIER_ID: selected_tier.id, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = CommercialSignUpForm(default_email=mb_email) def custom_validation(f): if f.amount_pledged.data < selected_tier.price: flash.warning("Custom amount must be more than threshold amount" "for selected tier or equal to it!") return False return True if form.validate_on_submit() and custom_validation(form): # Checking if this user already exists new_user = User.get(musicbrainz_id=mb_username) if not new_user: new_user = User.add( is_commercial=True, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, org_name=form.org_name.data, org_desc=form.org_desc.data, website_url=form.website_url.data, org_logo_url=form.logo_url.data, api_url=form.api_url.data, address_street=form.address_street.data, address_city=form.address_city.data, address_state=form.address_state.data, address_postcode=form.address_postcode.data, address_country=form.address_country.data, tier_id=tier_id, amount_pledged=form.amount_pledged.data, ) flash.success("Thanks for signing up! Your application will be reviewed " "soon. We will send you updates via email.") send_mail( subject="[MetaBrainz] Sign up confirmation", text='Dear %s,\n\nThank you for signing up!\n\nYour application' ' will be reviewed soon. We will send you updates via email.' % new_user.contact_name, recipients=[new_user.contact_email], ) else: flash.info("You already have a MetaBrainz account!") login_user(new_user) return redirect(url_for('.profile')) return render_template("users/signup-commercial.html", form=form, tier=selected_tier, mb_username=mb_username)
def signup_commercial(): """Sign up endpoint for commercial users. Commercial users need to choose support tier before filling out the form. `tier_id` argument with ID of a tier of choice is required there. """ tier_id = request.args.get('tier_id') if not tier_id: flash.warn( gettext("You need to choose support tier before signing up!")) return redirect(url_for('.account_type')) selected_tier = Tier.get(id=tier_id) if not selected_tier or not selected_tier.available: flash.error( gettext("You need to choose existing tier before signing up!")) return redirect(url_for(".account_type")) mb_username = session.fetch_data(SESSION_KEY_MB_USERNAME) if not mb_username: session.persist_data( **{ SESSION_KEY_ACCOUNT_TYPE: ACCOUNT_TYPE_COMMERCIAL, SESSION_KEY_TIER_ID: selected_tier.id, }) return redirect(url_for(".signup")) mb_email = session.fetch_data(SESSION_KEY_MB_EMAIL) form = CommercialSignUpForm(default_email=mb_email) def custom_validation(f): if f.amount_pledged.data < selected_tier.price: flash.warning( gettext("Custom amount must be more than threshold amount" "for selected tier or equal to it!")) return False return True if form.validate_on_submit() and custom_validation(form): # Checking if this user already exists new_user = User.get(musicbrainz_id=mb_username) if not new_user: new_user = User.add( is_commercial=True, musicbrainz_id=mb_username, contact_name=form.contact_name.data, contact_email=form.contact_email.data, data_usage_desc=form.usage_desc.data, org_name=form.org_name.data, org_desc=form.org_desc.data, website_url=form.website_url.data, org_logo_url=form.logo_url.data, api_url=form.api_url.data, address_street=form.address_street.data, address_city=form.address_city.data, address_state=form.address_state.data, address_postcode=form.address_postcode.data, address_country=form.address_country.data, tier_id=tier_id, amount_pledged=form.amount_pledged.data, ) flash.success( gettext( "Thanks for signing up! Your application will be reviewed " "soon. We will send you updates via email.")) try: send_mail( subject="[MetaBrainz] Sign up confirmation", text= 'Dear %s,\n\nThank you for signing up!\n\nYour application' ' will be reviewed soon. We will send you updates via email.' % new_user.contact_name, recipients=[new_user.contact_email], ) except MailException as e: logging.error(e) flash.warn( gettext( "Failed to send welcome email to you. We are looking into it. " "Sorry for inconvenience!")) else: flash.info(gettext("You already have a MetaBrainz account!")) login_user(new_user) return redirect(url_for('.profile')) return render_template("users/signup-commercial.html", form=form, tier=selected_tier, mb_username=mb_username)