Skip to content

Commit

Permalink
Run as Windows service
Browse files Browse the repository at this point in the history
  • Loading branch information
lufog committed Apr 24, 2024
1 parent bd290b1 commit c3ccd45
Show file tree
Hide file tree
Showing 8 changed files with 144 additions and 2 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
.vscode
ciadpi.exe
3 changes: 2 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,13 @@ TARGET = ciadpi
CC ?= gcc
CFLAGS += -std=c99 -O2 -D_XOPEN_SOURCE=500
SOURCES = packets.c main.c conev.c proxy.c desync.c mpool.c extend.c
WIN_SOURCES = win_service.c

all:
$(CC) $(CFLAGS) $(SOURCES) -I . -o $(TARGET)

windows:
$(CC) $(CFLAGS) $(SOURCES) -I . -lws2_32 -lmswsock -o $(TARGET).exe
$(CC) $(CFLAGS) $(SOURCES) $(WIN_SOURCES) -I . -lws2_32 -lmswsock -o $(TARGET).exe

clean:
rm -f $(TARGET) *.o
4 changes: 4 additions & 0 deletions dist/windows/byedpi.bat
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
@echo off
title ByeDPI

ciadpi.exe --split 1+s --disorder 3+s --mod-http=h,d --auto --tlsrec 1+s
13 changes: 13 additions & 0 deletions dist/windows/service_delete.bat
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
@echo off
title ByeDPI - Delete Service

echo This script should be run with administrator privileges.
echo Right click - run as administrator.
echo Press any key if you're running it as administrator.
pause

set svc_name="ByeDPI"

sc stop %svc_name%
sc delete %svc_name%
pause
24 changes: 24 additions & 0 deletions dist/windows/service_install.bat
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
@echo off
title ByeDPI - Install Service
pushd "%~dp0"

echo This script should be run with administrator privileges.
echo Right click - run as administrator.
echo Press any key if you're running it as administrator.
pause

set svc_name="ByeDPI"
set svc_desc="Local SOCKS proxy server to bypass DPI (Deep Packet Inspection)."

:: Set up launch args (bypass methods) here. The "--service" arg is required;
:: without it, the program will not register itself as a Windows service!
set svc_bin="\"%cd%\ciadpi.exe\" --service --split 1+s --disorder 3+s --mod-http=h,d --auto --tlsrec 1+s"

sc stop %svc_name%
sc delete %svc_name%
sc create %svc_name% binPath= %svc_bin% start= "auto"
sc description %svc_name% %svc_desc%
sc start %svc_name%

popd
pause
20 changes: 19 additions & 1 deletion main.c
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
#include <sys/mman.h>
#else
#include <ws2tcpip.h>
#include "win_service.h"
#define close(fd) closesocket(fd)
#endif

Expand Down Expand Up @@ -139,6 +140,9 @@ const struct option options[] = {
#ifdef __linux__
{"md5sig", 0, 0, 'S'},
#endif
#ifdef _WIN32
{"service", 0, 0, 'B'},
#endif
{"fake-data", 1, 0, 'l'},
{"tls-sni", 1, 0, 'n'},
#endif
Expand Down Expand Up @@ -433,6 +437,8 @@ int main(int argc, char **argv)
uniperror("WSAStartup");
return -1;
}

int as_winsvc = 0;
#endif
struct sockaddr_ina s = {
.in = {
Expand All @@ -459,7 +465,7 @@ int main(int argc, char **argv)
int rez;
int invalid = 0;

long val = 0;
ssize_t val = 0;
char *end = 0;

uint16_t port = htons(1080);
Expand All @@ -475,6 +481,12 @@ int main(int argc, char **argv)
argc, argv, opt, options, 0)) != -1) {
switch (rez) {

#ifdef _WIN32
case 'B':
as_winsvc = 1;
break;
#endif

case 'N':
params.resolve = 0;
break;
Expand Down Expand Up @@ -803,6 +815,12 @@ int main(int argc, char **argv)
return -1;
}
}

#ifdef _WIN32
if (as_winsvc && register_winsvc(argc, argv))
return 0;
#endif

if (invalid) {
fprintf(stderr, "invalid value: -%c %s\n", rez, optarg);
clear_params();
Expand Down
79 changes: 79 additions & 0 deletions win_service.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
#include "win_service.h"
#include <minwindef.h>
#include <winsvc.h>

#define SERVICE_NAME "ByeDPI"

static SERVICE_STATUS ServiceStatus;
static SERVICE_STATUS_HANDLE hStatus;
static int svc_argc = 0;
static char **svc_argv = NULL;

int main(int argc, char *argv[]);

void service_ctrl_handler(DWORD request)
{
switch(request)
{
case SERVICE_CONTROL_STOP:
case SERVICE_CONTROL_SHUTDOWN:
ServiceStatus.dwWin32ExitCode = 0;
ServiceStatus.dwCurrentState = SERVICE_STOPPED;
default:
break;
}
SetServiceStatus(hStatus, &ServiceStatus);
return;
}

void service_main(int argc __attribute__((unused)), char *argv[] __attribute__((unused)))
{
ServiceStatus.dwServiceType = SERVICE_WIN32_OWN_PROCESS;
ServiceStatus.dwCurrentState = SERVICE_RUNNING;
ServiceStatus.dwControlsAccepted = SERVICE_ACCEPT_STOP | SERVICE_ACCEPT_SHUTDOWN;
ServiceStatus.dwWin32ExitCode = 0;
ServiceStatus.dwServiceSpecificExitCode = 0;
ServiceStatus.dwCheckPoint = 1;
ServiceStatus.dwWaitHint = 0;

hStatus = RegisterServiceCtrlHandler(SERVICE_NAME, (LPHANDLER_FUNCTION)service_ctrl_handler);
if (hStatus == (SERVICE_STATUS_HANDLE)0)
{
// Registering Control Handler failed
return;
}

SetServiceStatus(hStatus, &ServiceStatus);

// Calling main with saved argc & argv
ServiceStatus.dwWin32ExitCode = (DWORD)main(svc_argc, svc_argv);
ServiceStatus.dwCurrentState = SERVICE_STOPPED;
SetServiceStatus(hStatus, &ServiceStatus);
return;
}

int register_winsvc(int argc, char *argv[])
{
SERVICE_TABLE_ENTRY ServiceTable[] = {
{SERVICE_NAME, (LPSERVICE_MAIN_FUNCTION)service_main},
{NULL, NULL}
};

// Save args passed to the program to use instead of the service args.
if (!svc_argc && !svc_argv) {
svc_argc = argc;
svc_argv = calloc((size_t)(argc + 1), sizeof(void*));
for (int i = 0; i < argc; i++)
svc_argv[i] = strdup(argv[i]);
}

int result = StartServiceCtrlDispatcher(ServiceTable);

if (svc_argc && svc_argv) {
for (int i = 0; i < svc_argc; i++)
free(svc_argv[i]);
free(svc_argv);
}

return result;
}
1 change: 1 addition & 0 deletions win_service.h
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
int register_winsvc(int argc, char *argv[]);

0 comments on commit c3ccd45

Please sign in to comment.