2016-01-17 00:15:26 +08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @Author: printempw
|
|
|
|
* @Date: 2016-01-16 23:01:33
|
|
|
|
* @Last Modified by: prpr
|
2016-02-02 21:52:53 +08:00
|
|
|
* @Last Modified time: 2016-02-02 21:50:54
|
2016-01-17 00:15:26 +08:00
|
|
|
*
|
|
|
|
* All ajax requests will be handled here
|
|
|
|
*/
|
|
|
|
|
2016-01-17 10:53:10 +08:00
|
|
|
header('Access-Control-Allow-Origin: *');
|
2016-01-17 00:15:26 +08:00
|
|
|
session_start();
|
2016-02-02 21:52:53 +08:00
|
|
|
$dir = dirname(__FILE__);
|
|
|
|
require "$dir/includes/autoload.inc.php";
|
2016-01-17 00:15:26 +08:00
|
|
|
|
2016-02-02 21:52:53 +08:00
|
|
|
if (isset($_POST['uname'])) {
|
2016-01-17 15:15:56 +08:00
|
|
|
$user = new user($uname);
|
|
|
|
} else {
|
|
|
|
utils::raise('1', 'Empty username.');
|
|
|
|
}
|
2016-02-02 21:52:53 +08:00
|
|
|
$action = isset($_GET['action']) ? $_GET['action'] : "login";
|
2016-01-17 00:15:26 +08:00
|
|
|
$json = null;
|
|
|
|
|
|
|
|
if ($action == "login") {
|
2016-01-17 12:14:19 +08:00
|
|
|
if (checkInput()) {
|
2016-02-02 21:52:53 +08:00
|
|
|
if (!$user->is_registered) {
|
2016-01-17 00:15:26 +08:00
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "Non-existent user.";
|
|
|
|
} else {
|
2016-02-02 21:52:53 +08:00
|
|
|
if ($user->checkPasswd($_POST['passwd'])) {
|
2016-01-17 00:15:26 +08:00
|
|
|
$json['errno'] = 0;
|
|
|
|
$json['msg'] = 'Logging in succeed!';
|
2016-02-02 21:52:53 +08:00
|
|
|
$json['token'] = $user->getToken();
|
|
|
|
$_SESSION['token'] = $user->getToken();
|
2016-01-17 00:15:26 +08:00
|
|
|
} else {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "Incorrect usename or password.";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-01-17 15:15:56 +08:00
|
|
|
} else if ($action == "register") {
|
2016-01-17 12:14:19 +08:00
|
|
|
if (checkInput()) {
|
2016-02-02 21:52:53 +08:00
|
|
|
if (!$user->is_registered) {
|
2016-01-17 10:53:10 +08:00
|
|
|
if (!empty($_SERVER['HTTP_CLIENT_IP'])) {
|
|
|
|
$ip = $_SERVER['HTTP_CLIENT_IP'];
|
|
|
|
} elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
|
|
|
|
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
|
|
|
|
} else {
|
|
|
|
$ip = $_SERVER['REMOTE_ADDR'];
|
|
|
|
}
|
2016-01-17 00:15:26 +08:00
|
|
|
|
2016-01-17 10:53:10 +08:00
|
|
|
if (!utils::select('ip', $ip)) {
|
|
|
|
// use once md5 to encrypt password
|
2016-02-02 21:52:53 +08:00
|
|
|
if ($user->register(md5($_POST['passwd']), $ip)) {
|
2016-01-17 10:53:10 +08:00
|
|
|
$json['errno'] = 0;
|
|
|
|
$json['msg'] = "Registered successfully.";
|
|
|
|
} else {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "Uncaught error.";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$json['errno'] = 1;
|
2016-01-21 18:21:21 +08:00
|
|
|
$json['msg'] = "It seems that you have already register an account with this IP address.";
|
2016-01-17 10:53:10 +08:00
|
|
|
}
|
2016-01-17 00:15:26 +08:00
|
|
|
|
2016-01-17 10:53:10 +08:00
|
|
|
} else {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "User already existed.";
|
|
|
|
}
|
|
|
|
}
|
2016-01-17 15:15:56 +08:00
|
|
|
} else if ($action == "upload") {
|
2016-02-02 21:52:53 +08:00
|
|
|
if ($_SESSION['token'] == $user->getToken()) {
|
2016-01-17 12:14:19 +08:00
|
|
|
if (checkFile()) {
|
2016-02-02 21:52:53 +08:00
|
|
|
if ($file = utils::getValue('skin_file', $_FILES)) {
|
|
|
|
if ($user->setTexture('skin', $file)) {
|
2016-01-17 10:53:10 +08:00
|
|
|
$json[0]['errno'] = 0;
|
|
|
|
$json[0]['msg'] = "Skin uploaded successfully.";
|
|
|
|
} else {
|
|
|
|
$json[0]['errno'] = 1;
|
|
|
|
$json[0]['msg'] = "Uncaught error.";
|
|
|
|
}
|
|
|
|
}
|
2016-02-02 21:52:53 +08:00
|
|
|
if ($file = utils::getValue('cape_file', $_FILES)) {
|
|
|
|
if ($user->setTexture('cape', $file)) {
|
2016-01-17 10:53:10 +08:00
|
|
|
$json[1]['errno'] = 0;
|
|
|
|
$json[1]['msg'] = "Cape uploaded successfully.";
|
|
|
|
} else {
|
|
|
|
$json[1]['errno'] = 1;
|
|
|
|
$json[1]['msg'] = "Uncaught error.";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "Invalid token.";
|
|
|
|
}
|
2016-01-17 15:15:56 +08:00
|
|
|
} else if ($action == "logout") {
|
2016-02-02 21:52:53 +08:00
|
|
|
if (utils::getValue('token', $_SESSION)) {
|
2016-01-17 15:15:56 +08:00
|
|
|
session_destroy();
|
|
|
|
$json['errno'] = 0;
|
|
|
|
$json['msg'] = 'Session destroyed.';
|
|
|
|
} else {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = 'No available session.';
|
|
|
|
}
|
2016-01-17 00:15:26 +08:00
|
|
|
}
|
|
|
|
|
2016-01-17 12:14:19 +08:00
|
|
|
function checkInput() {
|
|
|
|
global $json;
|
|
|
|
if (!$_POST['uname']) {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = 'Empty username!';
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (!$_POST['passwd']) {
|
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "Empty password!";
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkFile() {
|
|
|
|
global $json;
|
|
|
|
|
2016-02-02 21:52:53 +08:00
|
|
|
if (!(utils::getValue('skin_file', $_FILES) || utils::getValue('cape_file', $_FILES))) {
|
2016-01-17 12:14:19 +08:00
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = "No input file selected.";
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Check for skin_file
|
|
|
|
*/
|
2016-02-02 21:52:53 +08:00
|
|
|
if ((utils::getValue('skin_file', $_FILES)["type"] == "image/png") || (utils::getValue('skin_file', $_FILES)["type"] == "image/x-png")) {
|
2016-01-17 12:14:19 +08:00
|
|
|
// if error occured while uploading file
|
2016-02-02 21:52:53 +08:00
|
|
|
if (utils::getValue('skin_file', $_FILES)["error"] > 0) {
|
2016-01-17 12:20:09 +08:00
|
|
|
$json['errno'] = 1;
|
2016-02-02 21:52:53 +08:00
|
|
|
$json['msg'] = utils::getValue('skin_file', $_FILES)["error"];
|
2016-01-17 12:14:19 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} else {
|
2016-02-02 21:52:53 +08:00
|
|
|
if (utils::getValue('skin_file', $_FILES)) {
|
2016-01-17 15:15:56 +08:00
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = 'Skin file type error.';
|
|
|
|
return false;
|
2016-01-17 15:56:36 +08:00
|
|
|
} else {
|
|
|
|
$json[0]['errno'] = 0;
|
|
|
|
$json[0]['msg'] = 'No skin file selected.';
|
2016-01-17 15:15:56 +08:00
|
|
|
}
|
2016-01-17 12:14:19 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check for cape_file
|
|
|
|
*/
|
2016-02-02 21:52:53 +08:00
|
|
|
if ((utils::getValue('cape_file', $_FILES)["type"] == "image/png") || (utils::getValue('cape_file', $_FILES)["type"] == "image/x-png")) {
|
2016-01-17 12:14:19 +08:00
|
|
|
// if error occured while uploading file
|
2016-02-02 21:52:53 +08:00
|
|
|
if (utils::getValue('cape_file', $_FILES)["error"] > 0) {
|
2016-01-17 12:20:09 +08:00
|
|
|
$json['errno'] = 1;
|
2016-02-02 21:52:53 +08:00
|
|
|
$json['msg'] = utils::getValue('cape_file', $_FILES)["error"];
|
2016-01-17 12:14:19 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} else {
|
2016-02-02 21:52:53 +08:00
|
|
|
if (utils::getValue('cape_file', $_FILES)) {
|
2016-01-17 15:15:56 +08:00
|
|
|
$json['errno'] = 1;
|
|
|
|
$json['msg'] = 'Cape file type error.';
|
|
|
|
return false;
|
2016-01-17 15:56:36 +08:00
|
|
|
} else {
|
|
|
|
$json[1]['errno'] = 0;
|
|
|
|
$json[1]['msg'] = 'No cape file selected.';
|
2016-01-17 15:15:56 +08:00
|
|
|
}
|
2016-01-17 12:14:19 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-01-17 00:15:26 +08:00
|
|
|
echo json_encode($json);
|