#!/usr/bin/perl -wT # -*- Mode: perl; indent-tabs-mode: nil -*- # # The contents of this file are subject to the Mozilla Public # License Version 1.1 (the "License"); you may not use this file # except in compliance with the License. You may obtain a copy of # the License at http://www.mozilla.org/MPL/ # # Software distributed under the License is distributed on an "AS # IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or # implied. See the License for the specific language governing # rights and limitations under the License. # # The Original Code is the Bugzilla Bug Tracking System. # # The Initial Developer of the Original Code is Netscape Communications # Corporation. Portions created by Netscape are # Copyright (C) 1998 Netscape Communications Corporation. All # Rights Reserved. # # Contributor(s): Terry Weissman # David Gardiner # Joe Robins # Christopher Aillon # Gervase Markham use strict; use lib qw(.); require "globals.pl"; use Bugzilla; use Bugzilla::Constants; use Bugzilla::User; use Bugzilla::BugMail; use Bugzilla::Util; # Just in case someone already has an account, let them get the correct footer # on an error message. The user is logged out just after the account is # actually created. Bugzilla->login(LOGIN_OPTIONAL); my $dbh = Bugzilla->dbh; my $cgi = Bugzilla->cgi; my $template = Bugzilla->template; my $vars = {}; print $cgi->header(); # If we're using LDAP for login, then we can't create a new account here. unless (Bugzilla->user->authorizer->user_can_create_account) { ThrowUserError("auth_cant_create_account"); } my $createexp = Param('createemailregexp'); unless ($createexp) { ThrowUserError("account_creation_disabled"); } my $login = $cgi->param('login'); if (defined($login)) { # We've been asked to create an account. my $realname = trim($cgi->param('realname')); validate_email_syntax($login) || ThrowUserError('illegal_email_address', {addr => $login}); $vars->{'login'} = $login; $dbh->bz_lock_tables('profiles WRITE', 'profiles_activity WRITE', 'user_group_map WRITE', 'email_setting WRITE', 'groups READ', 'tokens READ', 'fielddefs READ'); if (!is_available_username($login)) { # Account already exists $dbh->bz_unlock_tables(); $template->process("account/exists.html.tmpl", $vars) || ThrowTemplateError($template->error()); exit; } if ($login !~ /$createexp/) { ThrowUserError("account_creation_disabled"); } # Create account my $password = insert_new_user($login, $realname); $dbh->bz_unlock_tables(); # Clear out the login cookies in case the user is currently logged in. Bugzilla->logout(); Bugzilla::BugMail::MailPassword($login, $password); $template->process("account/created.html.tmpl", $vars) || ThrowTemplateError($template->error()); exit; } # Show the standard "would you like to create an account?" form. $template->process("account/create.html.tmpl", $vars) || ThrowTemplateError($template->error());