diff options
-rw-r--r-- | Changelog.txt | 4 | ||||
-rw-r--r-- | src/map/clif.c | 57 |
2 files changed, 45 insertions, 16 deletions
diff --git a/Changelog.txt b/Changelog.txt index 42774b03e..bd0e191f9 100644 --- a/Changelog.txt +++ b/Changelog.txt @@ -1,5 +1,9 @@ Date Added 01/11 + * Updated clif.c to be able to identify client versions based on the packet DB + [celest] + * Correct packet_db_ver to the maximum version allowed if it was set too high + or too low in packet_db.txt [celest] * Added support for 2005-01-10Sakexe [celest] * Updated packet functions for 2004-11-08 and 2004-12-06 (Note: eA *can* support 12-06, but still doesn't recognise it... so unless we find a way, diff --git a/src/map/clif.c b/src/map/clif.c index bb91da6fa..e505b3f6c 100644 --- a/src/map/clif.c +++ b/src/map/clif.c @@ -52,9 +52,10 @@ #endif #define STATE_BLIND 0x10 -#define MAX_PACKET_DB 0x224 -int packet_db_ver = -1; +int packet_db_ver = -1; // the packet version used by packet_db +int packet_db_connect_cmd = 0xF5; // the default packet used for connecting to the server + int *packet_db_size; void (**packet_db_parse_func)(); short packet_db_pos[MAX_PACKET_DB][20]; @@ -7293,8 +7294,12 @@ void clif_parse_WantToConnection(int fd, struct map_session_data *sd) return; } + // packet DB + if (RFIFOW(fd,0) == packet_db_connect_cmd) { + //printf("Received bytes %d with packet 0x72.\n", RFIFOREST(fd)); + account_id = RFIFOL(fd,packet_db_pos[packet_db_connect_cmd][0]); // 0x72 - if (RFIFOW(fd,0) == 0x72) { + } else if (RFIFOW(fd,0) == 0x72) { //printf("Received bytes %d with packet 0x72.\n", RFIFOREST(fd)); if (RFIFOREST(fd) >= 39 && (RFIFOB(fd,38) == 0 || RFIFOB(fd,38) == 1)) // 00 = Female, 01 = Male account_id = RFIFOL(fd,12); @@ -7336,7 +7341,13 @@ void clif_parse_WantToConnection(int fd, struct map_session_data *sd) sd->fd = fd; // 0x72 - if (RFIFOW(fd,0) == 0x72) { + if (RFIFOW(fd,0) == packet_db_connect_cmd) { + sd->packet_ver = packet_db_ver; // 5: old, 6: 7july04, 7: 13july04, 8: 26july04, 9: 9aug04/16aug04/17aug04, 10: 6sept04, 11: 21sept04, 12: 18oct04, 13: 25oct04 (by [Yor]) + pc_setnewpc(sd, account_id, RFIFOL(fd,packet_db_pos[packet_db_connect_cmd][1]), + RFIFOL(fd,packet_db_pos[packet_db_connect_cmd][2]), + RFIFOL(fd,packet_db_pos[packet_db_connect_cmd][3]), + RFIFOL(fd,packet_db_pos[packet_db_connect_cmd][4]), fd); + } else if (RFIFOW(fd,0) == 0x72) { if (RFIFOREST(fd) >= 39 && (RFIFOB(fd,38) == 0 || RFIFOB(fd,38) == 1)) { // 00 = Female, 01 = Male sd->packet_ver = 7; // 5: old, 6: 7july04, 7: 13july04, 8: 26july04, 9: 9aug04/16aug04/17aug04, 10: 6sept04, 11: 21sept04, 12: 18oct04, 13: 25oct04 (by [Yor]) pc_setnewpc(sd, account_id, RFIFOL(fd,22), RFIFOL(fd,30), RFIFOL(fd,34), RFIFOB(fd,38), fd); @@ -10415,6 +10426,8 @@ static void (*clif_parse_func_table[10][MAX_PACKET_DB])() = { {NULL}, {NULL}, {NULL}, + {NULL}, + {NULL}, {NULL} }; @@ -10488,8 +10501,14 @@ static int clif_parse(int fd) { packet_ver = sd->packet_ver; // check authentification packet to know packet version else { + // packet DB + if (cmd == packet_db_connect_cmd) { + if (RFIFOREST(fd) >= packet_db_size[cmd] && + (RFIFOB(fd,packet_db_pos[cmd][4]) == 0 || RFIFOB(fd,packet_db_pos[cmd][4]) == 1)) {// 00 = Female, 01 = Male + packet_ver = packet_db_ver; + } // 0x72 - if (cmd == 0x72) { + } else if (cmd == 0x72) { if (RFIFOREST(fd) >= 39 && (RFIFOB(fd,38) == 0 || RFIFOB(fd,38) == 1)) // 00 = Female, 01 = Male packet_ver = 7; // 7: 13july04 else if (RFIFOREST(fd) >= 22 && (RFIFOB(fd,21) == 0 || RFIFOB(fd,21) == 1)) // 00 = Female, 01 = Male @@ -10533,19 +10552,13 @@ static int clif_parse(int fd) { } // check if version is accepted if (packet_ver <= 9 || // reject any client versions older than 6sept04 -/* if (packet_ver < 5 || - (packet_ver == 5 && (battle_config.packet_ver_flag & 1) == 0) || - (packet_ver == 6 && (battle_config.packet_ver_flag & 2) == 0) || - (packet_ver == 7 && (battle_config.packet_ver_flag & 4) == 0) || - (packet_ver == 8 && (battle_config.packet_ver_flag & 8) == 0) || - (packet_ver == 9 && (battle_config.packet_ver_flag & 16) == 0) ||*/ - (packet_ver == 10 && (battle_config.packet_ver_flag & 1) == 0) || - (packet_ver == 11 && (battle_config.packet_ver_flag & 2) == 0) || - (packet_ver == 12 && (battle_config.packet_ver_flag & 4) == 0) || - (packet_ver == 13 && (battle_config.packet_ver_flag & 8) == 0) || + (packet_ver == 10 && (battle_config.packet_ver_flag & 1) == 0) || + (packet_ver == 11 && (battle_config.packet_ver_flag & 2) == 0) || + (packet_ver == 12 && (battle_config.packet_ver_flag & 4) == 0) || + (packet_ver == 13 && (battle_config.packet_ver_flag & 8) == 0) || (packet_ver == 14 && (battle_config.packet_ver_flag & 16) == 0) || (packet_ver == 15 && (battle_config.packet_ver_flag & 32) == 0) || - (packet_ver == 16 && (battle_config.packet_ver_flag & 64) == 0) || + (packet_ver == 16 && (battle_config.packet_ver_flag & 64) == 0) || packet_ver > 16) { // no support yet WFIFOW(fd,0) = 0x6a; WFIFOB(fd,2) = 5; // 05 = Game's EXE is not the latest version @@ -10803,6 +10816,10 @@ static int packetdb_readdb(void) } } if (packet_db_ver > 7) { // minimum packet version allowed + // check if packet db version is higher than allowed + if (packet_db_ver > (j= 6 + sizeof(clif_parse_func_table)/sizeof(clif_parse_func_table[0]))) + packet_db_ver = j; + packet_db_size = packet_size_table[packet_db_ver - 5]; packet_db_parse_func = clif_parse_func_table[packet_db_ver - 7]; @@ -10840,6 +10857,10 @@ static int packetdb_readdb(void) break; } } + // set the identifying cmd for the packet_db version + if (strcmp(str[2],"wanttoconnection")==0){ + packet_db_connect_cmd = cmd; + } if(str[3]==NULL){ sprintf(tmp_output, "packet_db: packet error\n"); ShowError(tmp_output); @@ -10856,6 +10877,10 @@ static int packetdb_readdb(void) // if(packet_size_table[packet_db_ver - 5][cmd] > 2 /* && packet_db[cmd].pos[0] == 0 */) // printf("packet_db: %d 0x%x %d %s %p | %p\n",ln,cmd,packet_db_size[cmd],str[2],packet_db_parse_func[cmd],clif_parse_func_table[packet_db_ver - 7][cmd]); } + } else { // old packet version - just use predefined values + packet_db_size = packet_size_table[0]; + packet_db_parse_func = clif_parse_func_table[0]; + packet_db_connect_cmd = 0x72; } fclose(fp); sprintf(tmp_output,"Done reading '"CL_WHITE"%s"CL_RESET"'.\n","db/packet_db.txt"); |