The present invention relates generally to networking and more particularly to the use of private cloud networks.
In the Internet connected environment, the Smart Device Clients including smart phone, tablet, eBook reader, notebook, PC and various smart gadgets are ubiquitous and omnipresent. Other than connectivity, one of the values of the Smart Device Clients is to be able to connect at any time and any place to retrieve services from one or many serving parties or servers. The services include audio, video contents, live or archived information, execution of applications, social media, messaging, email, storage, backup, calendar, contact, synchronization and others. There are different types of servers that serve these various requests from the Smart Device Clients. In general, these types of servers can be categorized to fall into two groups: a public cloud and a private cloud. Servers in the public cloud, implied by the name “public”, provide services that tend to be free with limited functionality or fee-based with more sophisticated services and interact with the public. Examples of the public cloud server include data center, social media services and storage/content provider through the Internet. On the other hand, servers in the private cloud tend to address the private need. The services provided are more private and personal as opposed to those offered by the public cloud.
One example of the application of the private cloud server is a private cloud storage server (PCSS). The PCSS sits within the local area network (LAN) managed by the user. It provides on-line and backup storage for the user either within the LAN or in the wide area network (WAN). The user is able to use a Smart Device Client to access information within the private cloud storage server at anytime from anywhere. The private cloud storage server and the associated Smart Device Client therefore form an example of the Private Cloud Server and Client architecture.
Conventionally, there are many storage server solutions exist, including network attached storage (NAS), Windows/Mac/Linux server, and direct attached storage (DAS) to fulfill the PCSS requirement. But the challenge for the Smart Device Clients in the field has been how to avoid the cumbersome setup and penetrate the firewall behind the router on the LAN to access the PCSS in a home or office environment. There are at least four kinds of solutions to this challenge.
One solution is to assign a fixed IP address and open certain ports for the router in front of the PCSS, such that the Smart Device Client is able to locate the PCSS from outside the LAN and to authenticate itself, penetrate the firewall and establish a secure communication channel with the PCSS.
The second solution applies when a fixed IP address is not available. The user configures the LAN router of the PCSS and open certain ports to map to the PCSS. The router is therefore able to be located by the intended Smart Device Client through a dynamic DNS (DDNS) service on the WAN. The Smart Device Client can authenticate itself, penetrate the firewall and establish a secure communication channel with the PCSS.
The third solution is to rely on another routing server in the WAN to conduct the virtual private network (VPN) communication between the Smart Device Client and the PCSS. The VPN communication allows the Smart Device Client to locate the PCSS, authenticate itself, penetrate the firewall and establish a secure communication channel with the PCSS.
The fourth solution is to rely on another routing server in the WAN to conduct the remote desktop protocol (RDP) or virtual network computing (VNC) communication between the Smart Device Client and the PCSS. The RDP/VNC communication allows the Smart Device Client to locate the PCSS, authenticate itself, penetrate the firewall and establish a secure communication channel with the PCSS. Other solutions can be mix-and match of the above mentioned solutions.
In the first scenario, a fixed IP address is required and the router needs to be set up and configured. The down side is that a fixed IP involves more cost and is usually not available in the home and small business environment. The router set up and configuration can be very complicated and are not user friendly with most consumers.
In the second scenario, a DDNS service is required and the router needs yet more complex set up. Again, the DDNS set up involves additional cost and complexity into the system. The router set up and configuration can be very complicated and is not user friendly with most consumers.
In the third and fourth scenarios, an outside routing server or service needs to be established, while a router set up is not necessary. The outside routing server or service controls and handles login/authentication between the Smart Device Client and the server. The private cloud becomes less private and less secure through the third party server or service. If for any reason the server or service is down, the communication and availability of the private cloud storage server will be jeopardized.
All of these scenarios require technical expertise that may be suitable for conventional corporate environment, but these scenarios are not suitable for consumer oriented Smart Device Client centric deployment.
In most conventional systems, an outside or third party routing server is used by the Smart Device Client during access to the Private Cloud Server. Using an outside server creates a number of concerns to the Smart Device Client owner. First, the sense of trust is always in question, because the outside or third party routing server is a middleman during all communication transactions between the Smart Device Client and the Private Cloud Server. It may hold all user account info, password and their corresponding IP addresses of the Smart Device Client and the Private Cloud Server. The routing server is able to sniff any communication in-between and render it insecure. Second, being an outside and third party routing server, its business model may not always be in-line or in-sync with the Smart Device Client owner. If the routing server is out of service due to any business reason, there is no remedy or option of replacement to restore the service. It potentially poses a tremendous business risk to the user, as the vital link in the communication can be broken without recourse.
What is needed in the consumer oriented environment is for the Smart Device Client in the WAN to be able to obtain services from a Private Cloud Storage Server (PCSS) or any Private Cloud Server (PCS) solving the following challenges:
1. Access the Private Cloud Server (PCS) at anytime from anywhere.
2. Access the PCS behind the firewall with fixed or dynamic IP address.
3. Require no outside or third party routing server in the WAN.
4. Require no additional router setup in the LAN.
5. Authenticate with the PCS using an authentication approach such as those of present invention including Initial Setup and Authentication Approach (
6. Establish a secure communication channel with the PCS.
If such challenges can be met and resolved, it will increase the deployment of the Private Cloud Server or service exponentially, due to the plug and play simplicity and availability. It also removes the technical and business concern by not utilizing a third party routing server. The Private Cloud Server covering storage and remote desktop service becomes very affordable and ubiquitous in the private cloud infrastructure. Accordingly, the present invention addresses such a need.
A method and system for use with a public cloud network is disclosed, wherein the public cloud network includes at least one private cloud server and at least one smart client device in communication therewith. The method and system comprise setting up the at least one private cloud server and the at least one smart client device in a client server relationship. The at least one private cloud server includes a message box associated therewith. The first message box is located in the public network. The at least one smart client includes a second message box associated therewith. The second message box is located on the public network. The method includes passing session based message information between the at least one private cloud server and the at least one smart client device via the first message box and the second message box in a secure manner. The session base information is authenticated by the private cloud server and the at least one smart client device. The smart client device and the private cloud server can then communicate with each other after the session based information is authenticated.
The present invention relates generally to networking and more particularly to the use of private cloud networks. The following description is presented to enable one of ordinary skill in the art to make and use the invention and is provided in the context of a patent application and its requirements. Various modifications to the embodiments and the generic principles and features described herein will be readily apparent to those skilled in the art. Thus, the present invention is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features described herein.
The term “Client” is interchangeable with “Smart Device Client” throughout discussion in the context. The term “router” is in general interchangeable with “gateway”, “access point” and/or “NAT” (network address translation) in the discussion.
The purpose of a system and method in accordance with the invention is to provide a Private Cloud Server and Client architecture without utilizing a routing server. The system and invention addresses all challenges that allows a Client to be able to access the Private Cloud Server (PCS) from anywhere at anytime. The system also accesses the PCS behind the firewall with fixed or dynamic IP, requires no additional router setup and no third party routing server in the WAN, to authenticate with the PCS, and to establish a secure communication channel directly with the PCS.
As shown in
Physically, there are three scenarios that a Smart Device Client 101, 107 or 109 can connect to the Private Cloud Server 108. First, a Smart Device Client 107 determines whether the target is in the locally accessible LAN 104 and decides to connect to the Private Cloud Server 108 directly. Second, the Smart Device Client 101 determines the target is not in the locally accessible LAN 104 and decides to connect through the WAN to the public cloud 100. The WAN locates the Router_P 102 and LAN 104, then connects to the Private Cloud Server 108. Third, the Smart Device Client 109 determines the target is not in the locally accessible LAN 105 and decides to passes through LAN 105, Router_S 103, and connects to the public cloud 100 in the WAN. The Smart Device Client 109 then locates Router_P 102, LAN 104 and connects to the Private Cloud Server 108. The first and the second scenario are two special cases and derivatives of the third scenario. Therefore, it is beneficial for the invention to focus on the third scenario that is with broader scope and complexity in real life application.
The configuration of the Router_P 102 and the setup of the Intermediate Routing Server 112 are not really trivial and can be very difficult for most of the end users. Further, by mapping the private IP address of the Private Cloud Server 108 to a port that is directly and permanently addressable by the outside world, it conceivably creates a big security risk for the Private Cloud Server 108.
The Private Cloud Server 108 is directly and permanently exposed to the outside world that can invite many vicious attacks. Also, the Intermediate Routing Server 112 is a third party server. It creates a number of concerns to the Smart Device Client 109 owner. First, the sense of trust is always in question, because the Intermediate Routing Server 112 is a middleman during all communication transactions between the Smart Device Client 109 and the Private Cloud Server 108. It may hold all user account information, password and their corresponding IP addresses of the Smart Device Client 109 and the Private Cloud Server 108. The Intermediate Routing Server 112 is able to sniff any communication in-between and render it insecure.
Second, being an outside and third party routing server, the business model of the Intermediate Routing Server 112 may not always be in-line or in-sync with the Smart Device Client 109 owner. If the Intermediate Routing Server 112 is out of service due to any business reason, there is no remedy or option of replacement to restore the service. It potentially poses a tremendous business risk to the user, as the vital link in the communication can be broken without recourse.
The Smart Device Client 109 then logs in to the VPN Routing Server 114 and looks up the virtual IP address of the Private Cloud Server 108, in step 303. All communication between the Smart Device Client 109 and the Private Cloud Server 108 are intercepted and encapsulated by the VPN Routing Server 114, in step 304. The Smart Device Client 109 can then start accessing the Private Cloud Server 108, as in step 305.
As opposed to the prior art in
Before the Smart Device Client 109 is able to access the Private Cloud Server 108, a number of steps have to happen. First, the Smart Device Client 109 obtains the ID and Password of the Private Cloud Server 108 from the server through a secure channel, such as phone call, email, text message or snail mail, as in step 403. The Smart Device Client 109 then logs in to the Intermediate Routing Server 112 with the its own ID and the obtained ID and Password of the Private Cloud Server 108, as in step 404. All communication between the Smart Device Client 109 and the Private Cloud Server 108 are intercepted and encapsulated by the Intermediate Routing Server 112, as in step 405. Finally, the Smart Device Client 109 can start accessing the Private Cloud Server 108, as in step 406.
As opposed to the conventional approach in
Being a third party server, the Intermediate Routing Server 112 creates a number of concerns to the Smart Device Client 109 owner. First, the sense of trust is always in question, because the Intermediate Routing Server 112 is a middleman during all communication transactions between the Smart Device Client 109 and the Private Cloud Server 108. It may hold all user account information, password and their corresponding IP addresses of the Smart Device Client 109 and the Private Cloud Server 108. The Intermediate Routing Server 112 is able to sniff any communication in-between and render it insecure.
Second, being an outside and third party routing server, the business model of the Intermediate Routing Server 112 may not always be in-line or in-sync with the Smart Device Client 109 owner. If the Intermediate Routing Server 112 is out of service due to any business reason, there is no remedy or option of replacement to restore the service. It potentially poses a tremendous business risk to the user, as the vital link in the communication can be broken without recourse.
Before the Smart Device Client 109 is able to access the Private Cloud Server 108, a number of steps have to happen. First, the Smart Device Client 109 and the Private Cloud Server 108 obtain the public IP and private IP addresses of the other party from the Intermediate Routing Server, as in step 503. Both parties punch a hole in their respective routers during initial outgoing communication attempt with each other, as in step 504. All communication between the Smart Device Client 109 and the Private Cloud Server 108 are bound together, establishing a peer-to-peer communication channel in between, as in step 505. Finally, the Smart Device Client 109 can start accessing the Private Cloud Server 108, as in step 506.
As opposed to the conventional approaches of
Second, being an outside and third party routing server, the business model of the Intermediate Routing Server 112 may not always be in-line or in-sync with the Smart Device Client 109 owner. If the Intermediate Routing Server 112 is out of service due to any business reason, there is no remedy or option of replacement to restore the service. It potentially poses a tremendous business risk to the user, as the vital link in the communication can be broken without recourse.
One of the biggest advantages of a system and method in accordance with the present invention over the above cited conventional approaches is to eliminate with the role of the third party routing server during access, as in the case of either the VPN Routing Server or the Intermediate Routing Server. Another advantage of the invention is that no secret information such as password of the account is ever exchanged between the Smart Device Client 109 and the Private Cloud Server 108.
To describe the features of the present invention in more detail, refer now to
On the Smart Device Client 109 side, it first retrieves the session based invitation from its own message_box_S 115, as in step 611. The session based invitation includes the message box address message_box_P 116 of the Private Cloud Server. If the invitation from the Private Cloud Server 108 is invalid, then it loops back to step 611. If the invitation is valid from the Private Cloud Server 108, the Smart Device Client 109 may reply to the Private Cloud Server 108 message box message_box_P 116 with a session based access request, to register its current client message box address, public IP and private IP addresses whenever it needs to access to the Private Cloud Server 108, as in step 613. The session based access request may include the Smart Device Client 109 message box address, message_box_S 115, and the client public and private IP addresses, public_IP_S 119 and private_IP_S 120. The Smart Device Client 109 then retrieves from the client message_box_S 115, the session based acknowledgement with the Private Cloud Server current public IP and private IP addresses, public_IP_P 117 and private_IP_P 118, as in step 614. The Smart Device Client 109 can start the communication request to the Private Cloud Server, as in step 615. These two independent processes conclude the initial setup of the Private Cloud Server 108 and the Smart Device Client 109.
The message box servers, hosting either server or client message boxes, can be an email server, text message server, or any kind of server that can host secure message for information exchange between the Private Cloud Server 108, as a server, and the Smart Device Client 109, as a client. The security and business model of the message box server is well understood and expected in the industry by the user. For any reason the message box server is down, it can be replaced or redeployed immediately without jeopardizing the communication between the server and the client in the private cloud infrastructure.
In order to ensure the peer-to-peer communication channel secure, a number of security measures are deployed, including AES encryption and/or SSL (secure socket layer), TLS (transport layer security). The session based communication between the server and client, including invitation, access request and acknowledgement, also utilizes random number seeds, time stamp, encryption and hashing to defeat man-in-the middle and reply attack from the third party to ensure the security and integrity of the communication.
Because the invention does not rely on a third party routing server, it solves and eases a number of concerns to the Smart Device Client owner. First, there is no single point of failure between the client and the server. Second, there is no middleman during any communication transactions between the Smart Device Client 109 and the Private Cloud Server 108. The performance is therefore better. Third, no sniffing of any communication in-between is possible and therefore makes the process very secure for the client and server. The user account information, password and their corresponding IP addresses of the Smart Device Client 109 and the Private Cloud Server 108 are never exposed to a third party. The only outside communication channels utilized in information exchange between the Smart Device Client 109 and the Private Cloud Server 108 are the two private message boxes message_box_S 115 and message_box_P 116. The password information is never exchanged between the Private Cloud Server 108 and the Smart Device Client 109, as a client. The security of the communication is as good as the message box servers hosting message_box_S 115 and message_box_P 116. If for any reason either message box is compromised or out of service, another replacement or backup message box can be deployed immediately. In this invention, any key component, including router, network switch, message box, Smart Device Client 109, or even Private Cloud Server 108, can be replaced without affecting the efficiency and integrity of the communication link between the Smart Device Client 109 and the Private Cloud Server 108.
The network interface 903 can connect to LAN, WAN or 3G/4G network. The I/O 904 is for user interface to the outside world, including input/output devices such as keyboard, mouse, audio and video. The non-volatile storage can be hard disk storage or flash based solid state disk. Inside the non-volatile mass storage 905, it is loaded with necessary software including OS and device drivers.
The Cloud Server Driver 907 is deployed to communicate with the corresponding Cloud Client Driver from the Smart Client Device 109. The Cloud Server Driver 907 initiates invitation, processes the access request, and then sends acknowledgement back to the Smart Device Client 109. Later, it sends communication request to the Smart Device Client 109 and opens a hole in its router in the outgoing direction. Once the incoming request from the Smart Device Client reaches the opened hole, the two-way communication channel is bound together. The Cloud Server Driver 907 can start secure peer-to-peer communication with the Smart Device Client 109.
The network interface 1003 can connect to LAN, WAN or 3G/4G network. The I/O 1004 is for user interface to the outside world, including input/output devices such as touch pad, audio and video. The non-volatile storage can be hard disk storage or flash based solid state disk. Inside the non-volatile mass storage 1005, it is loaded with necessary software including OS and device drivers. The Cloud Client Driver 1007 is deployed to communicate with the corresponding Cloud Server Driver 907 from the Private Cloud Server 108. The Cloud Client Driver 1007 responds to server invitation, replies with the access request, and then accepts acknowledgement from the Private Cloud Server 108. Later, it sends communication request to the Private Cloud Server 108 and opens a hole in its router in the outgoing direction. Once the incoming request from the Private Cloud Server 108 reaches the opened hole, the two-way communication channel is bound together. The Smart Device Client 109 can start secure peer-to-peer communication with the Private Cloud Server 108.
Although the present invention has been described in accordance with the embodiments shown, one of ordinary skill in the art will readily recognize that there could be variations to the embodiments and those variations would be within the spirit and scope of the present invention. Accordingly, many modifications may be made by one of ordinary skill in the art without departing from the spirit and scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
5408618 | Aho et al. | Apr 1995 | A |
6438594 | Bowman-Amuah | Aug 2002 | B1 |
6779004 | Zintel | Aug 2004 | B1 |
6954790 | Forslow | Oct 2005 | B2 |
6978314 | Tarr | Dec 2005 | B2 |
6981041 | Araujo et al. | Dec 2005 | B2 |
7068680 | Kaltenmark et al. | Jun 2006 | B1 |
7219140 | Marl et al. | May 2007 | B2 |
7293077 | Teo et al. | Nov 2007 | B1 |
7328256 | Taoyama et al. | Feb 2008 | B2 |
7392034 | Westman et al. | Jun 2008 | B2 |
7408882 | Abdo et al. | Aug 2008 | B2 |
7467198 | Goodman et al. | Dec 2008 | B2 |
7487230 | Gu et al. | Feb 2009 | B2 |
7558846 | Gu et al. | Jul 2009 | B2 |
7562393 | Buddhikot et al. | Jul 2009 | B2 |
7602756 | Gu et al. | Oct 2009 | B2 |
7627653 | Taoyama et al. | Dec 2009 | B2 |
7630341 | Buddhikot et al. | Dec 2009 | B2 |
7640340 | Stapp et al. | Dec 2009 | B1 |
7640546 | Zarenin et al. | Dec 2009 | B2 |
7647203 | Herz | Jan 2010 | B1 |
7676690 | Bucher et al. | Mar 2010 | B2 |
7788656 | Harper | Aug 2010 | B2 |
7810148 | Ben-Shacher et al. | Oct 2010 | B2 |
7978714 | Rao et al. | Jul 2011 | B2 |
8045000 | Davidson et al. | Oct 2011 | B2 |
8069217 | Lo et al. | Nov 2011 | B2 |
8300056 | Nugent et al. | Oct 2012 | B2 |
8412798 | Wang | Apr 2013 | B1 |
20040223469 | Bahl et al. | Nov 2004 | A1 |
20050286476 | Crosswy et al. | Dec 2005 | A1 |
20060291434 | Gu et al. | Dec 2006 | A1 |
20070165579 | Delibie et al. | Jul 2007 | A1 |
20070294368 | Bomgaars et al. | Dec 2007 | A1 |
20080016491 | Doepke | Jan 2008 | A1 |
20080019333 | Kharia et al. | Jan 2008 | A1 |
20080162698 | Hopen et al. | Jul 2008 | A1 |
20080201751 | Ahmed et al. | Aug 2008 | A1 |
20080301794 | Lee | Dec 2008 | A1 |
20090019492 | Grasset | Jan 2009 | A1 |
20090106394 | Lin et al. | Apr 2009 | A1 |
20090303973 | Patil | Dec 2009 | A1 |
20100036955 | Hopen et al. | Feb 2010 | A1 |
20110107379 | Lajoie et al. | May 2011 | A1 |
20110145418 | Pratt et al. | Jun 2011 | A1 |
20110145821 | Philipson et al. | Jun 2011 | A1 |
20120081382 | Lindahl et al. | Apr 2012 | A1 |
20120084798 | Reeves et al. | Apr 2012 | A1 |
20120236796 | Lazaridis | Sep 2012 | A1 |
20120307141 | Millet et al. | Dec 2012 | A1 |
20120311329 | Medina | Dec 2012 | A1 |
20130024545 | Sheppard et al. | Jan 2013 | A1 |
20130067550 | Chen et al. | Mar 2013 | A1 |
20130231146 | Mathias | Sep 2013 | A1 |
Number | Date | Country |
---|---|---|
2341523 | Mar 2000 | GB |
WO 2011133908 | Oct 2011 | WO |
Entry |
---|
Rue Liu, “Iomega Home Media Hard Drive Cloud Edition Review—SlashGear”, Jun. 2011, SlashGear, http://www.slashgear.com/iomega-home-media-hard-drive-cloud-edition-review-14156840/. |
Guy McDowell, “How Does a Router Work”, Oct. 2009, http://www.makeuseof.com/tag/technology-explained-how-does-a-router-work/. |
Rue Liu, “Iomega Home Media Hard Drive Cloud Edition Review—SlashGear”, Jun. 2011, SlashGear. |
Guy McDowell, “How Does a Router Work”, Oct. 2009. |
Craig Ellison, “Iomega Home Media Network Hard Drive—Cloud Edition Reviewed”, Mar. 2011, Applicant's admitted prior art. |
Ellison, Craig (Mar. 29, 2011) “Iomega Home Media Network Hard Drive—Cloud Edition Reviewed” SmallCloudBuilder.com http://www.smallcloudbuilder.com/storage/reviews/311-iomega-home-media-network-hard-drive-cloud-edition-reviewed. |
Malik, Om (May 22, 2009) “How Pogoplug Works” gigaom.com http://gigaom.com/2009/05/22/how-pogoplug-works/. |
Mldonkey (Oct. 5, 2010) “WhatFirewallPortsToOpen” mldonkey.sourceforge.net http://mldonkey.sourceforge.net/WhatFirewallPortsToOpen. |
Number | Date | Country | |
---|---|---|---|
20130067550 A1 | Mar 2013 | US |