Skip to content

Commit 59352d3

Browse files
authored
Merge pull request #8 from libxengine/develop
V1.5.1.1001 Merge
2 parents 15518f1 + 036a2b0 commit 59352d3

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

56 files changed

+802
-829
lines changed

CHANGELOG

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,15 @@
1+
XEngine_ProxyServer V1.5.1.1001
2+
3+
更新:匹配XEngine到V8.x版本
4+
更新:启动打印xengine版本类型了
5+
修改:启动参数-v现在打印自身版本信息
6+
删除:xengine版本判断代码
7+
8+
update:match xengine v8.x
9+
update:start printf xengine ver type
10+
modify:printf self version info for parament -v
11+
delete:xengine version judgment code
12+
======================================================================================
113
XEngine_ProxyServer V1.5.0.1001
214

315
优化:优化服务器性能和线程个数

LICENSE

Lines changed: 21 additions & 165 deletions
Original file line numberDiff line numberDiff line change
@@ -1,165 +1,21 @@
1-
GNU LESSER GENERAL PUBLIC LICENSE
2-
Version 3, 29 June 2007
3-
4-
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
5-
Everyone is permitted to copy and distribute verbatim copies
6-
of this license document, but changing it is not allowed.
7-
8-
9-
This version of the GNU Lesser General Public License incorporates
10-
the terms and conditions of version 3 of the GNU General Public
11-
License, supplemented by the additional permissions listed below.
12-
13-
0. Additional Definitions.
14-
15-
As used herein, "this License" refers to version 3 of the GNU Lesser
16-
General Public License, and the "GNU GPL" refers to version 3 of the GNU
17-
General Public License.
18-
19-
"The Library" refers to a covered work governed by this License,
20-
other than an Application or a Combined Work as defined below.
21-
22-
An "Application" is any work that makes use of an interface provided
23-
by the Library, but which is not otherwise based on the Library.
24-
Defining a subclass of a class defined by the Library is deemed a mode
25-
of using an interface provided by the Library.
26-
27-
A "Combined Work" is a work produced by combining or linking an
28-
Application with the Library. The particular version of the Library
29-
with which the Combined Work was made is also called the "Linked
30-
Version".
31-
32-
The "Minimal Corresponding Source" for a Combined Work means the
33-
Corresponding Source for the Combined Work, excluding any source code
34-
for portions of the Combined Work that, considered in isolation, are
35-
based on the Application, and not on the Linked Version.
36-
37-
The "Corresponding Application Code" for a Combined Work means the
38-
object code and/or source code for the Application, including any data
39-
and utility programs needed for reproducing the Combined Work from the
40-
Application, but excluding the System Libraries of the Combined Work.
41-
42-
1. Exception to Section 3 of the GNU GPL.
43-
44-
You may convey a covered work under sections 3 and 4 of this License
45-
without being bound by section 3 of the GNU GPL.
46-
47-
2. Conveying Modified Versions.
48-
49-
If you modify a copy of the Library, and, in your modifications, a
50-
facility refers to a function or data to be supplied by an Application
51-
that uses the facility (other than as an argument passed when the
52-
facility is invoked), then you may convey a copy of the modified
53-
version:
54-
55-
a) under this License, provided that you make a good faith effort to
56-
ensure that, in the event an Application does not supply the
57-
function or data, the facility still operates, and performs
58-
whatever part of its purpose remains meaningful, or
59-
60-
b) under the GNU GPL, with none of the additional permissions of
61-
this License applicable to that copy.
62-
63-
3. Object Code Incorporating Material from Library Header Files.
64-
65-
The object code form of an Application may incorporate material from
66-
a header file that is part of the Library. You may convey such object
67-
code under terms of your choice, provided that, if the incorporated
68-
material is not limited to numerical parameters, data structure
69-
layouts and accessors, or small macros, inline functions and templates
70-
(ten or fewer lines in length), you do both of the following:
71-
72-
a) Give prominent notice with each copy of the object code that the
73-
Library is used in it and that the Library and its use are
74-
covered by this License.
75-
76-
b) Accompany the object code with a copy of the GNU GPL and this license
77-
document.
78-
79-
4. Combined Works.
80-
81-
You may convey a Combined Work under terms of your choice that,
82-
taken together, effectively do not restrict modification of the
83-
portions of the Library contained in the Combined Work and reverse
84-
engineering for debugging such modifications, if you also do each of
85-
the following:
86-
87-
a) Give prominent notice with each copy of the Combined Work that
88-
the Library is used in it and that the Library and its use are
89-
covered by this License.
90-
91-
b) Accompany the Combined Work with a copy of the GNU GPL and this license
92-
document.
93-
94-
c) For a Combined Work that displays copyright notices during
95-
execution, include the copyright notice for the Library among
96-
these notices, as well as a reference directing the user to the
97-
copies of the GNU GPL and this license document.
98-
99-
d) Do one of the following:
100-
101-
0) Convey the Minimal Corresponding Source under the terms of this
102-
License, and the Corresponding Application Code in a form
103-
suitable for, and under terms that permit, the user to
104-
recombine or relink the Application with a modified version of
105-
the Linked Version to produce a modified Combined Work, in the
106-
manner specified by section 6 of the GNU GPL for conveying
107-
Corresponding Source.
108-
109-
1) Use a suitable shared library mechanism for linking with the
110-
Library. A suitable mechanism is one that (a) uses at run time
111-
a copy of the Library already present on the user's computer
112-
system, and (b) will operate properly with a modified version
113-
of the Library that is interface-compatible with the Linked
114-
Version.
115-
116-
e) Provide Installation Information, but only if you would otherwise
117-
be required to provide such information under section 6 of the
118-
GNU GPL, and only to the extent that such information is
119-
necessary to install and execute a modified version of the
120-
Combined Work produced by recombining or relinking the
121-
Application with a modified version of the Linked Version. (If
122-
you use option 4d0, the Installation Information must accompany
123-
the Minimal Corresponding Source and Corresponding Application
124-
Code. If you use option 4d1, you must provide the Installation
125-
Information in the manner specified by section 6 of the GNU GPL
126-
for conveying Corresponding Source.)
127-
128-
5. Combined Libraries.
129-
130-
You may place library facilities that are a work based on the
131-
Library side by side in a single library together with other library
132-
facilities that are not Applications and are not covered by this
133-
License, and convey such a combined library under terms of your
134-
choice, if you do both of the following:
135-
136-
a) Accompany the combined library with a copy of the same work based
137-
on the Library, uncombined with any other library facilities,
138-
conveyed under the terms of this License.
139-
140-
b) Give prominent notice with the combined library that part of it
141-
is a work based on the Library, and explaining where to find the
142-
accompanying uncombined form of the same work.
143-
144-
6. Revised Versions of the GNU Lesser General Public License.
145-
146-
The Free Software Foundation may publish revised and/or new versions
147-
of the GNU Lesser General Public License from time to time. Such new
148-
versions will be similar in spirit to the present version, but may
149-
differ in detail to address new problems or concerns.
150-
151-
Each version is given a distinguishing version number. If the
152-
Library as you received it specifies that a certain numbered version
153-
of the GNU Lesser General Public License "or any later version"
154-
applies to it, you have the option of following the terms and
155-
conditions either of that published version or of any later version
156-
published by the Free Software Foundation. If the Library as you
157-
received it does not specify a version number of the GNU Lesser
158-
General Public License, you may choose any version of the GNU Lesser
159-
General Public License ever published by the Free Software Foundation.
160-
161-
If the Library as you received it specifies that a proxy can decide
162-
whether future versions of the GNU Lesser General Public License shall
163-
apply, that proxy's public statement of acceptance of any version is
164-
permanent authorization for you to choose that version for the
165-
Library.
1+
MIT License
2+
3+
Copyright (c) 2023 XEngine:www.xyry.org
4+
5+
Permission is hereby granted, free of charge, to any person obtaining a copy
6+
of this software and associated documentation files (the "Software"), to deal
7+
in the Software without restriction, including without limitation the rights
8+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
copies of the Software, and to permit persons to whom the Software is
10+
furnished to do so, subject to the following conditions:
11+
12+
The above copyright notice and this permission notice shall be included in all
13+
copies or substantial portions of the Software.
14+
15+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21+
SOFTWARE.

README.en.md

Lines changed: 9 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,7 @@ this software support following features
2525
## install
2626

2727
#### XEngine Evn
28-
you must install XEngine,need V7.38 or above,install XEngine can be refer to xengine Readme docment
28+
you must install XEngine,need V8.10 or above,install XEngine can be refer to xengine Readme docment
2929
GITEE:https://gitee.com/xyry/libxengine
3030
GITHUB:https://github.com/libxengine/xengine
3131

@@ -40,11 +40,7 @@ use vs open and compile,suport windows 7sp1 and above
4040
Just Run it,use XEngine_AuthorizeApp
4141

4242
#### Linux
43-
use makefile compile,UBUNTU20.04 x64 or CENTOS8 x64
44-
Run it on the terminal
45-
46-
#### Macos
47-
use makefile compile,mac 12 and above
43+
use makefile compile,UBUNTU22.04 x64 or RockyLinux9 x64
4844
Run it on the terminal
4945

5046
##### complie
@@ -53,6 +49,13 @@ make complie
5349
make FLAGS=InstallAll install
5450
make FLAGS=CleanAll clear
5551

52+
#### Macos
53+
use makefile compile,mac 12 and above
54+
Run it on the terminal
55+
56+
##### complie
57+
Refer to Linux
58+
5659
#### use
5760

5861
1. Switch to the MASTER branch

README.md

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,7 @@ c c++ Socks5 Proxy Service,HTTP Tunnel Proxy Service,tcp forward service
2525
## 安装教程
2626

2727
#### XEngine环境
28-
必须安装XEngine,版本需要V7.38或者以上版本,安装XEngine可以参考其Readme文档
28+
必须安装XEngine,版本需要V8.10或者以上版本,安装XEngine可以参考其Readme文档
2929
GITEE:https://gitee.com/xyry/libxengine
3030
GITHUB:https://github.com/libxengine/xengine
3131

@@ -40,11 +40,7 @@ macos执行:./XEngine_LINEnv.sh -i 3
4040
直接运行即可,使用XEngine_AuthorizeApp
4141

4242
#### Linux
43-
Linux使用Makefile编译,UBUNTU20.04 x64或者CENTOS8 x64
44-
在控制台运行
45-
46-
#### Macos
47-
使用makefile编译,控制台运行,需要mac 12以及以上版本
43+
Linux使用Makefile编译,UBUNTU22.04 x64或者RockyLinux9 x64
4844
在控制台运行
4945

5046
##### 编译命令
@@ -53,6 +49,13 @@ make 编译
5349
make FLAGS=InstallAll 安装库程序
5450
make FLAGS=CleanAll 清理编译
5551

52+
#### Macos
53+
使用makefile编译,控制台运行,需要mac 13以及以上版本
54+
在控制台运行
55+
56+
##### 编译命令
57+
参考Linux
58+
5659
#### 使用说明
5760

5861
1. 切换到MASTER分支
@@ -85,6 +88,7 @@ make FLAGS=CleanAll 清理编译
8588
## 开发计划
8689
透传代理
8790
转发代理支持权限和确认
91+
支持加密代理
8892

8993
## 关注我们
9094
如果你觉得这个软件对你有帮助,请你给我们一个START吧

XEngine_APPClient/APPClient_ForwardExample/APPClient_ForwardExample.cpp

Lines changed: 12 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -26,15 +26,16 @@
2626
//需要优先配置XEngine
2727
//WINDOWS支持VS2022 x86 debug 编译调试
2828
//linux使用下面的命令编译
29-
//g++ -std=c++17 -Wall -g APPClient_ForwardExample.cpp -o APPClient_ForwardExample.exe -L /usr/local/lib/XEngine_Release/XEngine_BaseLib -L /usr/local/lib/XEngine_Release/XEngine_Client -L /usr/local/lib/XEngine_Release/XEngine_RfcComponents -lXEngine_BaseLib -lXClient_Socket -lRfcComponents_ProxyProtocol
29+
//g++ -std=c++17 -Wall -g APPClient_ForwardExample.cpp -o APPClient_ForwardExample.exe -I ../../XEngine_Source/XEngine_ThirdPart/jsoncpp -L /usr/local/lib/XEngine_Release/XEngine_BaseLib -L /usr/local/lib/XEngine_Release/XEngine_Client -L /usr/local/lib/XEngine_Release/XEngine_RfcComponents -L ../../XEngine_Source/XEngine_ThirdPart/jsoncpp -lXEngine_BaseLib -lXClient_Socket -lRfcComponents_ProxyProtocol -ljsoncpp -Wl,-rpath=../../XEngine_Source/XEngine_ThirdPart/jsoncpp,--disable-new-dtags
30+
3031
int main(int argc, char** argv)
3132
{
3233
#ifdef _MSC_BUILD
3334
WSADATA st_WSAData;
3435
WSAStartup(MAKEWORD(2, 2), &st_WSAData);
3536
#endif
36-
SOCKET m_Socket;
37-
LPCTSTR lpszServiceAddr = _T("127.0.0.1");
37+
XSOCKET m_Socket;
38+
LPCXSTR lpszServiceAddr = _X("127.0.0.1");
3839
if (!XClient_TCPSelect_Create(&m_Socket, lpszServiceAddr, 5402))
3940
{
4041
printf("连接失败!错误:%lX\n", XClient_GetLastError());
@@ -53,14 +54,14 @@ int main(int argc, char** argv)
5354
st_ProtocolHdr.unOperatorType = ENUM_XENGINE_COMMUNICATION_PROTOCOL_TYPE_AUTH;
5455
st_ProtocolHdr.unOperatorCode = XENGINE_COMMUNICATION_PROTOCOL_OPERATOR_CODE_FORWARD_LOGREQ;
5556

56-
if (!XClient_TCPSelect_SendMsg(m_Socket, (LPCTSTR)&st_ProtocolHdr, sizeof(XENGINE_PROTOCOLHDR)))
57+
if (!XClient_TCPSelect_SendMsg(m_Socket, (LPCXSTR)&st_ProtocolHdr, sizeof(XENGINE_PROTOCOLHDR)))
5758
{
5859
printf("发送失败!\n");
5960
return 0;
6061
}
6162

6263
nMsgLen = 0;
63-
TCHAR* ptszMsgBuffer = NULL;
64+
XCHAR* ptszMsgBuffer = NULL;
6465
memset(&st_ProtocolHdr, '\0', sizeof(XENGINE_PROTOCOLHDR));
6566
if (!XClient_TCPSelect_RecvPkt(m_Socket, &ptszMsgBuffer, &nMsgLen, &st_ProtocolHdr))
6667
{
@@ -75,7 +76,7 @@ int main(int argc, char** argv)
7576
st_ProtocolHdr.byVersion = 0;
7677
st_ProtocolHdr.unOperatorType = ENUM_XENGINE_COMMUNICATION_PROTOCOL_TYPE_USER_FORWARD;
7778
st_ProtocolHdr.unOperatorCode = XENGINE_COMMUNICATION_PROTOCOL_OPERATOR_CODE_FORWARD_LISTREQ;
78-
if (!XClient_TCPSelect_SendMsg(m_Socket, (LPCTSTR)&st_ProtocolHdr, sizeof(XENGINE_PROTOCOLHDR)))
79+
if (!XClient_TCPSelect_SendMsg(m_Socket, (LPCXSTR)&st_ProtocolHdr, sizeof(XENGINE_PROTOCOLHDR)))
7980
{
8081
printf("发送失败!\n");
8182
return 0;
@@ -95,7 +96,7 @@ int main(int argc, char** argv)
9596
std::unique_ptr<Json::CharReader> const pSt_JsonReader(st_JsonBuilder.newCharReader());
9697
if (!pSt_JsonReader->parse(ptszMsgBuffer, ptszMsgBuffer + nMsgLen, &st_JsonAddr, &st_JsonError))
9798
{
98-
return FALSE;
99+
return false;
99100
}
100101
BaseLib_OperatorMemory_FreeCStyle((XPPMEM)&ptszMsgBuffer);
101102
if (st_JsonAddr["Count"].asInt() > 0)
@@ -112,7 +113,7 @@ int main(int argc, char** argv)
112113
st_ProtocolHdr.unPacketSize = st_JsonRoot.toStyledString().length();
113114
st_ProtocolHdr.unOperatorType = ENUM_XENGINE_COMMUNICATION_PROTOCOL_TYPE_USER_FORWARD;
114115
st_ProtocolHdr.unOperatorCode = XENGINE_COMMUNICATION_PROTOCOL_OPERATOR_CODE_FORWARD_BINDREQ;
115-
if (!XClient_TCPSelect_SendMsg(m_Socket, (LPCTSTR)&st_ProtocolHdr, sizeof(XENGINE_PROTOCOLHDR)))
116+
if (!XClient_TCPSelect_SendMsg(m_Socket, (LPCXSTR)&st_ProtocolHdr, sizeof(XENGINE_PROTOCOLHDR)))
116117
{
117118
printf("发送失败!\n");
118119
return 0;
@@ -139,14 +140,14 @@ int main(int argc, char** argv)
139140
}
140141
else
141142
{
142-
BOOL bGet = FALSE;
143+
bool bGet = false;
143144
while (1)
144145
{
145146
if (bGet)
146147
{
147148
//收到转发请求
148149
nMsgLen = 2048;
149-
TCHAR tszMsgBuffer[2048];
150+
XCHAR tszMsgBuffer[2048];
150151

151152
memset(tszMsgBuffer, '\0', sizeof(tszMsgBuffer));
152153

@@ -162,7 +163,7 @@ int main(int argc, char** argv)
162163
//收到转发请求
163164
if (XENGINE_COMMUNICATION_PROTOCOL_OPERATOR_CODE_FORWARD_BINDREQ == st_ProtocolHdr.unOperatorCode)
164165
{
165-
bGet = TRUE;
166+
bGet = true;
166167
printf("get forward\n");
167168
}
168169
BaseLib_OperatorMemory_FreeCStyle((XPPMEM)&ptszMsgBuffer);

0 commit comments

Comments
 (0)