MochaPayload/source/ios_mcp/source/logger.c

70 lines
1.5 KiB
C
Raw Normal View History

2022-02-04 14:23:22 +01:00
#include "logger.h"
2020-04-28 15:07:52 +02:00
#include "imports.h"
#include "socket.h"
2022-02-04 14:23:22 +01:00
#include "types.h"
#include <stdarg.h>
#include <string.h>
2020-04-28 15:07:52 +02:00
#ifdef LOG_IP
static int log_socket = 0;
2022-02-04 14:23:22 +01:00
int log_init(unsigned int ipAddress) {
2020-06-20 23:43:44 +02:00
log_socket = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
2022-02-04 14:23:22 +01:00
if (log_socket < 0) {
2020-06-20 23:43:44 +02:00
return log_socket;
2020-04-28 15:07:52 +02:00
}
2020-06-20 23:43:44 +02:00
struct sockaddr_in connect_addr;
memset(&connect_addr, 0, sizeof(connect_addr));
2022-02-04 14:23:22 +01:00
connect_addr.sin_family = AF_INET;
connect_addr.sin_port = 4405;
2020-06-20 23:43:44 +02:00
connect_addr.sin_addr.s_addr = ipAddress;
2020-04-28 15:07:52 +02:00
2022-02-04 14:23:22 +01:00
if (connect(log_socket, (struct sockaddr *) &connect_addr, sizeof(connect_addr)) < 0) {
2020-06-20 23:43:44 +02:00
closesocket(log_socket);
log_socket = -1;
}
2020-04-28 15:07:52 +02:00
2020-06-20 23:43:44 +02:00
return log_socket;
2020-04-28 15:07:52 +02:00
}
2022-02-04 14:23:22 +01:00
void log_deinit() {
if (log_socket >= 0) {
2020-04-28 15:07:52 +02:00
closesocket(log_socket);
log_socket = -1;
}
}
2022-02-04 14:23:22 +01:00
static void log_print(const char *str, int len) {
if (log_socket < 0) {
2020-04-28 15:07:52 +02:00
return;
}
int ret;
while (len > 0) {
int block = len < 1400 ? len : 1400; // take max 1400 bytes per UDP packet
2022-02-04 14:23:22 +01:00
ret = send(log_socket, str, block, 0);
if (ret < 0)
2020-04-28 15:07:52 +02:00
break;
len -= ret;
str += ret;
}
}
2022-02-04 14:23:22 +01:00
void log_printf(const char *format, ...) {
if (log_socket < 0) {
2020-04-28 15:07:52 +02:00
return;
}
va_list args;
va_start(args, format);
char buffer[0x100];
int len = vsnprintf(buffer, sizeof(buffer), format, args);
log_print(buffer, len);
va_end(args);
}
#endif // DEBUG_LOGGER