Quantcast
Channel: SA-MP Forums
Viewing all articles
Browse latest Browse all 18226

How do I create a database for my gm

$
0
0
Hi, I downloaded the samp server from scratch to start making an RP this https://www.sa-mp.com/download.php on your page and I downloaded the mysql install the mysql R41-4 now I want to know how I do my database to upload it to the localhost of my xampp

GM / FS: - https://www.sa-mp.com/download.php the SA-MP 0.3.7-R2 Windows Server
Notes: - + 1
this is all my gm
Quote:

#include <a_samp>
#include <core>
#include <a_mysql>
#include <float>

main()
{
print("---------- ---------- ---------- ---------- ---------- ----------\n");
print(" *- La lista del servidor XXXXX ha sido cargada, creado por xxx\n");
print("---------- ---------- ---------- ---------- ---------- ----------\n");
}

#define MYSQL_HOST "localhost"
#define MYSQL_USER "root"
#define MYSQL_PASSWORD ""
#define MYSQL_DATABASE "database"

/* Define */
#define SEGUNDOS_PARA_INICIARSESIÓN 30

/* Donde aparece cuando te registras */
#define DEFAULT_POS_X 1958.3783
#define DEFAULT_POS_Y 1343.1572
#define DEFAULT_POS_Z 15.3746
#define DEFAULT_POS_A 270.1425

/* La conexión MySQL */
new MySQL: g_SQL;

/* Datos del jugador */
enum jInfo
{
ID,
Name[MAX_PLAYER_NAME],
Password[65], // la salida de la función SHA256_PassHash (que se agregó en la versión 0.3.7 R1) siempre tiene 256 bytes de longitud, o el equivalente de 64 celdas de peón
Salt[17],
Kills,
Deaths,
Float: X_Pos,
Float: Y_Pos,
Float: Z_Pos,
Float: A_Pos,
Interior,

Cache: Cache_ID,
bool: IsLoggedIn,
LoginAttempts,
LoginTimer
};
new Jugador[MAX_PLAYERS][jInfo];

new g_MysqlRaceCheck[MAX_PLAYERS];

/* Datos de diálogo */
enum
{
DIALOG_UNUSED,

DIALOG_LOGIN,
DIALOG_REGISTER
};

public OnGameModeInit()
{
new MySQLOpt: option_id = mysql_init_options();

mysql_set_option(option_id, AUTO_RECONNECT, true); // se vuelve a conectar automáticamente al perder la conexión al servidor mysql

g_SQL = mysql_connect(MYSQL_HOST, MYSQL_USER, MYSQL_PASSWORD, MYSQL_DATABASE, option_id); // AUTO_RECONNECT está habilitado solo para este mango de conexión
if (g_SQL == MYSQL_INVALID_HANDLE || mysql_errno(g_SQL) != 0)
{
print("La conexión de MySQL falló. El servidor se está apagando.");
SendRconCommand("salir"); // cierra el servidor si no hay conexión
return 1;
}

print("La conexión de MySQL es exitosa.");
return 1;
}

public OnGameModeExit()
{
// guardar todos los datos del jugador antes de cerrar la conexión
for (new i = 0, j = GetPlayerPoolSize(); i <= j; i++) // Se agregó la función GetPlayerPoolSize en la versión 0.3.7 y obtiene el playerid más alto actualmente en uso en el servidor
{
if (IsPlayerConnected(i))
{
// razón se establece en 1 para 'Salir' normal
OnPlayerDisconnect(i, 1);
}
}

mysql_close(g_SQL);
return 1;
}

public OnPlayerConnect(playerid)
{
g_MysqlRaceCheck[playerid]++;

// restablecer los datos del jugador
static const empty_player[jInfo];
Jugador[playerid] = empty_player;

GetPlayerName(playerid, Jugador[playerid][Name], MAX_PLAYER_NAME);

// enviar una consulta para recibir todos los datos almacenados del jugador de la tabla
new query[103];
mysql_format(g_SQL, query, sizeof query, "SELECT * FROM `players` WHERE `username` = '%e' LIMIT 1", Jugador[playerid][Name]);
mysql_tquery(g_SQL, query, "OnPlayerDataLoaded", "dd", playerid, g_MysqlRaceCheck[playerid]);
return 1;
}

public OnPlayerDisconnect(playerid, reason)
{
g_MysqlRaceCheck[playerid]++;

UpdatePlayerData(playerid, reason);

// si el jugador fue expulsado (contraseña incorrecta o tardando demasiado) durante la parte de inicio de sesión, elimine los datos de la memoria
if (cache_is_valid(Jugador[playerid][Cache_ID]))
{
cache_delete(Jugador[playerid][Cache_ID]);
Jugador[playerid][Cache_ID] = MYSQL_INVALID_CACHE;
}

// si el jugador fue pateado antes de que el tiempo expire (30 segundos), mata el temporizador
if (Jugador[playerid][LoginTimer])
{
KillTimer(Jugador[playerid][LoginTimer]);
Jugador[playerid][LoginTimer] = 0;
}

// establece "IsLoggedIn" en falso cuando el reproductor se desconecta, evita guardar los datos del reproductor dos veces cuando se usa "gmx"
Jugador[playerid][IsLoggedIn] = false;
return 1;
}

public OnPlayerSpawn(playerid)
{
// generar el jugador en su última posición guardada
SetPlayerInterior(playerid, Jugador[playerid][Interior]);
SetPlayerPos(playerid, Jugador[playerid][X_Pos], Jugador[playerid][Y_Pos], Jugador[playerid][Z_Pos]);
SetPlayerFacingAngle(playerid, Jugador[playerid][A_Pos]);

SetCameraBehindPlayer(playerid);
return 1;
}

public OnPlayerDeath(playerid, killerid, reason)
{
UpdatePlayerDeaths(playerid);
UpdatePlayerKills(killerid);
return 1;
}

public OnDialogResponse(playerid, dialogid, response, listitem, inputtext[])
{
switch (dialogid)
{
case DIALOG_UNUSED: return 1; // Útil para diálogos que contienen solo información y no hacemos nada dependiendo de si respondieron o no

case DIALOG_LOGIN:
{
if (!response) return Kick(playerid);

new hashed_pass[65];
SHA256_PassHash(inputtext, Jugador[playerid][Salt], hashed_pass, 65);

if (strcmp(hashed_pass, Jugador[playerid][Password]) == 0)
{

// contraseña correcta, genera el jugador
ShowPlayerDialog(playerid, DIALOG_UNUSED, DIALOG_STYLE_MSGBOX, "Login", "You have been successfully logged in.", "Okay", "");

// establece el caché especificado como el caché activo para que podamos recuperar el resto de los datos del jugador
cache_set_active(Jugador[playerid][Cache_ID]);

AssignPlayerData(playerid);

// elimina la memoria caché activa de la memoria y también desactiva la memoria caché activa
cache_delete(Jugador[playerid][Cache_ID]);
Jugador[playerid][Cache_ID] = MYSQL_INVALID_CACHE;

KillTimer(Jugador[playerid][LoginTimer]);
Jugador[playerid][LoginTimer] = 0;
Jugador[playerid][IsLoggedIn] = true;

// generar el jugador en su última posición guardada después de iniciar sesión
SetSpawnInfo(playerid, NO_TEAM, 0, Jugador[playerid][X_Pos], Jugador[playerid][Y_Pos], Jugador[playerid][Z_Pos], Jugador[playerid][A_Pos], 0, 0, 0, 0, 0, 0);
SpawnPlayer(playerid);
}
else
{
Jugador[playerid][LoginAttempts]++;

if (Jugador[playerid][LoginAttempts] >= 3)
{
ShowPlayerDialog(playerid, DIALOG_UNUSED, DIALOG_STYLE_MSGBOX, "Login", "You have mistyped your password too often (3 times).", "Okay", "");
DelayedKick(playerid);
}
else ShowPlayerDialog(playerid, DIALOG_LOGIN, DIALOG_STYLE_PASSWORD, "Login", "Wrong password!\nPlease enter your password in the field below:", "Login", "Abort");
}
}
case DIALOG_REGISTER:
{
if (!response) return Kick(playerid);

if (strlen(inputtext) <= 5) return ShowPlayerDialog(playerid, DIALOG_REGISTER, DIALOG_STYLE_PASSWORD, "Registration", "Your password must be longer than 5 characters!\nPlease enter your password in the field below:", "Register", "Abort");

// 16 caracteres aleatorios de 33 a 126 (en ASCII) para la sal
for (new i = 0; i < 16; i++) Jugador[playerid][Salt][i] = random(94) + 33;
SHA256_PassHash(inputtext, Jugador[playerid][Salt], Jugador[playerid][Password], 65);

new query[221];
mysql_format(g_SQL, query, sizeof query, "INSERT INTO `players` (`username`, `password`, `salt`) VALUES ('%e', '%s', '%e')", Jugador[playerid][Name], Jugador[playerid][Password], Jugador[playerid][Salt]);
mysql_tquery(g_SQL, query, "OnPlayerRegister", "d", playerid);
}

default: return 0; // ID de diálogo no se encontró, busca en otras secuencias de comandos
}
return 1;
}

//-----------------------------------------------------

forward OnPlayerDataLoaded(playerid, race_check);
public OnPlayerDataLoaded(playerid, race_check)
{
/* verificación de condición de carrera:
el jugador A se conecta -> se activa la consulta SELECT -> esta consulta lleva mucho tiempo
mientras la consulta aún se está procesando, el jugador A con el playerid 2 se desconecta
el jugador B se une ahora con playerid 2 -> nuestra consulta laggy SELECT finalmente ha terminado, pero para el jugador equivocado

¿Qué hacemos contra eso?
creamos un conteo de conexiones para cada jugador y lo aumentamos cada vez que el playerid se conecta o desconecta
también pasamos el valor actual del recuento de conexiones a nuestra devolución de llamada OnPlayerDataLoaded
luego verificamos si el recuento de la conexión actual es el mismo que el conteo de la conexión que pasamos a la devolución de llamada
si es así, todo está bien, si no, simplemente pateamos al jugador
*/
if (race_check != g_MysqlRaceCheck[playerid]) return Kick(playerid);

new string[115];
if(cache_num_rows() > 0)
{
// almacenamos la contraseña y la sal para poder comparar la contraseña de las entradas del jugador
// y guarda el resto para no tener que ejecutar otra consulta más tarde
cache_get_value(0, "password", Jugador[playerid][Password], 65);
cache_get_value(0, "salt", Jugador[playerid][Salt], 17);

// guarda el caché activo en la memoria y devuelve un identificador de caché para acceder a él para usarlo más tarde
Jugador[playerid][Cache_ID] = cache_save();

format(string, sizeof string, "This account (%s) is registered. Please login by entering your password in the field below:", Jugador[playerid][Name]);
ShowPlayerDialog(playerid, DIALOG_LOGIN, DIALOG_STYLE_PASSWORD, "Login", string, "Login", "Abort");

// a partir de ahora, el jugador tiene 30 segundos para iniciar sesión
Jugador[playerid][LoginTimer] = SetTimerEx("OnLoginTimeout", SEGUNDOS_PARA_INICIARSESIÓN * 1000, false, "d", playerid);
}
else
{
format(string, sizeof string, "Welcome %s, you can register by entering your password in the field below:", Jugador[playerid][Name]);
ShowPlayerDialog(playerid, DIALOG_REGISTER, DIALOG_STYLE_PASSWORD, "Registration", string, "Register", "Abort");
}
return 1;
}

forward OnLoginTimeout(playerid);
public OnLoginTimeout(playerid)
{
// restablecer la variable que almacena el timerid
Jugador[playerid][LoginTimer] = 0;

ShowPlayerDialog(playerid, DIALOG_UNUSED, DIALOG_STYLE_MSGBOX, "Login", "You have been kicked for taking too long to login successfully to your account.", "Okay", "");
DelayedKick(playerid);
return 1;
}

forward OnPlayerRegister(playerid);
public OnPlayerRegister(playerid)
{
// recupera la ID generada para una columna AUTO_INCREMENT por la consulta enviada
Jugador[playerid][ID] = cache_insert_id();

ShowPlayerDialog(playerid, DIALOG_UNUSED, DIALOG_STYLE_MSGBOX, "Registration", "Account successfully registered, you have been automatically logged in.", "Okay", "");

Jugador[playerid][IsLoggedIn] = true;

Jugador[playerid][X_Pos] = DEFAULT_POS_X;
Jugador[playerid][Y_Pos] = DEFAULT_POS_Y;
Jugador[playerid][Z_Pos] = DEFAULT_POS_Z;
Jugador[playerid][A_Pos] = DEFAULT_POS_A;

SetSpawnInfo(playerid, NO_TEAM, 0, Jugador[playerid][X_Pos], Jugador[playerid][Y_Pos], Jugador[playerid][Z_Pos], Jugador[playerid][A_Pos], 0, 0, 0, 0, 0, 0);
SpawnPlayer(playerid);
return 1;
}

forward _KickPlayerDelayed(playerid);
public _KickPlayerDelayed(playerid)
{
Kick(playerid);
return 1;
}


//-----------------------------------------------------

AssignPlayerData(playerid)
{
cache_get_value_int(0, "id", Jugador[playerid][ID]);

cache_get_value_int(0, "kills", Jugador[playerid][Kills]);
cache_get_value_int(0, "deaths", Jugador[playerid][Deaths]);

cache_get_value_float(0, "x", Jugador[playerid][X_Pos]);
cache_get_value_float(0, "y", Jugador[playerid][Y_Pos]);
cache_get_value_float(0, "z", Jugador[playerid][Z_Pos]);
cache_get_value_float(0, "angle", Jugador[playerid][A_Pos]);
cache_get_value_int(0, "interior", Jugador[playerid][Interior]);
return 1;
}

DelayedKick(playerid, time = 500)
{
SetTimerEx("_KickPlayerDelayed", time, false, "d", playerid);
return 1;
}

SetupPlayerTable()
{
mysql_tquery(g_SQL, "CREATE TABLE IF NOT EXISTS `players` (`id` int(11) NOT NULL AUTO_INCREMENT,`username` varchar(24) NOT NULL,`password` char(64) NOT NULL,`salt` char(16) NOT NULL,`kills` mediumint(8) NOT NULL DEFAULT '0',`deaths` mediumint(8) NOT NULL DEFAULT '0',`x` float NOT NULL DEFAULT '0',`y` float NOT NULL DEFAULT '0',`z` float NOT NULL DEFAULT '0',`angle` float NOT NULL DEFAULT '0',`interior` tinyint(3) NOT NULL DEFAULT '0', PRIMARY KEY (`id`), UNIQUE KEY `username` (`username`))");
return 1;
}

UpdatePlayerData(playerid, reason)
{
if (Jugador[playerid][IsLoggedIn] == false) return 0;

// si el cliente se bloqueó, no es posible obtener la posición del jugador en OnPlayerDisconnect callback
// entonces usaremos la última posición guardada (en el caso de un jugador que se registró y se estrelló / pateó, la posición será el punto de generación predeterminado)
if (reason == 1)
{
GetPlayerPos(playerid, Jugador[playerid][X_Pos], Jugador[playerid][Y_Pos], Jugador[playerid][Z_Pos]);
GetPlayerFacingAngle(playerid, Jugador[playerid][A_Pos]);
}

new query[145];
mysql_format(g_SQL, query, sizeof query, "UPDATE `players` SET `x` = %f, `y` = %f, `z` = %f, `angle` = %f, `interior` = %d WHERE `id` = %d LIMIT 1", Jugador[playerid][X_Pos], Jugador[playerid][Y_Pos], Jugador[playerid][Z_Pos], Jugador[playerid][A_Pos], GetPlayerInterior(playerid), Jugador[playerid][ID]);
mysql_tquery(g_SQL, query);
return 1;
}

UpdatePlayerDeaths(playerid)
{
if (Jugador[playerid][IsLoggedIn] == false) return 0;

Jugador[playerid][Deaths]++;

new query[70];
mysql_format(g_SQL, query, sizeof query, "UPDATE `players` SET `deaths` = %d WHERE `id` = %d LIMIT 1", Jugador[playerid][Deaths], Jugador[playerid][ID]);
mysql_tquery(g_SQL, query);
return 1;
}

UpdatePlayerKills(killerid)
{
// debemos verificar antes si el asesino no era un jugador válido (conectado) para evitar el error de tiempo de ejecución 4
if (killerid == INVALID_PLAYER_ID) return 0;
if (Jugador[killerid][IsLoggedIn] == false) return 0;

Jugador[killerid][Kills]++;

new query[70];
mysql_format(g_SQL, query, sizeof query, "UPDATE `players` SET `kills` = %d WHERE `id` = %d LIMIT 1", Jugador[killerid][Kills], Jugador[killerid][ID]);
mysql_tquery(g_SQL, query);
return 1;
}

Viewing all articles
Browse latest Browse all 18226

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>