Advertisement
Guest User

register.php

a guest
Jul 28th, 2015
258
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 13.88 KB | None | 0 0
  1. <?php
  2. require_once 'engine/init.php';
  3. logged_in_redirect();
  4. include 'layout/overall/header.php';
  5.  
  6. if (empty($_POST) === false) {
  7. // $_POST['']
  8. $required_fields = array('username', 'password', 'password_again', 'email', 'selected');
  9. foreach($_POST as $key=>$value) {
  10. if (empty($value) && in_array($key, $required_fields) === true) {
  11. $errors[] = 'You need to fill in all fields.';
  12. break 1;
  13. }
  14. }
  15.  
  16. // check errors (= user exist, pass long enough
  17. if (empty($errors) === true) {
  18. /* Token used for cross site scripting security */
  19. if (!Token::isValid($_POST['token'])) {
  20. $errors[] = 'Token is invalid.';
  21. }
  22.  
  23. if (user_exist($_POST['username']) === true) {
  24. $errors[] = 'Sorry, that username already exist.';
  25. }
  26.  
  27. // Don't allow "default admin names in config.php" access to register.
  28. $defaultAdmin = array(
  29. 'otland',
  30. 'otland1',
  31. );
  32.  
  33. $isNoob = in_array(strtolower($_POST['username']), $defaultAdmin) ? true : false;
  34. if ($isNoob) {
  35. $errors[] = 'Default admin accounts are not allowed to register.';
  36. }
  37. if (strtolower($_POST['username']) === true) {
  38. $errors[] = 'Sorry, that username already exist.';
  39. }
  40. if (preg_match("/^[a-zA-Z0-9]+$/", $_POST['username']) == false) {
  41. $errors[] = 'Your account name can only contain characters a-z, A-Z and 0-9.';
  42. }
  43. // name restriction
  44. $resname = explode(" ", $_POST['username']);
  45. foreach($resname as $res) {
  46. if(in_array(strtolower($res), $config['invalidNameTags'])) {
  47. $errors[] = 'Your username contains a restricted word.';
  48. }
  49. else if(strlen($res) == 1) {
  50. $errors[] = 'Too short words in your name.';
  51. }
  52. }
  53. // end name restriction
  54. if (strlen($_POST['password']) < 6) {
  55. $errors[] = 'Your password must be at least 6 characters.';
  56. }
  57. if (strlen($_POST['password']) > 33) {
  58. $errors[] = 'Your password must be less than 33 characters.';
  59. }
  60. if ($_POST['password'] !== $_POST['password_again']) {
  61. $errors[] = 'Your passwords do not match.';
  62. }
  63. if (filter_var($_POST['email'], FILTER_VALIDATE_EMAIL) === false) {
  64. $errors[] = 'A valid email address is required.';
  65. }
  66. if (user_email_exist($_POST['email']) === true) {
  67. $errors[] = 'That email address is already in use.';
  68. }
  69. if ($_POST['selected'] != 1) {
  70. $errors[] = 'You are only allowed to have an account if you accept the rules.';
  71. }
  72. if (validate_ip(getIP()) === false) {
  73. $errors[] = 'Failed to recognize your IP address. (Not a valid IPv4 address).';
  74. }
  75. }
  76. }
  77.  
  78. ?>
  79. <h1>Register Account</h1>
  80. <?php
  81. if (isset($_GET['success']) && empty($_GET['success'])) {
  82. echo 'Congratulations! Your account has been created. You may now login to create a character.';
  83. } else {
  84. if (empty($_POST) === false && empty($errors) === true) {
  85. if ($config['log_ip']) {
  86. znote_visitor_insert_detailed_data(1);
  87. }
  88. //Register
  89. $register_data = array(
  90. 'name' => $_POST['username'],
  91. 'password' => $_POST['password'],
  92. 'email' => $_POST['email'],
  93. 'flag' => $_POST['flag'],
  94. 'ip' => ip2long(getIP()),
  95. 'created' => time()
  96. );
  97.  
  98. user_create_account($register_data);
  99. header('Location: register.php?success');
  100. exit();
  101. //End register
  102.  
  103. } else if (empty($errors) === false){
  104. echo '<font color="red"><b>';
  105. echo output_errors($errors);
  106. echo '</b></font>';
  107. }
  108. ?>
  109. <form action="" method="post">
  110. <ul>
  111. <li>
  112. Account Name:<br>
  113. <input type="text" name="username">
  114. </li>
  115. <li>
  116. Password:<br>
  117. <input type="password" name="password">
  118. </li>
  119. <li>
  120. Password again:<br>
  121. <input type="password" name="password_again">
  122. </li>
  123. <li>
  124. Email:<br>
  125. <input type="text" name="email">
  126. </li>
  127. <li>
  128. Country:<br>
  129. <select name="flag">
  130. <option value="">(Please choose)</option><option value="af"> Afghanistan </option><option value="al"> Albania </option><option value="dz"> Algeria </option><option value="as"> American Samoa </option><option value="ad"> Andorra </option><option value="ao"> Angola </option><option value="ai"> Anguilla </option><option value="aq"> Antarctica </option><option value="ag"> Antigua and Barbuda </option><option value="ar"> Argentina </option>
  131. <option value="am"> Armenia </option><option value="aw"> Aruba </option><option value="au"> Australia </option><option value="at"> Austria </option><option value="az"> Azerbaijan </option><option value="bs"> Bahamas </option><option value="bh"> Bahrain </option><option value="bd"> Bangladesh </option><option value="bb"> Barbados </option><option value="by"> Belarus </option><option value="be"> Belgium </option><option value="bz"> Belize </option><option value="bj"> Benin </option><option value="bm"> Bermuda </option><option value="bt"> Bhutan </option><option value="bo"> Bolivia </option><option value="ba"> Bosnia and Herzegowina </option><option value="bw"> Botswana </option><option value="bv"> Bouvet Island </option><option value="br"> Brazil </option><option value="io"> British Indian Ocean Territory </option><option value="bn"> Brunei Darussalam </option><option value="bg"> Bulgaria </option><option value="bf"> Burkina Faso </option><option value="bi"> Burundi </option>
  132. <option value="kh"> Cambodia </option><option value="cm"> Cameroon </option><option value="ca"> Canada </option><option value="cv"> Cape Verde </option><option value="ky"> Cayman Islands </option><option value="cf"> Central African Republic </option><option value="td"> Chad </option><option value="cl"> Chile </option><option value="cn"> China </option><option value="cx"> Christmas Island </option><option value="cc"> Cocos Islands </option><option value="co"> Colombia </option><option value="km"> Comoros </option><option value="cd"> Congo </option><option value="cg"> Congo </option><option value="ck"> Cook Islands </option><option value="cr"> Costa Rica </option><option value="ci"> Cote DIvoire </option><option value="hr"> Croatia </option><option value="cu"> Cuba </option><option value="cy"> Cyprus </option><option value="cz"> Czech Republic </option><option value="dk"> Denmark </option><option value="dj"> Djibouti </option><option value="dm"> Dominica </option>
  133. <option value="do"> Dominican Republic </option><option value="tp"> East Timor </option><option value="ec"> Ecuador </option><option value="eg"> Egypt </option><option value="sv"> El Salvador </option><option value="gq"> Equatorial Guinea </option><option value="er"> Eritrea </option><option value="ee"> Estonia </option><option value="et"> Ethiopia </option><option value="fk"> Falkland Islands </option><option value="fo"> Faroe Islands </option><option value="fj"> Fiji </option><option value="fi"> Finland </option><option value="fr"> France </option><option value="gf"> French Guiana </option><option value="pf"> French Polynesia </option><option value="tf"> French Southern Territories </option><option value="ga"> Gabon </option><option value="gm"> Gambia </option><option value="ge"> Georgia </option><option value="de"> Germany </option><option value="gh"> Ghana </option><option value="gi"> Gibraltar </option><option value="gr"> Greece </option>
  134. <option value="gl"> Greenland </option><option value="gd"> Grenada </option><option value="gp"> Guadeloupe </option><option value="gu"> Guam </option><option value="gt"> Guatemala </option><option value="gn"> Guinea </option><option value="gw"> Guinea-Bissau </option><option value="gy"> Guyana </option><option value="ht"> Haiti </option><option value="hm"> Heard and Mc Donald Islands </option><option value="hn"> Honduras </option><option value="hk"> Hong Kong </option><option value="hu"> Hungary </option><option value="is"> Iceland </option><option value="in"> India </option><option value="id"> Indonesia </option><option value="ir"> Iran </option><option value="iq"> Iraq </option><option value="ie"> Ireland </option><option value="il"> Israel </option><option value="it"> Italy </option><option value="jm"> Jamaica </option><option value="jp"> Japan </option><option value="jo"> Jordan </option><option value="kz"> Kazakhstan </option><option value="ke"> Kenya </option>
  135. <option value="ki"> Kiribati </option><option value="kr"> Korea </option><option value="kp"> Korea </option><option value="kw"> Kuwait </option><option value="kg"> Kyrgyzstan </option><option value="la"> Lao Peoples Democratic Republic </option><option value="lv"> Latvia </option><option value="lb"> Lebanon </option><option value="ls"> Lesotho </option><option value="lr"> Liberia </option><option value="ly"> Libyan Arab Jamahiriya </option><option value="li"> Liechtenstein </option><option value="lt"> Lithuania </option><option value="lu"> Luxembourg </option><option value="mo"> Macau </option><option value="mk"> Macedonia </option><option value="mg"> Madagascar </option><option value="mw"> Malawi </option><option value="my"> Malaysia </option><option value="mv"> Maldives </option><option value="ml"> Mali </option><option value="mt"> Malta </option><option value="mh"> Marshall Islands </option><option value="mq"> Martinique </option>
  136. <option value="mr"> Mauritania </option><option value="mu"> Mauritius </option><option value="yt"> Mayotte </option><option value="mx"> Mexico </option><option value="fm"> Micronesia </option><option value="md"> Moldova </option><option value="mc"> Monaco </option><option value="mn"> Mongolia </option><option value="ms"> Montserrat </option><option value="ma"> Morocco </option><option value="mz"> Mozambique </option><option value="mm"> Myanmar </option><option value="na"> Namibia </option><option value="nr"> Nauru </option><option value="np"> Nepal </option><option value="nl"> Netherlands </option><option value="an"> Netherlands Antilles </option><option value="nc"> New Caledonia </option><option value="nz"> New Zealand </option><option value="ni"> Nicaragua </option><option value="ne"> Niger </option><option value="ng"> Nigeria </option><option value="nu"> Niue </option><option value="nf"> Norfolk Island </option><option value="mp"> Northern Mariana Islands </option>
  137. <option value="no"> Norway </option><option value="om"> Oman </option><option value="pk"> Pakistan </option><option value="pw"> Palau </option><option value="pa"> Panama </option><option value="pg"> Papua New Guinea </option><option value="py"> Paraguay </option><option value="pe"> Peru </option><option value="ph"> Philippines </option><option value="pn"> Pitcairn </option><option value="pl"> Poland </option><option value="pt"> Portugal </option><option value="pr"> Puerto Rico </option><option value="qa"> Qatar </option><option value="re"> Reunion </option><option value="ro"> Romania </option><option value="ru"> Russian Federation </option><option value="rw"> Rwanda </option><option value="kn"> Saint Kitts and Nevis </option><option value="lc"> Saint Lucia </option><option value="ws"> Samoa </option><option value="sm"> San Marino </option><option value="st"> Sao Tome and Principe </option><option value="sa"> Saudi Arabia </option><option value="sn"> Senegal </option>
  138. <option value="sc"> Seychelles </option><option value="sl"> Sierra Leone </option><option value="sg"> Singapore </option><option value="sk"> Slovakia </option><option value="si"> Slovenia </option><option value="sb"> Solomon Islands </option><option value="so"> Somalia </option><option value="za"> South Africa </option><option value="es"> Spain </option><option value="lk"> Sri Lanka </option><option value="sh"> St. Helena </option><option value="pm"> St. Pierre and Miquelon </option><option value="sd"> Sudan </option><option value="sr"> Suriname </option><option value="sj"> Svalbard and Jan Mayen Islands </option><option value="sz"> Swaziland </option><option value="se"> Sweden </option><option value="ch"> Switzerland </option><option value="sy"> Syrian Arab Republic </option><option value="tw"> Taiwan </option><option value="tj"> Tajikistan </option><option value="tz"> Tanzania </option>
  139. <option value="th"> Thailand </option><option value="tg"> Togo </option><option value="tk"> Tokelau </option><option value="to"> Tonga </option><option value="tt"> Trinidad and Tobago </option><option value="tn"> Tunisia </option><option value="tr"> Turkey </option><option value="tm"> Turkmenistan </option><option value="tc"> Turks and Caicos Islands </option><option value="tv"> Tuvalu </option><option value="ug"> Uganda </option><option value="ua"> Ukraine </option><option value="ae"> United Arab Emirates </option><option value="gb"> United Kingdom </option><option value="us"> United States </option><option value="uy"> Uruguay </option><option value="uz"> Uzbekistan </option><option value="vu"> Vanuatu </option><option value="va"> Vatican </option><option value="ve"> Venezuela </option><option value="vn"> Viet Nam </option><option value="vg"> Virgin Islands (British) </option><option value="vi"> Virgin Islands (US) </option>
  140. <option value="wf"> Wallis and Futuna Islands </option><option value="eh"> Western Sahara </option><option value="ye"> Yemen </option><option value="yu"> Yugoslavia </option><option value="zm"> Zambia </option><option value="zw"> Zimbabwe </option>
  141. </select>
  142. </li>
  143. <li>
  144. <h2>Server Rules</h2>
  145. <p>The golden rule: Have fun.</p>
  146. <p>If you get pwn3d, don't hate the game.</p>
  147. <p>No <a href='http://en.wikipedia.org/wiki/Cheating'>cheating</a> allowed.</p>
  148. <p>No <a href='http://en.wikipedia.org/wiki/Internet_bot'>botting</a> allowed.</p>
  149. <p>The staff can delete, ban, do whatever they want with your account and your <br>
  150. submitted information. (Including exposing and logging your IP).</p>
  151. <p></p>
  152. </li>
  153. <li>
  154. Do you agree to follow the server rules?<br>
  155. <select name="selected">
  156. <option value="0">Umh...</option>
  157. <option value="1">Yes.</option>
  158. <option value="2">No.</option>
  159. </select>
  160. </li>
  161. <?php
  162. /* Form file */
  163. Token::create();
  164. ?>
  165. <li>
  166. <input type="submit" value="Create Account">
  167. </li>
  168. </ul>
  169. </form>
  170. <?php
  171. }
  172. include 'layout/overall/footer.php';
  173. ?>
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement