| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474 | 
							- // SoftEther VPN Source Code - Stable Edition Repository
 
- // Cedar Communication Module
 
- // 
 
- // SoftEther VPN Server, Client and Bridge are free software under GPLv2.
 
- // 
 
- // Copyright (c) Daiyuu Nobori.
 
- // Copyright (c) SoftEther VPN Project, University of Tsukuba, Japan.
 
- // Copyright (c) SoftEther Corporation.
 
- // 
 
- // All Rights Reserved.
 
- // 
 
- // http://www.softether.org/
 
- // 
 
- // Author: Daiyuu Nobori, Ph.D.
 
- // Comments: Tetsuo Sugiyama, Ph.D.
 
- // 
 
- // This program is free software; you can redistribute it and/or
 
- // modify it under the terms of the GNU General Public License
 
- // version 2 as published by the Free Software Foundation.
 
- // 
 
- // This program is distributed in the hope that it will be useful,
 
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
 
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 
- // GNU General Public License for more details.
 
- // 
 
- // You should have received a copy of the GNU General Public License version 2
 
- // along with this program; if not, write to the Free Software
 
- // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 
- // 
 
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 
- // IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
 
- // CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
 
- // TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
 
- // SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
- // 
 
- // THE LICENSE AGREEMENT IS ATTACHED ON THE SOURCE-CODE PACKAGE
 
- // AS "LICENSE.TXT" FILE. READ THE TEXT FILE IN ADVANCE TO USE THE SOFTWARE.
 
- // 
 
- // 
 
- // THIS SOFTWARE IS DEVELOPED IN JAPAN, AND DISTRIBUTED FROM JAPAN,
 
- // UNDER JAPANESE LAWS. YOU MUST AGREE IN ADVANCE TO USE, COPY, MODIFY,
 
- // MERGE, PUBLISH, DISTRIBUTE, SUBLICENSE, AND/OR SELL COPIES OF THIS
 
- // SOFTWARE, THAT ANY JURIDICAL DISPUTES WHICH ARE CONCERNED TO THIS
 
- // SOFTWARE OR ITS CONTENTS, AGAINST US (SOFTETHER PROJECT, SOFTETHER
 
- // CORPORATION, DAIYUU NOBORI OR OTHER SUPPLIERS), OR ANY JURIDICAL
 
- // DISPUTES AGAINST US WHICH ARE CAUSED BY ANY KIND OF USING, COPYING,
 
- // MODIFYING, MERGING, PUBLISHING, DISTRIBUTING, SUBLICENSING, AND/OR
 
- // SELLING COPIES OF THIS SOFTWARE SHALL BE REGARDED AS BE CONSTRUED AND
 
- // CONTROLLED BY JAPANESE LAWS, AND YOU MUST FURTHER CONSENT TO
 
- // EXCLUSIVE JURISDICTION AND VENUE IN THE COURTS SITTING IN TOKYO,
 
- // JAPAN. YOU MUST WAIVE ALL DEFENSES OF LACK OF PERSONAL JURISDICTION
 
- // AND FORUM NON CONVENIENS. PROCESS MAY BE SERVED ON EITHER PARTY IN
 
- // THE MANNER AUTHORIZED BY APPLICABLE LAW OR COURT RULE.
 
- // 
 
- // USE ONLY IN JAPAN. DO NOT USE THIS SOFTWARE IN ANOTHER COUNTRY UNLESS
 
- // YOU HAVE A CONFIRMATION THAT THIS SOFTWARE DOES NOT VIOLATE ANY
 
- // CRIMINAL LAWS OR CIVIL RIGHTS IN THAT PARTICULAR COUNTRY. USING THIS
 
- // SOFTWARE IN OTHER COUNTRIES IS COMPLETELY AT YOUR OWN RISK. THE
 
- // SOFTETHER VPN PROJECT HAS DEVELOPED AND DISTRIBUTED THIS SOFTWARE TO
 
- // COMPLY ONLY WITH THE JAPANESE LAWS AND EXISTING CIVIL RIGHTS INCLUDING
 
- // PATENTS WHICH ARE SUBJECTS APPLY IN JAPAN. OTHER COUNTRIES' LAWS OR
 
- // CIVIL RIGHTS ARE NONE OF OUR CONCERNS NOR RESPONSIBILITIES. WE HAVE
 
- // NEVER INVESTIGATED ANY CRIMINAL REGULATIONS, CIVIL LAWS OR
 
- // INTELLECTUAL PROPERTY RIGHTS INCLUDING PATENTS IN ANY OF OTHER 200+
 
- // COUNTRIES AND TERRITORIES. BY NATURE, THERE ARE 200+ REGIONS IN THE
 
- // WORLD, WITH DIFFERENT LAWS. IT IS IMPOSSIBLE TO VERIFY EVERY
 
- // COUNTRIES' LAWS, REGULATIONS AND CIVIL RIGHTS TO MAKE THE SOFTWARE
 
- // COMPLY WITH ALL COUNTRIES' LAWS BY THE PROJECT. EVEN IF YOU WILL BE
 
- // SUED BY A PRIVATE ENTITY OR BE DAMAGED BY A PUBLIC SERVANT IN YOUR
 
- // COUNTRY, THE DEVELOPERS OF THIS SOFTWARE WILL NEVER BE LIABLE TO
 
- // RECOVER OR COMPENSATE SUCH DAMAGES, CRIMINAL OR CIVIL
 
- // RESPONSIBILITIES. NOTE THAT THIS LINE IS NOT LICENSE RESTRICTION BUT
 
- // JUST A STATEMENT FOR WARNING AND DISCLAIMER.
 
- // 
 
- // 
 
- // SOURCE CODE CONTRIBUTION
 
- // ------------------------
 
- // 
 
- // Your contribution to SoftEther VPN Project is much appreciated.
 
- // Please send patches to us through GitHub.
 
- // Read the SoftEther VPN Patch Acceptance Policy in advance:
 
- // http://www.softether.org/5-download/src/9.patch
 
- // 
 
- // 
 
- // DEAR SECURITY EXPERTS
 
- // ---------------------
 
- // 
 
- // If you find a bug or a security vulnerability please kindly inform us
 
- // about the problem immediately so that we can fix the security problem
 
- // to protect a lot of users around the world as soon as possible.
 
- // 
 
- // Our e-mail address for security reports is:
 
- // softether-vpn-security [at] softether.org
 
- // 
 
- // Please note that the above e-mail address is not a technical support
 
- // inquiry address. If you need technical assistance, please visit
 
- // http://www.softether.org/ and ask your question on the users forum.
 
- // 
 
- // Thank you for your cooperation.
 
- // 
 
- // 
 
- // NO MEMORY OR RESOURCE LEAKS
 
- // ---------------------------
 
- // 
 
- // The memory-leaks and resource-leaks verification under the stress
 
- // test has been passed before release this source code.
 
- // Remote.c
 
- // Remote Procedure Call
 
- #include "CedarPch.h"
 
- // End of RPC
 
- void EndRpc(RPC *rpc)
 
- {
 
- 	RpcFree(rpc);
 
- }
 
- // Release the RPC
 
- void RpcFree(RPC *rpc)
 
- {
 
- 	// Validate arguments
 
- 	if (rpc == NULL)
 
- 	{
 
- 		return;
 
- 	}
 
- 	Disconnect(rpc->Sock);
 
- 	ReleaseSock(rpc->Sock);
 
- 	DeleteLock(rpc->Lock);
 
- 	Free(rpc);
 
- }
 
- // Get error
 
- UINT RpcGetError(PACK *p)
 
- {
 
- 	// Validate arguments
 
- 	if (p == NULL)
 
- 	{
 
- 		return ERR_DISCONNECTED;
 
- 	}
 
- 	return PackGetInt(p, "error_code");
 
- }
 
- // Error checking
 
- bool RpcIsOk(PACK *p)
 
- {
 
- 	// Validate arguments
 
- 	if (p == NULL)
 
- 	{
 
- 		return false;
 
- 	}
 
- 	if (PackGetInt(p, "error") == 0)
 
- 	{
 
- 		return true;
 
- 	}
 
- 	else
 
- 	{
 
- 		return false;
 
- 	}
 
- }
 
- // Error code setting
 
- void RpcError(PACK *p, UINT err)
 
- {
 
- 	// Validate arguments
 
- 	if (p == NULL)
 
- 	{
 
- 		return;
 
- 	}
 
- 	PackAddInt(p, "error", 1);
 
- 	PackAddInt(p, "error_code", err);
 
- }
 
- // Start the RPC dispatcher
 
- PACK *CallRpcDispatcher(RPC *r, PACK *p)
 
- {
 
- 	char func_name[MAX_SIZE];
 
- 	// Validate arguments
 
- 	if (r == NULL || p == NULL)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	if (PackGetStr(p, "function_name", func_name, sizeof(func_name)) == false)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	return r->Dispatch(r, func_name, p);
 
- }
 
- // Wait for the next RPC call
 
- bool RpcRecvNextCall(RPC *r)
 
- {
 
- 	UINT size;
 
- 	void *tmp;
 
- 	SOCK *s;
 
- 	BUF *b;
 
- 	PACK *p;
 
- 	PACK *ret;
 
- 	// Validate arguments
 
- 	if (r == NULL)
 
- 	{
 
- 		return false;
 
- 	}
 
- 	s = r->Sock;
 
- 	if (RecvAll(s, &size, sizeof(UINT), s->SecureMode) == false)
 
- 	{
 
- 		return false;
 
- 	}
 
- 	size = Endian32(size);
 
- 	if (size > MAX_PACK_SIZE)
 
- 	{
 
- 		return false;
 
- 	}
 
- 	tmp = MallocEx(size, true);
 
- 	if (RecvAll(s, tmp, size, s->SecureMode) == false)
 
- 	{
 
- 		Free(tmp);
 
- 		return false;
 
- 	}
 
- 	b = NewBuf();
 
- 	WriteBuf(b, tmp, size);
 
- 	SeekBuf(b, 0, 0);
 
- 	Free(tmp);
 
- 	p = BufToPack(b);
 
- 	FreeBuf(b);
 
- 	if (p == NULL)
 
- 	{
 
- 		return false;
 
- 	}
 
- 	ret = CallRpcDispatcher(r, p);
 
- 	FreePack(p);
 
- 	if (ret == NULL)
 
- 	{
 
- 		ret = PackError(ERR_NOT_SUPPORTED);
 
- 	}
 
- 	b = PackToBuf(ret);
 
- 	FreePack(ret);
 
- 	size = Endian32(b->Size);
 
- 	SendAdd(s, &size, sizeof(UINT));
 
- 	SendAdd(s, b->Buf, b->Size);
 
- 	if (SendNow(s, s->SecureMode) == false)
 
- 	{
 
- 		FreeBuf(b);
 
- 		return false;
 
- 	}
 
- 	FreeBuf(b);
 
- 	return true;
 
- }
 
- // RPC server operation
 
- void RpcServer(RPC *r)
 
- {
 
- 	SOCK *s;
 
- 	// Validate arguments
 
- 	if (r == NULL)
 
- 	{
 
- 		return;
 
- 	}
 
- 	s = r->Sock;
 
- 	while (true)
 
- 	{
 
- 		// Wait for the next RPC call
 
- 		if (RpcRecvNextCall(r) == false)
 
- 		{
 
- 			// Communication error
 
- 			break;
 
- 		}
 
- 	}
 
- }
 
- // RPC call
 
- PACK *RpcCall(RPC *r, char *function_name, PACK *p)
 
- {
 
- 	PACK *ret;
 
- 	UINT num_retry = 0;
 
- 	UINT err = 0;
 
- 	// Validate arguments
 
- 	if (r == NULL || function_name == NULL)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- //	Debug("RpcCall: %s\n", function_name);
 
- 	Lock(r->Lock);
 
- 	{
 
- 		if (p == NULL)
 
- 		{
 
- 			p = NewPack();
 
- 		}
 
- 		PackAddStr(p, "function_name", function_name);
 
- RETRY:
 
- 		err = 0;
 
- 		ret = RpcCallInternal(r, p);
 
- 		if (ret == NULL)
 
- 		{
 
- 			if (r->IsVpnServer && r->Sock != NULL)
 
- 			{
 
- 				if (num_retry < 1)
 
- 				{
 
- 					num_retry++;
 
- 					// Attempt to reconnect the RPC to the VPN Server
 
- 					err = AdminReconnect(r);
 
- 					if (err == ERR_NO_ERROR)
 
- 					{
 
- 						goto RETRY;
 
- 					}
 
- 				}
 
- 			}
 
- 		}
 
- 		FreePack(p);
 
- 		if (ret == NULL)
 
- 		{
 
- 			if (err == 0)
 
- 			{
 
- 				err = ERR_DISCONNECTED;
 
- 			}
 
- 			ret = PackError(err);
 
- 			PackAddInt(ret, "error_code", err);
 
- 		}
 
- 	}
 
- 	Unlock(r->Lock);
 
- 	return ret;
 
- }
 
- // RPC internal call
 
- PACK *RpcCallInternal(RPC *r, PACK *p)
 
- {
 
- 	BUF *b;
 
- 	UINT size;
 
- 	PACK *ret;
 
- 	void *tmp;
 
- 	// Validate arguments
 
- 	if (r == NULL || p == NULL)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	if (r->Sock == NULL)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	b = PackToBuf(p);
 
- 	size = Endian32(b->Size);
 
- 	SendAdd(r->Sock, &size, sizeof(UINT));
 
- 	SendAdd(r->Sock, b->Buf, b->Size);
 
- 	FreeBuf(b);
 
- 	if (SendNow(r->Sock, r->Sock->SecureMode) == false)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	if (RecvAll(r->Sock, &size, sizeof(UINT), r->Sock->SecureMode) == false)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	size = Endian32(size);
 
- 	if (size > MAX_PACK_SIZE)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	tmp = MallocEx(size, true);
 
- 	if (RecvAll(r->Sock, tmp, size, r->Sock->SecureMode) == false)
 
- 	{
 
- 		Free(tmp);
 
- 		return NULL;
 
- 	}
 
- 	b = NewBuf();
 
- 	WriteBuf(b, tmp, size);
 
- 	SeekBuf(b, 0, 0);
 
- 	Free(tmp);
 
- 	ret = BufToPack(b);
 
- 	if (ret == NULL)
 
- 	{
 
- 		FreeBuf(b);
 
- 		return NULL;
 
- 	}
 
- 	FreeBuf(b);
 
- 	return ret;
 
- }
 
- // Start the RPC server
 
- RPC *StartRpcServer(SOCK *s, RPC_DISPATCHER *dispatch, void *param)
 
- {
 
- 	RPC *r;
 
- 	// Validate arguments
 
- 	if (s == NULL)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	r = ZeroMallocEx(sizeof(RPC), true);
 
- 	r->Sock = s;
 
- 	r->Param = param;
 
- 	r->Lock = NewLock();
 
- 	AddRef(s->ref);
 
- 	r->ServerMode = true;
 
- 	r->Dispatch = dispatch;
 
- 	// Name generation
 
- 	Format(r->Name, sizeof(r->Name), "RPC-%u", s->socket);
 
- 	return r;
 
- }
 
- // Start the RPC client
 
- RPC *StartRpcClient(SOCK *s, void *param)
 
- {
 
- 	RPC *r;
 
- 	// Validate arguments
 
- 	if (s == NULL)
 
- 	{
 
- 		return NULL;
 
- 	}
 
- 	r = ZeroMalloc(sizeof(RPC));
 
- 	r->Sock = s;
 
- 	r->Param = param;
 
- 	r->Lock = NewLock();
 
- 	AddRef(s->ref);
 
- 	r->ServerMode = false;
 
- 	return r;
 
- }
 
 
  |