Advertisement
Guest User

Untitled

a guest
May 2nd, 2017
490
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 16.53 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 ($config['use_captcha']) {
  24. $captcha = (isset($_POST['g-recaptcha-response'])) ? $_POST['g-recaptcha-response'] : false;
  25. if(!$captcha) {
  26. $errors[] = 'Please check the the captcha form.';
  27. } else {
  28. $secretKey = $config['captcha_secret_key'];
  29. $ip = $_SERVER['REMOTE_ADDR'];
  30. // curl start
  31. $curl_connection = curl_init("https://www.google.com/recaptcha/api/siteverify");
  32. $post_string = "secret=".$secretKey."&response=".$captcha."&remoteip=".$ip;
  33. curl_setopt($curl_connection, CURLOPT_CONNECTTIMEOUT, 5);
  34. curl_setopt($curl_connection, CURLOPT_RETURNTRANSFER, true);
  35. curl_setopt($curl_connection, CURLOPT_SSL_VERIFYPEER, false);
  36. curl_setopt($curl_connection, CURLOPT_FOLLOWLOCATION, 0);
  37. curl_setopt($curl_connection, CURLOPT_POSTFIELDS, $post_string);
  38. $response = curl_exec($curl_connection);
  39. curl_close($curl_connection);
  40. // Curl end
  41. $responseKeys = json_decode($response,true);
  42. if(intval($responseKeys["success"]) !== 1) {
  43. $errors[] = 'Captcha failed.';
  44. }
  45. }
  46. }
  47.  
  48. if (user_exist($_POST['username']) === true) {
  49. $errors[] = 'Sorry, that username already exist.';
  50. }
  51.  
  52. // Don't allow "default admin names in config.php" access to register.
  53. $isNoob = in_array(strtolower($_POST['username']), $config['page_admin_access']) ? true : false;
  54. if ($isNoob) {
  55. $errors[] = 'This account name is blocked for registration.';
  56. }
  57. if (preg_match("/^[a-zA-Z0-9]+$/", $_POST['username']) == false) {
  58. $errors[] = 'Your account name can only contain characters a-z, A-Z and 0-9.';
  59. }
  60. // name restriction
  61. $resname = explode(" ", $_POST['username']);
  62. foreach($resname as $res) {
  63. if(in_array(strtolower($res), $config['invalidNameTags'])) {
  64. $errors[] = 'Your username contains a restricted word.';
  65. }
  66. else if(strlen($res) == 1) {
  67. $errors[] = 'Too short words in your name.';
  68. }
  69. }
  70. if (strlen($_POST['username']) > 32) {
  71. $errors[] = 'Your account name must be less than 33 characters.';
  72. }
  73. // end name restriction
  74. if (strlen($_POST['password']) < 6) {
  75. $errors[] = 'Your password must be at least 6 characters.';
  76. }
  77. if (strlen($_POST['password']) > 100) {
  78. $errors[] = 'Your password must be less than 100 characters.';
  79. }
  80. if ($_POST['password'] !== $_POST['password_again']) {
  81. $errors[] = 'Your passwords do not match.';
  82. }
  83. if (filter_var($_POST['email'], FILTER_VALIDATE_EMAIL) === false) {
  84. $errors[] = 'A valid email address is required.';
  85. }
  86. if (user_email_exist($_POST['email']) === true) {
  87. $errors[] = 'That email address is already in use.';
  88. }
  89. if ($_POST['selected'] != 1) {
  90. $errors[] = 'You are only allowed to have an account if you accept the rules.';
  91. }
  92. if (validate_ip(getIP()) === false && $config['validate_IP'] === true) {
  93. $errors[] = 'Failed to recognize your IP address. (Not a valid IPv4 address).';
  94. }
  95. if (strlen($_POST['flag']) < 1) {
  96. $errors[] = 'Please choose country.';
  97. }
  98. }
  99. }
  100.  
  101. ?>
  102. <h1>Register Account</h1>
  103. <?php
  104. if (isset($_GET['success']) && empty($_GET['success'])) {
  105. if ($config['mailserver']['register']) {
  106. ?>
  107. <h1>Email authentication required</h1>
  108. <p>We have sent you an email with an activation link to your submitted email address.</p>
  109. <p>If you can't find the email within 5 minutes, check your <strong>junk/trash inbox (spam filter)</strong> as it may be mislocated there.</p>
  110. <?php
  111. } else echo 'Congratulations! Your account has been created. You may now login to create a character.';
  112. } elseif (isset($_GET['authenticate']) && empty($_GET['authenticate'])) {
  113. // Authenticate user, fetch user id and activation key
  114. $auid = (isset($_GET['u']) && (int)$_GET['u'] > 0) ? (int)$_GET['u'] : false;
  115. $akey = (isset($_GET['k']) && (int)$_GET['k'] > 0) ? (int)$_GET['k'] : false;
  116. // Find a match
  117. $user = mysql_select_single("SELECT `id`, `active` FROM `znote_accounts` WHERE `account_id`='$auid' AND `activekey`='$akey' LIMIT 1;");
  118. if ($user !== false) {
  119. $user = $user['id'];
  120. $active = $user['active'];
  121. // Enable the account to login
  122. if ($active == 0) {
  123. mysql_update("UPDATE `znote_accounts` SET `active`='1' WHERE `id`='$user' LIMIT 1;");
  124. }
  125. echo '<h1>Congratulations!</h1> <p>Your account has been created. You may now login to create a character.</p>';
  126. } else {
  127. echo '<h1>Authentication failed</h1> <p>Either the activation link is wrong, or your account is already activated.</p>';
  128. }
  129. } else {
  130. if (empty($_POST) === false && empty($errors) === true) {
  131. if ($config['log_ip']) {
  132. znote_visitor_insert_detailed_data(1);
  133. }
  134.  
  135. //Register
  136. $register_data = array(
  137. 'id' => $_POST['username'],
  138. 'password' => $_POST['password'],
  139. 'email' => $_POST['email'],
  140. 'created' => time(),
  141. 'ip' => getIPLong(),
  142. 'flag' => $_POST['flag']
  143. );
  144.  
  145. user_create_account($register_data, $config['mailserver']);
  146. if (!$config['mailserver']['debug']) header('Location: register.php?success');
  147. exit();
  148. //End register
  149.  
  150. } else if (empty($errors) === false){
  151. echo '<font color="red"><b>';
  152. echo output_errors($errors);
  153. echo '</b></font>';
  154. }
  155. ?>
  156. <form action="" method="post">
  157. <ul>
  158. <li>
  159. Account Name:<br>
  160. <input type="text" name="username">
  161. </li>
  162. <li>
  163. Password:<br>
  164. <input type="password" name="password">
  165. </li>
  166. <li>
  167. Password again:<br>
  168. <input type="password" name="password_again">
  169. </li>
  170. <li>
  171. Email:<br>
  172. <input type="text" name="email">
  173. </li>
  174. <li>
  175. Country:<br>
  176. <select name="flag">
  177. <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>
  178. <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>
  179. <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>
  180. <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>
  181. <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>
  182. <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>
  183. <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>
  184. <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>
  185. <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>
  186. <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>
  187. <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>
  188. </select>
  189. </li>
  190. <?php
  191. if ($config['use_captcha']) {
  192. ?>
  193. <li>
  194. <div class="g-recaptcha" data-sitekey="<?php echo $config['captcha_site_key']; ?>"></div>
  195. </li>
  196. <?php
  197. }
  198. ?>
  199. <li>
  200. <h2>Server Rules</h2>
  201. <p>The golden rule: Have fun.</p>
  202. <p>If you get pwn3d, don't hate the game.</p>
  203. <p>No <a href='http://en.wikipedia.org/wiki/Cheating_in_video_games' target="_blank">cheating</a> allowed.</p>
  204. <p>No <a href='http://en.wikipedia.org/wiki/Video_game_bot' target="_blank">botting</a> allowed.</p>
  205. <p>The staff can delete, ban, do whatever they want with your account and your <br>
  206. submitted information. (Including exposing and logging your IP).</p>
  207. </li>
  208. <li>
  209. Do you agree to follow the server rules?<br>
  210. <select name="selected">
  211. <option value="0">Umh...</option>
  212. <option value="1">Yes.</option>
  213. <option value="2">No.</option>
  214. </select>
  215. </li>
  216. <?php
  217. /* Form file */
  218. Token::create();
  219. ?>
  220. <li>
  221. <input type="submit" value="Create Account">
  222. </li>
  223. </ul>
  224. </form>
  225. <?php
  226. }
  227. include 'layout/overall/footer.php';
  228. ?>
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement