###############################################################################
# Register.pl #
###############################################################################
# YaBB: Yet another Bulletin Board #
# Open-Source Community Software for Webmasters #
# Version: YaBB 1 Gold - SP 1.3 #
# Released: December 2001; Updated April 6, 2003 #
# Distributed by: http://www.yabbforum.com #
# =========================================================================== #
# Copyright (c) 2000-2003 YaBB (www.yabbforum.com) - All Rights Reserved. #
# Software by: The YaBB Development Team #
# with assistance from the YaBB community. #
# Sponsored by: Xnull Internet Media, Inc. - http://www.ximinc.com #
###############################################################################
$registerplver = "1 Gold - SP 1.3";
sub Register {
#start register_bugfix
if ($username ne 'Guest') { &fatal_error("$register_bugfix{'1'}"); }
#end register_bugfix
if( $regcheck ) {
&validation_code;
}
$yymain .= qq~
~;
$yytitle = "$txt{'97'}";
&template;
exit;
}
sub Register2 {
if($FORM{'regagree'} eq "no") {
$yySetLocation = qq~$scripturl~;
&redirectexit;
}
my %member;
while( ($key,$value) = each(%FORM) ) {
$value =~ s~\A\s+~~;
$value =~ s~\s+\Z~~;
$value =~ s~[\n\r]~~g;
$member{$key} = $value;
}
$member{'username'} =~ s/\s/_/g;
if (length($member{'username'}) > 25) { $member{'username'} = substr($member{'username'},0,25); }
&fatal_error("($member{'username'}) $txt{'37'}") if($member{'username'} eq '');
&fatal_error("($member{'username'}) $txt{'99'}") if($member{'username'} eq '_' || $member{'username'} eq '|');
&fatal_error("$txt{'244'} $member{'username'}") if($member{'username'} =~ /guest/i);
&fatal_error("$txt{'240'} $txt{'35'} $txt{'241'}") if($member{'username'} !~ /\A[0-9A-Za-z#%+-\.@^_]+\Z/);
&fatal_error("$txt{'240'}") if($member{'username'} =~ /,/);
&fatal_error("($member{'username'}) $txt{'76'}") if($member{'email'} eq "");
&fatal_error("($member{'username'}) $txt{'100'}") if(-e ("$memberdir/$member{'username'}.dat"));
if ($regcheck){
&fatal_error("$floodtxt{'4'}") if($member{'verification'} eq '');
&fatal_error("$txt{'240'} $floodtxt{'3'} $txt{'241'}") if($member{'verification'} !~ /\A[0-9A-Za-z]+\Z/);
## Trying to figure out the mess we made while encrypting verification ##
$lastvalue =13;
$verificationtest="";
for($n=0; $n < length "$member{'regdate'}"; $n++) {
$value = (substr ("$member{'regdate'}",$n,1))+$lastvalue+1;
$letter = substr ("$member{'_session_id_'}", $value, 1);
$lastvalue = $value;
$verificationtest .=qq~$letter~;
}
&fatal_error("$floodtxt{'4'}") if($verificationtest ne $member{'verification'});
}
if($req_location) {
&fatal_error("($member{'username'}) $maptxt{'24'}") if($member{'cityloc'} eq '');
&fatal_error("($member{'username'}) $maptxt{'25'}") if($member{'cityloc'} eq '_' || $member{'cityloc'} eq '|');
&fatal_error("$txt{'240'} $maptxt{'03'} $txt{'241'}") if($member{'cityloc'} !~ /\A[0-9A-Za-zæøåÆØÅäöÄÖ#%+-\.@^_ ]+\Z/);
&fatal_error("($member{'username'}) $maptxt{'26'}") if($member{'mapcountry'} eq '');
}
if ($send_welcomeim == 1) {
$messageid = $^T.$$;
$imtext =~ s/\&\&/\n/g;
$imtext =~ s/\<//g;
$imtext =~ s/</g;
$imtext =~ s/>/>/g;
$imtext =~ s/\t/ \ \ \ /g;
$imtext =~ s/\cM//g;
$imtext =~ s/\n/
/g;
$imtext =~ s/\|/\|/g;
fopen(FILE,">$memberdir/$member{'username'}.msg", 1);
print FILE "$sendname|$imsubject|$date|$imtext|$messageid|$ENV{'REMOTE_ADDR'}|1\n";
fclose(FILE);
}
if( $emailpassword ) {
srand();
$member{'passwrd1'} = int( rand(100) );
$member{'passwrd1'} =~ tr/0123456789/ymifxupbck/;
$_ = int( rand(77) );
$_ =~ tr/0123456789/q8dv7w4jm3/;
$member{'passwrd1'} .= $_;
$_ = int( rand(89) );
$_ =~ tr/0123456789/y6uivpkcxw/;
$member{'passwrd1'} .= $_;
$_ = int( rand(188) );
$_ =~ tr/0123456789/poiuytrewq/;
$member{'passwrd1'} .= $_;
$_ = int( rand(65) );
$_ =~ tr/0123456789/lkjhgfdaut/;
$member{'passwrd1'} .= $_;
} else {
&fatal_error("($member{'username'}) $txt{'213'}") if($member{'passwrd1'} ne $member{'passwrd2'});
&fatal_error("($member{'username'}) $txt{'91'}") if($member{'passwrd1'} eq '');
&fatal_error("$txt{'240'} $txt{'36'} $txt{'241'}") if($member{'passwrd1'} !~ /\A[\s0-9A-Za-z!@#$%\^&*\(\)_\+|`~\-=\\:;'",\.\/?\[\]\{\}]+\Z/);
}
&fatal_error("$txt{'240'} $txt{'69'} $txt{'241'}") if($member{'email'} !~ /[\w\-\.\+]+\@[\w\-\.\+]+\.(\w{2,4}$)/);
&fatal_error("$txt{'500'}") if(($member{'email'} =~ /(@.*@)|(\.\.)|(@\.)|(\.@)|(^\.)|(\.$)/) || ($member{'email'} !~ /\A.+@\[?(\w|[-.])+\.[a-zA-Z]{2,4}|[0-9]{1,4}\]?\Z/));
fopen(FILE, "$vardir/ban_email.txt");
@banned = ;
fclose(FILE);
foreach $curban (@banned) {
if(lc($member{'email'}) eq lc("$curban")) { &fatal_error("$txt{'678'}$txt{'430'}!"); }
}
if ($member{'email'}=~/\@(.+)$/) {
my (@tmp) = split(/\./,lc($1));
my $test = join('.',splice(@tmp,-2,2));
fopen(FILE, "$vardir/ban_domains.txt");
@banned = ;
fclose(FILE);
foreach $curban (@banned) {
chomp($curban);
if ($test eq $curban) { &fatal_error("$txt{'678'}$txt{'430a'}!"); }
}
}
fopen(FILE, "$memberdir/memberlist.txt");
@memberlist = ;
fclose(FILE);
$testname = lc $member{'username'};
$testemail = lc $member{'email'};
$doublecheck = &profilecheck($member{'username'},$testname,$testemail,"check");
if($doublecheck eq "email_exists"){&fatal_error("$txt{'730'} ($member{'email'}) $txt{'731'}");}
if($doublecheck eq "realname_exists"){&fatal_error("($member{'username'}) $txt{'473'}");}
&ToHTML($member{'email'});
fopen(FILE, "$vardir/reserve.txt") || &fatal_error("$txt{'23'} reserve.txt");
@reserve = ;
fclose(FILE);
fopen(FILE, "$vardir/reservecfg.txt") || &fatal_error("$txt{'23'} reservecfg.txt");
@reservecfg = ;
fclose(FILE);
for( $a = 0; $a < @reservecfg; $a++ ) {
chomp $reservecfg[$a];
}
$matchword = $reservecfg[0] eq 'checked';
$matchcase = $reservecfg[1] eq 'checked';
$matchuser = $reservecfg[2] eq 'checked';
$matchname = $reservecfg[3] eq 'checked';
$namecheck = $matchcase eq 'checked' ? $member{'username'} : lc $member{'username'};
foreach $reserved (@reserve) {
chomp $reserved;
$reservecheck = $matchcase ? $reserved : lc $reserved;
if ($matchuser) {
if ($matchword) {
if ($namecheck eq $reservecheck) { &fatal_error("$txt{'244'} $reserved"); }
}
else {
if ($namecheck =~ $reservecheck) { &fatal_error("$txt{'244'} $reserved"); }
}
}
}
&fatal_error("$txt{'100'})") if(-e ("$memberdir/$member{'username'}.dat"));
require "$sourcedir/ExtendedProfiles.pl";
my $error = &ext_validate_submition($member{'username'},$member{'username'});
if ($error ne "") { &fatal_error($error); } else { &ext_saveprofile($member{'username'}); }
fopen(FILE, ">$memberdir/$member{'username'}.dat");
print FILE "$member{'passwrd1'}\n";
print FILE "$member{'username'}\n";
print FILE "$member{'email'}\n";
if($req_location) {
$memblocal = $member{'cityloc'};
if($view_state) { $membstate = $member{'mapstate'} }
else { $membstate = "" }
$membcountry = $member{'mapcountry'};
$membcontinent = "";
$membx = 0;
$memby = 0;
$loccode = "x0";
$member{'location'} .= qq($loccode|$memblocal|$membcountry|$membcontinent|$membx|$memby|$membstate);
print FILE "\n\n\n0\n\n\n\n\n\n$txt{'209'}\nblank.gif\n$date\n";
print FILE "$member{'location'}\n\n\n\n";
}
else {
print FILE "\n\n\n0\n\n\n\n\n\n$txt{'209'}\nblank.gif\n$date\n\n\n\n\n";
}
if ($FORM{'hideemail'} ne "checked") { $FORM{'hideemail'} = ""; }
print FILE "$FORM{'hideemail'}\n";
print FILE "$FORM{'mmcheck'}\n";
fclose(FILE);
fopen(FILE, ">$memberdir/memberlist.txt", 1);
foreach $curmem (@memberlist) {
##################### correct error appearing 8-2-04
chomp $curmem;
#####################
print FILE "$curmem\n"; }
print FILE "$member{'username'}\n";
fclose(FILE);
## add to profile checklist ##
fopen(FILE, ">>$memberdir/profiles.txt", 1);
print FILE "$member{'username'}|$member{'username'}|$member{'email'}\n";
fclose(FILE);
my $membershiptotal = @memberlist + 1;
fopen(FILE, "+>$memberdir/members.ttl");
print FILE qq~$membershiptotal|$member{'username'}~;
fclose(FILE);
###### Start YaMS add-on Member-number ######
fopen(FILE, "$memberdir/membernumb.txt");
@membernumb = ;
$membernumber = @membernumb;
fclose(FILE);
fopen(FILE, ">$memberdir/membernumb.txt", 1);
foreach $curnum (@membernumb) {
chomp $curnum;
print FILE "$curnum\n";
}
print FILE "$membernumber|$member{'username'}\n";
fclose(FILE);
fopen(FILE, ">$memberdir/$member{'username'}.yam");
print FILE "$membernumber\n";
print FILE "0|0|0\n";
fclose(FILE);
chmod(0666,"$memberdir/$member{'username'}.yam");
###### End YaMS add-on Member-number ######
&FormatUserName($member{'username'});
###AssignDefaultMemberGroupsStart
###Assign default group if any exist
fopen(FILE, "$vardir/defmemgroups.txt");
$dmgroups = ;
fclose(FILE);
if($dmgroups) {
@defkrimodset = split( /, /, $dmgroups );
fopen(FILE, ">$memberdir/$member{'username'}.kri");
foreach $curgroup (@defkrimodset) {
chomp $curgroup;
print FILE "$curgroup\n";
}
fclose(FILE);
}
###AssignDefaultMemberGroupsEnd##########
# Advanced System eMails Mod
&advsendmail3(8,$webmaster_email,$member{'username'},"");
# End Advanced System eMails Mod
if($emailpassword) {
# Advanced System eMails Mod
&advsendmail3(3,$member{'email'},$member{'username'},$member{'passwrd1'});
# End Advanced System eMails Mod
$yymain .= qq~
~;
require "$sourcedir/LogInOut.pl";
$sharedLogin_title="$txt{'97'}";
$sharedLogin_text="$txt{'703'}";
&sharedLogin;
$yymain .= qq~
~;
}
else {
if($emailwelcome) {
# Advanced System eMails Mod
&advsendmail3(2,$member{'email'},$member{'username'},$member{'passwrd1'});
# End Advanced System eMails Mod
}
$yymain .= qq~
$txt{'97'} |
|
~;
}
if ($popup_on) { $y = "on"; }
open(FILE, ">$memberdir/$member{'username'}.imconfig");
print FILE "\n\n$sound\n$y";
close(FILE);
$yytitle="$txt{'245'}";
&template;
exit;
}
1;