status response
This commit is contained in:
parent
209c3e8bdb
commit
4ee7f7a1e9
34
main.c
34
main.c
|
@ -3,6 +3,7 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <time.h>
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
|
|
||||||
#define PORT 6969
|
#define PORT 6969
|
||||||
|
@ -145,9 +146,22 @@ void write_String(int client_fd, const char* str, int len)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void write_Long(int client_fd, int64_t value)
|
||||||
|
{
|
||||||
|
(void) client_fd;
|
||||||
|
request[req_current_byte] = value;
|
||||||
|
req_current_byte += 8;
|
||||||
|
}
|
||||||
|
|
||||||
void send_request(int client_fd)
|
void send_request(int client_fd)
|
||||||
{
|
{
|
||||||
write(client_fd, request, req_current_byte);
|
write(client_fd, request, req_current_byte);
|
||||||
|
|
||||||
|
printf("[INFO] %d byte request sent: ", req_current_byte);
|
||||||
|
print_hex((const char*) request, req_current_byte > 10 ? 10 : req_current_byte);
|
||||||
|
printf("...\n");
|
||||||
|
|
||||||
|
req_current_byte = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
File read_entire_file(const char *filename)
|
File read_entire_file(const char *filename)
|
||||||
|
@ -155,7 +169,7 @@ File read_entire_file(const char *filename)
|
||||||
FILE *f = fopen(filename, "r");
|
FILE *f = fopen(filename, "r");
|
||||||
fseek(f, 0, SEEK_END);
|
fseek(f, 0, SEEK_END);
|
||||||
long fsize = ftell(f);
|
long fsize = ftell(f);
|
||||||
fseek(f, 0, SEEK_SET); /* same as rewind(f); */
|
fseek(f, 0, SEEK_SET);
|
||||||
|
|
||||||
char *string = malloc(fsize);
|
char *string = malloc(fsize);
|
||||||
fread(string, fsize, 1, f);
|
fread(string, fsize, 1, f);
|
||||||
|
@ -246,12 +260,24 @@ int main()
|
||||||
write_String(client_fd, status_rep.data, status_rep.len);
|
write_String(client_fd, status_rep.data, status_rep.len);
|
||||||
|
|
||||||
send_request(client_fd);
|
send_request(client_fd);
|
||||||
printf("[INFO] %d byte request sent: ", req_current_byte);
|
|
||||||
print_hex((const char*) request, 10);
|
|
||||||
printf("...\n");
|
|
||||||
|
|
||||||
file_free(status_rep);
|
file_free(status_rep);
|
||||||
|
|
||||||
|
int request_status_len = read_VarInt(client_fd);
|
||||||
|
int request_status_id = read_VarInt(client_fd);
|
||||||
|
printf("[MCPACKET %d] packet length: %d\n", request_status_id, request_status_len);
|
||||||
|
if (request_status_id != 0 || request_status_len != 1) {
|
||||||
|
printf("[ERR] client not in the status state\n");
|
||||||
|
close_connection(client_fd);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
write_VarInt(client_fd, 1 /*packet id*/ + 8 /*Long len*/);
|
||||||
|
write_VarInt(client_fd, 1); // protocol id
|
||||||
|
write_Long(client_fd, (long)time(NULL));
|
||||||
|
|
||||||
|
send_request(client_fd);
|
||||||
|
|
||||||
close_connection(client_fd);
|
close_connection(client_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
"online": 1,
|
"online": 1,
|
||||||
"sample": [
|
"sample": [
|
||||||
{
|
{
|
||||||
"name": "caca player 69 ?",
|
"name": "Le caca est cuit ?",
|
||||||
"id": "83e2e372-1df3-485d-a360-d9c4caf8b8c4"
|
"id": "83e2e372-1df3-485d-a360-d9c4caf8b8c4"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -16,6 +16,6 @@
|
||||||
"description": {
|
"description": {
|
||||||
"text": "caca serveur minecraft en \u00a72C"
|
"text": "caca serveur minecraft en \u00a72C"
|
||||||
},
|
},
|
||||||
"favicon": "data:image/png;base64,<data>",
|
"favicon": "",
|
||||||
"enforcesSecureChat": false
|
"enforcesSecureChat": false
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue