Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
P
proxy-in-proxychains
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nanahira
proxy-in-proxychains
Commits
dca4e2e9
Commit
dca4e2e9
authored
Oct 28, 2016
by
Krzysztof Kliś
Committed by
GitHub
Oct 28, 2016
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1 from ticpu/various_fix
Various fixes
parents
34a6ce1d
dfc88f2b
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
7 additions
and
5 deletions
+7
-5
proxy.c
proxy.c
+7
-5
No files found.
proxy.c
View file @
dca4e2e9
...
...
@@ -43,7 +43,7 @@
#include <unistd.h>
#include <wait.h>
#define BUF_SIZE 1
02
4
#define BUF_SIZE 1
638
4
#define READ 0
#define WRITE 1
...
...
@@ -68,6 +68,7 @@ void server_loop();
void
handle_client
(
int
client_sock
,
struct
sockaddr_in
client_addr
);
void
forward_data
(
int
source_sock
,
int
destination_sock
);
void
forward_data_ext
(
int
source_sock
,
int
destination_sock
,
char
*
cmd
);
int
create_connection
();
int
parse_options
(
int
argc
,
char
*
argv
[]);
int
server_sock
,
client_sock
,
remote_sock
,
remote_port
=
0
;
...
...
@@ -76,7 +77,7 @@ bool foreground = FALSE;
/* Program start */
int
main
(
int
argc
,
char
*
argv
[])
{
int
c
,
local_port
;
int
local_port
;
pid_t
pid
;
local_port
=
parse_options
(
argc
,
argv
);
...
...
@@ -147,7 +148,7 @@ int parse_options(int argc, char *argv[]) {
/* Create server socket */
int
create_socket
(
int
port
)
{
int
server_sock
,
optval
;
int
server_sock
,
optval
=
1
;
struct
sockaddr_in
server_addr
;
if
((
server_sock
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
))
<
0
)
{
...
...
@@ -189,7 +190,7 @@ void sigterm_handler(int signal) {
/* Main server loop */
void
server_loop
()
{
struct
sockaddr_in
client_addr
;
in
t
addrlen
=
sizeof
(
client_addr
);
socklen_
t
addrlen
=
sizeof
(
client_addr
);
while
(
TRUE
)
{
client_sock
=
accept
(
server_sock
,
(
struct
sockaddr
*
)
&
client_addr
,
&
addrlen
);
...
...
@@ -208,7 +209,7 @@ void handle_client(int client_sock, struct sockaddr_in client_addr)
{
if
((
remote_sock
=
create_connection
())
<
0
)
{
perror
(
"Cannot connect to host"
);
return
;
goto
cleanup
;
}
if
(
fork
()
==
0
)
{
// a process forwarding data from client to remote socket
...
...
@@ -229,6 +230,7 @@ void handle_client(int client_sock, struct sockaddr_in client_addr)
exit
(
0
);
}
cleanup:
close
(
remote_sock
);
close
(
client_sock
);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment