Embodiments of the present disclosure relate generally to wagering games and, more particularly, to network gaming architectures, gaming systems, and related methods.
Global internet access has revolutionized electronic gaming, and in particular, participation in on-line gambling games and related websites offering such games. Such internet gaming platforms have enabled players to participate in gambling and other gaming events through personal computers or other electronic devices, wherever the player may be and at all times. Implementations of on-line gambling may include typical gambling elements, such as permitting one or more users to bet against the House in wagering games that are similar to those found in traditional casinos.
Many casinos have an on-line presence and offer on-line gambling operations. Such on-line gambling operations generally enable users to choose a wagering game, enter the wagering game by either downloading a computer application or through a web browser, place bets on one or more possible outcomes of the game, and win or lose money according to the outcome of the bets. With most on-line gambling applications, the House controls the computer application or web site through which a player bets. The House is generally in control of both managing the game and all associated financial transactions.
It is not surprising that security of such on-line gambling platforms is of utmost importance. Hackers may attempt to cheat and gain an unfair advantage in a variety of ways that would cause the House to lose significant sums of money by paying on bets that should not have been paid on, by allowing bets to be placed when the game outcome can be already be determined by unauthorized access, or by redirecting payments to parties that are not entitled to such payments. For example, a hacker may attempt to gain unauthorized access to view and in some cases even alter game information. In addition, individuals employed to work on the on-line gaming platform may be tempted to use their access to cheat the system.
Other considerations for on-line gambling platforms include, but are not limited to, concerns about the considerable resources used in complying with regulatory requirements, both for an original submission and for resubmissions when changes are made to a system, and, the highly variable demand (load) made on backend systems during game play.
a-9e are illustrations of a user interface of a game of three card poker in accordance with an embodiment of the present disclosure.
a-b are a flow charts illustrating methods enabling a play for fun game having the options of purchasing additional countable elements and/or purchasing additional assignment of players for a game in accordance with an embodiment of the present disclosure.
The terms “gaming,” “gambling,” or the like, refer to activities, games, sessions, rounds, hands, rolls, operations, and other events related to wagering games, where a wagering game may be a web game, casino game, card game, dice game, and/or other games of chance for which wagers may be placed by a player. The word “wager,” “bet,” “bid” or the like, refer to any type of wagers, bets or gaming ventures that are placed on games that involve, or whose outcome is at least partially dependent on, one or more random events. A wager may be placed on games whose outcome may have monetary or non-monetary value. Examples of the different kinds of games include games based on dice rolls, slot machines, or roulette wheels, which are games whose outcome is based on chance (one or more random events). Draw poker is an example of a game whose outcome is based partially on one or more random events, and partially on skill. Chess is an example of a game involving no random events. Points, credits, and other items of value may be purchased, earned, or otherwise issued prior to beginning the wagering game. In some embodiments, purchased points, credits, or other items of value may have an exchange rate that is not one-to-one to the currency used by the user. For example, a wager may include money, points, credits, symbols, or other items that may have some value related to a wagering game. Wagers may be placed in wagering games that are play for pay (aka play-for-pay) as well as play for fun (play for fun), as will be described in more detail below.
The wagering games supported by the gaming system 400 may be operated with real currency, virtual credits and/or countable elements. Countable elements are any one or more elements used to indicate amounts won or lost. For example, the real currency option may include traditional casino and lottery-type wagering games in which money or other items of value are wagered and may be cashed out at the end of a game session. The virtual credits option and/or countable elements may include wagering games in which credits (or other symbols, e.g., countable elements) may be issued to a player to be used for the wagers. Although credits may be won or lost, the ability of the player to cash out the credits may be prevented. In other words, while the credits may be purchased or otherwise awarded or made available to a player, the credits in a play for fun option may be limited to non-monetary credits in terms of the ability of the player to extract cash or goods or services of monetary value out of the wagering game. Systems that operate play for fun games may include issuance of free credits. In some embodiments, a limited number free credits may be issued in order to entice players to play the games. Credits may be won or lost, but credit balances may not be cashed out. In exchange for an action, e.g., identifying friends who may want to play, duration of play based on time or number of sessions, viewing and/or listening to an of advertisement or other audio/video presentation, the system may issue additional credits or achievable elements, described further below. Often, additional credits may be issued after a period of time has elapsed to encourage the player to continue or resume playing the game. The system may enable players to buy time, which triggers additional game credits to allow the player to resume play more quickly than waiting for a predetermined time period to pass. Objects of value may be awarded to play for fun players, which may or may not be in a direct exchange for credits. For example, the client may award a prize for a highest scoring play for fun player during a defined time interval.
a-b are a flow charts illustrating methods enabling a play for fun game having the options of purchasing additional countable elements and/or purchasing additional assignment of players for a game in accordance with an embodiment of the present disclosure. In the play for fun environment illustrated additional countable elements are awarded 1102 after a pre-set amount of time or game plays. The player may decide 1104 to purchase 1106 countable elements which are then shown 1110 in the game. In addition or alternatively, the player may continue to earn 1106 countable elements based on time and/or game plays. In another embodiment, decision 1104 is a choice to buy game time (game playing time), which is followed 1108 by the awarding of more game time which enables, triggers, or happens to trigger the awarding of addition countable elements. In another embodiment, decision 1104 is a choice to buy a number of additional game plays (as if the player had finished an additional number of individual game plays), which is followed 1108 by the awarding of more game plays which then enables, triggers, or happens to trigger awarding of addition countable elements
In another example, if a play for fun player wants one or more additional players for a game 1122, e.g., if a certain number of players are needed to start the game, or if additional players are wanted even if not necessary to play, several different embodiments may be used to involve further players in the game session. In one embodiment decision diamond 1122 allows a player to use previously earned achievable elements to decrease the waiting time to have one or more real or virtual players join the player's game. In another embodiment decision 1122 allows a player to purchase players, which may be one or more virtual players (i.e., one or more player position(s) in the game session played by a computer or the system), or pay an early entry fee for a real player who is waiting to join a game session. The game continues 1128 with the additional player(s). If the player chooses not to buy one or more additional players, play continues 1124 where the player waits for the passage of time, carries out additional game plays, or achieves enough countable elements, for example, after which game play with additional player(s) continues in box 1128.
A player may purchase assets using payment, virtual credits and/or achievable elements. Assets can include personalized asset data from the asset server 114, such as game play elements having a particular skin, theme, color, etc. In an embodiment the game provider provides pre-defined themes based on seasons/holidays, past-times, sports, characters etc. that may be made available for free or through purchase by currency or achievable elements, for example.
As described above, the player can be allocated achievable elements based on any of a variety of factors such as the number of game plays, number of game sessions, duration of playing, amount of bets, amount of winnings or losses (either virtual currency or real currency) of a player or group of players.
The gaming system 400 includes a gaming platform that establishes a portal for an end user to access a wagering game hosted by a game server 406 through a user interaction server 402. The user device 420 communicates with a user interaction server 402 of the gaming system 400 using a network 430. The user interaction server 402 communicates with the game server 406 and provides game information to the user. In some embodiments, a single user device communicates with a game provided by the game engine 406, while other embodiments may include a plurality of user devices 420 configured to communicate and provide end users with access to the same game provided by game engine 406. In addition, a plurality of end users may access a single user interaction server 402 or a plurality of user interaction servers 402 to access game server 406.
The user interaction server 402 communicates with the user device 420 to enable access to the gaming system 400. The user interaction server 402 allows a user to create and access a user account and interact with gaming server 406. The user interaction server 402 allows users to initiate new games, join existing games, and interface with games being played by the user.
The user interaction server 402 may also provide a client 422 for execution on the user device for accessing the gaming system 400. The client 422 provided by the gaming system 400 for execution on the user device 420 can comprise a variety of implementations according to the user device and method of communication with the gaming system 400. In one embodiment, the user device 420 connects to the gaming system 400 using a web browser and the client 422 executes within a browser window or frame of the web browser. In another embodiment, the client 422 is a stand-alone executable on the user device 420.
For example, the client 422 may comprise a relatively small amount of script (e.g., JavaScript), also referred to as a “script driver,” including scripting language that controls an interface of the client 422. The script driver may include simple function calls requesting information from the gaming system 400. In other words, the script driver stored in the client 422 may merely include calls to functions that are externally defined by, and executed by, the gaming system 400. As a result, the client 422 may be characterized as a “thin client.” As that term is used herein, the client 422 may be little more than a script player. The client 422 may simply send requests to the gaming system 400 rather than performing logic itself. The client 422 receives player inputs and the player inputs are passed to gaming system 400 for processing and executing the wagering game. In other embodiments, the client 422 comprises an executable rather than a script. As a result, the bulk of the processing of the game play is performed in the gaming system 400. The client 422 may receive intermediate data and final game outcome information from the gaming system 400 for displaying on the end user's computer after such is determined by the game engine 406.
In another embodiment, the client 422 implements further logic and game control methodology beyond the thin client described above. For example, the client 422 may parse and define player interactions prior to passing the player interactions to the gaming system 400. Likewise, when the client 422 receives a gaming interaction from the gaming system 400, the client 422 may be configured to determine how to modify the display as a result of the gaming interaction. The client 422 may also allow the player to change a perspective or otherwise interact with elements of the display which do not change aspects of the game.
The gaming system 400 also includes an asset server 404 which hosts various media assets (e.g., audio, video, and image files) that may be sent to the client 422 for presenting the various wagering games to the end user. In other words, in this embodiment the assets presented to the end user are stored separately from the client 422, and the client 422 requests the assets appropriate for the game played by the user. For example, the client 422 may call a function defined at the user interaction server 402 or asset server 404 which determines what assets are to be delivered to the client server 110 as well as how the assets are to be presented by the client 422 to the end user. Different assets may correspond to the various clients that may have access to the game engine 406 or to different games to be played.
The game server 406 is configured to perform game play methods and determine game play outcomes that are provided to the user interaction server 402 to be transmitted to user device 420 for display on the end user's computer. For example, the game server 406 may include game rules for one or more wagering games, such that the game 406 controls the game flow for a selected wagering game, as well as the determining game outcomes, pay tables, and other game logic. The game server 406 also performs random number generation for determining random game elements of the wagering game. The game server 406 is typically separated from the user interaction server 402 by a firewall or other method of preventing unauthorized access to the game server 406 from the general members of the network 430.
The term “firewall” as used herein encompasses conventional firewalls as well as other methods of preventing unauthorized access to a device. A firewall can be a bi-directional firewall, two separate firewalls each preventing unauthorized access to a device on separate sides of the firewalls, or a combination, for example. In the case where a “firewall” includes multiple firewalls, the firewalls may be located in physical proximity to each other or may be remote from each other.
As described below, with reference to
The user device 420 presents a gaming interface to the player and communicates the user interaction to the gaming system 400. The user device 420 may be any electronic system capable of displaying gaming information, receiving user input and communicating the user input to the gaming system 400. As such, the user device 420 can be a desktop computer, a laptop, tablet computer, set-top box, mobile device, kiosk, terminal, or other computing device. The user device 420 operates the client 422 for connecting to the interactive gaming system 100 as described above. The client 422 may be a specialized application or may be executed within a generalized application capable of interpreting instructions from the interactive gaming system 400, such as a web browser.
The client 422 may interface with an end user through a web page, an application (e.g., a smartphone or tablet application), or other computer program in order to access the gaming system 100. The client 422 may be illustrated within a casino webpage (or other interface) indicating that the client 422 is embedded into a webpage, which is supported by a web browser executing on the client device 420.
The gaming system 400 may be operated by different entities in one embodiment. The user device 420 may be operated by a third party, such as a casino, that links to the gaming system 400. Therefore, in some embodiments, the user device 420 and client 422 is operated by a different administrator than the operator of the game server 406. In other words, the user device 420 may be part of a third-party system that does not administer the game engine 120. In another embodiment, the user interaction server 402 and asset server 404 are provided by a third-party system. For example, a gaming entity (e.g., a casino) may operate the user interaction server 402 or user device 420 to provide its customers access to game content managed by a different entity. In some embodiments, the these functions are operated by the same administrator. For example, a gaming entity (e.g., a casino) may elect to perform each of these functions in-house, such as providing both the access to the user device 420 and the actual game content and providing administration of the gaming system 400.
The gaming system 400 also communicate with external account servers 410, optionally through another firewall. For example, the gaming system itself may not take wagers or issue payouts. In other words, the gaming system 400 may facilitate online casino gaming, but may not be part of a self-contained online casino itself. Instead, the gaming system 400 may facilitate the play of proprietary card game content owned and controlled by a company offering games and gaming products and services, such as Shuffle Master, Inc. Another entity (e.g., a casino) may operate and maintain its external account servers 410 to take bets and make payout distributions. The gaming system 400 may communicate with the account servers 410 to verify the existence of funds for wagering, and instructs the account servers 410 to execute debits and credits.
In some embodiments, the gaming system 400 may take bets and make payout distributions, such as in the case where administrator of the gaming system 400 operates as a casino. As discussed above, the gaming system 400 may be integrated within the operations of a casino rather than separating out functionality (e.g., game content, game play, credits, debits, etc.) among different entities. In addition, for “play for fun” wagering games, the gaming system 400 may issue credits, take bets, manage the balance of the credits according to the game outcomes, but may not permit payout distributions or be linked to play for fun client servers that permit payout distributions. Such credits may be issued for free, through purchase, or for other reasons, without the ability for the player to cash out. Such play for fun wagering games may be played on platforms that do not permit traditional gambling, such as to comply with jurisdictions that do not permit online gambling.
As described herein, the gaming system 400 may be configured using a distributed server architecture. For example, the game server 406 may include a plurality of servers (e.g., game rules server, deck server, game routing server, account server, asset server, etc.) that are logically separated to perform different functions for the wagering game. Additional features may be supported by the game server 406, such as hacking and cheating detection, data storage and archival, metrics generation, messages generation, output formatting for different end user devices, as well as other features and operations. For example, the gaming system 400 may include additional features and configurations as described in U.S. patent application Ser. No. 13/353,194, filed Jan. 18, 2012, and entitled “Network Gaming Architecture, Gaming Systems, and Related Methods,” the entire disclosure of which is incorporated herein by this reference.
The network 430 enables communications between the user device 420 and the gaming system 400. A network may also connect gaming system 400 and account server 410 (not shown). In one embodiment, the network 430 uses standard communications technologies and/or protocols. Thus, the network 430 can include links using technologies such as Ethernet, 802.11, worldwide interoperability for microwave access (WiMAX), 3G, digital subscriber line (DSL), asynchronous transfer mode (ATM), InfiniBand, PCI Express Advanced Switching, etc. Similarly, the networking protocols used on the network 430 can include multiprotocol label switching (MPLS), the transmission control protocol/Internet protocol (TCP/IP), the User Datagram Protocol (UDP), the hypertext transport protocol (HTTP), the simple mail transfer protocol (SMTP), the file transfer protocol (FTP), etc. The data exchanged over the network 430 can be represented using technologies and/or formats including the hypertext markup language (HTML), the extensible markup language (XML), etc. In addition, all or some of links can be encrypted using conventional encryption technologies such as secure sockets layer (SSL), transport layer security (TLS), virtual private networks (VPNs), Internet Protocol security (IPsec), etc. In another embodiment, the entities can use custom and/or dedicated data communications technologies instead of, or in addition to, the ones described above. Depending upon the embodiment, the network 430 can also include links to other networks such as the Internet.
Computer Architecture
The storage device 508 is any non-transitory computer-readable storage medium, such as a hard drive, compact disk read-only memory (CD-ROM), DVD, or a solid-state memory device. The memory 506 holds instructions and data used by the processor 502. The pointing device 514 may be a mouse, track ball, or other type of pointing device, and is used in combination with the keyboard 510 to input data into the computer system 500. The graphics adapter 512 displays images and other information on the display 518. The network adapter 516 couples the computer system 500 to a local or wide area network.
As is known in the art, a computer 500 can have different and/or other components than those shown in
The gaming system 400 may comprise several such computers 500. The gaming system 400 may include load balancers, firewalls, and various other components for assisting the gaming system 400 to provide services to a variety of user devices.
As is known in the art, the computer 500 is adapted to execute computer program modules for providing functionality described herein. As used herein, the term “module” refers to computer program logic utilized to provide the specified functionality. Thus, a module can be implemented in hardware, firmware, and/or software. In one embodiment, program modules are stored on the storage device 508, loaded into the memory 506, and executed by the processor 502.
Embodiments of the entities described herein can include other and/or different modules than the ones described here. In addition, the functionality attributed to the modules can be performed by other or different modules in other embodiments. Moreover, this description occasionally omits the term “module” for purposes of clarity and convenience.
Some portions of the detailed description are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps (instructions) leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic or optical signals capable of being stored, transferred, combined, compared and otherwise manipulated. It is convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. Furthermore, it is also convenient at times, to refer to certain arrangements of steps requiring physical manipulations or transformation of physical quantities or representations of physical quantities as modules or code devices, without loss of generality.
However, all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as “processing” or “computing” or “calculating” or “determining” or “displaying” or “determining” or the like, refer to the action and processes of a computer system, or similar electronic computing device (such as a specific computing machine), that manipulates and transforms data represented as physical (electronic) quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Certain aspects of the embodiments include process steps and instructions described herein in the form of an algorithm. It should be noted that the process steps and instructions of the embodiments can be embodied in software, firmware or hardware, and when embodied in software, could be downloaded to reside on and be operated from different platforms used by a variety of operating systems. The embodiments can also be in a computer program product which can be executed on a computing system.
The embodiments also relates to an apparatus for performing the operations herein. This apparatus may be specially constructed for the purposes, e.g., a specific computer, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a computer readable storage medium, such as, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for storing electronic instructions, and each coupled to a computer system bus. Memory can include any of the above and/or other devices that can store information/data/programs and can be transient or non-transient medium, where a non-transient or non-transitory medium can include memory/storage that stores information for more than a minimal duration. Furthermore, the computers referred to in the specification may include a single processor or may be architectures employing multiple processor designs for increased computing capability.
The algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Various general-purpose systems may also be used with programs in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatus to perform the method steps. The structure for a variety of these systems will appear from the description herein. In addition, the embodiments are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the embodiments as described herein, and any references herein to specific languages are provided for disclosure of enablement and best mode.
In addition, the language used in the specification has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the inventive subject matter. Accordingly, the disclosure of the embodiments is intended to be illustrative, but not limiting, of the scope of the embodiments, which is set forth in the claims.
While particular embodiments and applications have been illustrated and described herein, it is to be understood that the embodiments are not limited to the precise construction and components disclosed herein and that various modifications, changes, and variations may be made in the arrangement, operation, and details of the methods and apparatuses of the embodiments without departing from the spirit and scope of the embodiments.
In some embodiments, the client server 110 may not be part of the gaming system 100, in that the client server 110 may be operated by a different administrator than operates the other servers of the gaming system 100. In other words, the client server 110 may be part of a third-party system that does not administer the gaming system 100. For example, a gaming entity (e.g., a casino) may operate the client server 110 to provide its customers access to game content managed by a different entity. In some embodiments, the client server 110 may offer and/or provide access to content in addition to what is supported by the gaming system 100. As a result, the client server 110 may establish communication between the client and the gaming system 100, as well as the client and other content that is unrelated to the gaming system 100, including multiple different gaming systems that are not part of the gaming system 100. For example, a gaming entity may have a client server 110 that accesses game content from a plurality of different game administrators that provide access to different gaming systems (not shown).
It is also contemplated that in some embodiments, the client server 110 may be part of the gaming system 100, such as being operated by the same administrator as the gaming system 100. In addition, the client server 110 may be dedicated to access only game content that is supported by the gaming system 100. For example, a gaming entity (e.g., a casino) may elect to perform each of these functions in-house, such as providing both the access to the client server 110 and the actual game content and the organization, as well as providing administration of the other servers of the gaming system 100 as well.
The gaming system 100 includes a game routing server 112, an asset server 114, an output format server 116, a metrics server 118, a game rules server 120, a deck server 122, a deck database server 124, an archive server 126, a messages server 128, and an account server 130. Other servers 132 are also contemplated as being included within the gaming system 100. The various servers of the gaming system 100 may be configured to perform the described functions and communicate with each other in the manner that is described in more detail below. In addition, the various servers of the gaming system 100 may be organized in a plurality of different sub-systems that may group the servers according to similar levels of communication and security.
The gaming system 100 may include a first sub-system 101 and a second sub-system 103, such that the various servers may be organized and separated to communicate through a plurality of firewalls 102, 104. The first sub-system 101 may be configured to communicate with the client server 110 through the first firewall 102. For example, the first sub-system 101 may include the game routing server 112, the asset server 114, the output format server 116, and the metrics server 118. The second sub-system 103 may be configured to communicate with the first sub-system 101 through the second firewall 104. The second sub-system 103 may include the game rules server 120, the deck server 122, the deck database server 124, the archive server 126, the account server 130, the messages server 128, as well as one or more other servers 132. In other words, the first firewall 102 separates the client server 110 from the game routing server 112, the asset server 114, the output format server 116, and the metrics server 118.
The second sub-system 103 may be isolated from the client server 110 by the first sub-system 101. As a result, therefore, the client server 110 and the servers of the second sub-system 103 may be configured to communicate with each other only through the first sub-system 101 (and the first firewall 102 and/or second firewall 104, if provided). In other words, the second firewall 104 may further separate the game rules server 120, deck server 122, the deck database server 124, the archive server 126, the messages server 128, the account server 130, as well as other servers 132.
The various servers may be organized with respect to the first firewall 102 and the second firewall 104 in a variety of different combinations according to the different levels of security desired for each server. In other words, the specific organization of the servers with respect to the plurality of firewalls 102, 104 should not be viewed as limiting the scope of present disclosure unless specifically described as such. In addition, the gaming system 100 may include additional sub-systems (not shown) separated by additional firewalls (not shown). For example, a third sub-system, if provided, may be configured to communicate with the second sub-system 103 and this communication may be through a third firewall. In some embodiments, the third sub-system may include external accounts servers (not shown). In addition, more or fewer firewalls may be implemented.
As will be understood, therefore, the first sub-system 101 provides an interface (e.g., a gateway) through which the second sub-system 103 and optionally the third sub-system may communicate with the client server 110. The third sub-system is not shown in
The gaming system 100 provides gaming content and enables secure on-line gaming from the client server 110. In some embodiments, the gaming system 100 does not take wagers or issue payouts. In other words, the gaming system 100 may facilitate on-line casino gaming, but may not be an on-line casino itself. Instead, the gaming system 100 facilitates the play of proprietary card game content owned and controlled by a company offering games and gaming products and services, such as Shuffle Master, Inc. In such an embodiment, the client server 110 may interface with an end user through a web page, an application (e.g., a smartphone or tablet application such as those), or other computer program in order to access the gaming system 100. The client server 110 may be operated by a third party, such as a casino, that links to the gaming system 100 through the client server 110 via a network, such as the internet. As will be described in further detail below, the account server 130 may communicate with an external entity (e.g., a casino) that maintains end user accounts to take bets and make payout distributions. In such an embodiment, the gaming system 100 merely verifies the existence of funds for wagering, and instructs the external end user accounts to execute debits and credits. In some embodiments, the gaming system 100 may take bets and make payout distributions, such as in the case where administrator of the gaming system 100 operates as a casino. As discussed above, the gaming system 100 may be integrated within the operations of a casino rather than separating out functionality (e.g., game content, game play, credits, debits, etc.) among different entities. In addition, for “play for fun” wagering games, the gaming system 100 may issue credits, take bets, manage the balance of the credits according to the game outcomes, but may not permit payout distributions or be linked to play for fun client servers 110 that permit payout distributions. Such credits may be issued for free, through purchase, or for other reasons, without the ability for the player to cash out. Such play for fun wagering games may be played on platforms that do not permit traditional gambling, such as to comply with jurisdictions that do not permit on-line gambling.
In play for fun wagering games, several sources of income for the game host may be realized that do not involve wagering on game outcomes. This allows the games to be played by people in jurisdictions that do not allow wagering games on-line while providing entertainment for the player(s) and the potential for income to the hosting company or companies. In these embodiments, the system will provide a play for fun wagering game, where the wagers are made with strictly freely provided credits, symbols, or similar representations of something useable by the player to make a “wager” while playing. There is no monetary value associated with the credits; for example, there would be no fixed conversion rate between credits and $US. In one embodiment, they cannot be redeemed in any manner. In another embodiment credits may be redeemable for a prize of some kind; prize redemption embodiments may have prizes comply with the laws of the jurisdiction in which the player is located, and/or, may be based on the value of the prize to the game host.
What may be offered to a player are purchasable items to enhance game play, but have no direct relationship to the wager portion of the game. In one embodiment, players may purchase forms of time compressor (game play speedup). In card games, the game compressor may be to display card shuffling and hands dealt instantly at each stage of the game, rather than showing cards being shuffled and then dealt to a player one-by-one (or other relatively slow game actions). For roulette, the wheel spin time before the ball settles on a number may be reduced. For slot machines, the symbol spinning cycle may be reduced. For dice games, the “throw” of the dice may be shown as a result rather than as a graphical sequence of dice being shaken, thrown, and the rolling to a stop. Any or all steps could be shortened or eliminated. If the game requires a certain minimum number of players to play, a player may be offered a chance to buy other players (played by the system once bought) in order to allow the game to begin, or, because the player wants a certain number of players in a pool (i.e., the player prefers more than the number of players currently at the virtual table). If the game involves levels, the player may be allowed to buy levels until they get to the level they want to play. Levels may be skill levels, where a player buys their way on to a table of players at a certain skill level rather than always starting with beginners. Alternatively, if the game involves winning credits, the player may buy a level that is equivalent to having won a specified number of credits, without having to play the lower levels of the game. This helps or allows players to buy their way to the skill level they want to play at, without having to play through the lower skill levels first. Other embodiments may include buying more than the freely available number of credits, buying more credits during a game hand or session (ordinarily one would have to wait until the hand or session ended to get the free credits again), buy extra game pieces for certain games, etc.
In one embodiment, a system that has non-wager purchases that affect some aspect of a player's experience of the game play, such as the speed of certain game events, the ability to buy more credits over those provided for free play, or other options, will additionally be configured to allow any player to play entirely for free. Any player not having the money, or simply not wanting to pay for the play for fun experience, can always play the games. In this embodiment there will always be at least one, but may be more, ways to play for no-pay (free) in addition to each optional pay event. The optional pay events do not, therefore, change the pay-for-fun site into a play-for-money site. In addition, in some embodiments the underlying rules and random events for each game will be the same for either player type (free or enhanced with pay), while in other embodiments there may be some variability in the game rules depending on optional pay events. In some embodiments a site may have free-to-play games with purchasable options, and may further include a subset of games that may require an optional purchase event. The subset of purchasable games may include added side-bet games, higher-ante games, or other variants. The decision on which pay options are available may depend on the desires and needs of the target clientele, the jurisdictions in which players may be located, and other considerations.
In a further embodiment, any optional pay events will not change the underlying game rules nor the way random events are used during game play, nor any other aspect of the credit-awarding “wager” portion of the games. The optional pay events will only change other player interactions with the game site, such as overall speed of game events, game depictions on the screen, numbers of players, level of play, starting level, or other options. Non-paying players will always be able to play the same games, but will play through longer graphics or other visuals, go through levels one at a time, need to wait until a predetermined number of live players are available to start a new round or game session, etc. This type of embodiment may be used when there is a need or desire to show that any purchases made while playing on the play for fun site are clearly for non-wager options.
The client server 110 may be provided with a relatively small amount of script 111 (
The game routing server 112 is configured to communicate between the client server 110 and the other various servers of the gaming system 100. The game routing server 112 may be further configured to only permit external communication through the first firewall 102 to come from the client server 110. In other words, authorized client servers 110 may be the only outside servers that are authorized (e.g., white listed) through the first firewall 102 to communicate with the game routing server 112. In addition, the client server 110 may not be permitted to communicate directly with any of the other servers of the gaming system 100 other than the game routing server 112 or, in some cases, the asset server 114.
A primary function of game routing server 112 is to route game outcome information to the client server 110 via the first firewall 102 and to further communicate with the other servers of the gaming system 100. In other words, when the client communicates with the client server 110, the client server 110 communicates with the other servers of the gaming system 100 through the game routing server 112. At times, the client server 110 may communicate directly with the asset server 114 as will be described with more detail below. Although direct communication paths are shown in
Referring still to
The game routing server 112 receives inputs into the gaming system 100 from the client server 110. For example, the client server 110 may send data indicating which wagering game is to be played, and game inputs such as player moves (e.g., bets, card requests, holds, etc.). Such inputs may be routed to the appropriate location, such as the game rules server 120 associated with the appropriate wagering game. The game routing server 112 may be scaled (e.g., the number of servers may be increased) to handle different games as new wagering games are released and supported by the gaming system 100 with the addition of additional game rules servers 120. Thus, a plurality of game rules servers 120 may share the game routing server 112. As a result, the more games that are added to the system, the more the cost per player per game may be reduced because resources will be shared among games. Also, as the number of clients and client servers 110 increase the number of game routing servers 112 may be increased. This approach of scaling individual servers according to need for that particular function is unlike that of conventional gaming systems, which tend to duplicate server resources for individual games (e.g., a Texas Hold 'Em variant, blackjack, etc.), which may result greater equipment and hosting expenses.
The game rules server 120 includes game rule information for at least one wagering game stored thereon. The game rules server 120 may be thought of as the game engine that controls the order of game play. For example, game rule information may include the game rules of a particular wagering game and the various stages of play. For example, the game rules include the number and order of cards to be dealt to various positions, such as the different player positions, common card positions, dealer card positions, whether cards may be shown, etc. The game rules may further include the relative ranking of hands in a card game (e.g., poker), whether the player hand is played against a dealer hand or against pay tables, and the pay tables themselves that are used to determine the amount of a payout award. In addition, the game rules may further include wager requirements such as whether wagers are mandatory or optional, the relative size of the wagers, the wager election choices, a comparison of the wager amounts made to table limits, and the like. Through the game rules server 120, the game rules ultimately determine whether the end user wins or loses, while the game routing server 112 determines what to do with such information.
As discussed briefly above, each wagering game supported by the gaming system 100 may have at least one different game rules server 120 associated therewith. In other words, in some embodiments, a set of game rules for any one game may be administered on the game rules server 120. For example, there may be at least one game rules server 120 for blackjack, at least one game rules server 120 for a Texas Hold 'Em variant, and so on. Each game rules server 120 may include game rules dedicated to a specific wagering game and does not comingle such information used by other games. Of course, the scale of the gaming system 100 and the complexity of the games may require a plurality of game rules servers 120 that are dedicated to a particular wagering game. In other embodiments, multiple sets of game rules are administered by the same game rules server 120. In other words, sets of game rules for a plurality of games may be administered by the same game rules server 120. For example, the same game rules server 120 may administer a set of game rules for the Texas Hold 'Em variant as well as a set of game rules for blackjack.
The deck server 122 is configured to provide the processing for generating the random game pieces (i.e., game piece indication) from a defined set of game pieces for the wagering game. For example, the deck server 122 includes a random number generator (RNG) 123 that is configured to randomly generate the game pieces in response to requests made from the game rules server 120 according to the rules of the wagering game being played by the end user. The random number generator 123 may be hardware based, software based, or a combination thereof. The term “random” also includes semi-random and pseudo-random events. The random number generator 123 employed shall pass a sufficient test of randomness. For example, The random number generator 123 may be created at a low-level programming level in order to sufficiently reduce or avoid language specific bugs. In operation, the random numbers may be appropriately seeded, and requests for numbers may not be done sequentially in order to ensure that the number pass an appropriate threshold test for randomness. The deck server 122 may compile a virtual deck of cards by indexing all the possible card values for a desired deck, and selecting at random one of those cards and placing it in a “shuffled” virtual deck. This process of card selection may be continued until all of the virtual cards have been placed in the virtual deck. The random number generator 123 may be implemented through one of a number of public domain and licensable random number generation algorithms, such as the CONVERSE Pseudorandom Number Generator (PRNG) developed by the University of Illinois at Urbana-Champaign of Champaign. Another example is the Park-Miller “minimal standard” PRNG, developed by Stephen K. Park and Keith W. Miller. Other methods are contemplated for ensuring that the random number generator generates a random number that passes the appropriate standard for randomness. In addition, it is recognized that standards for randomness may change over time, and that additional random number generators 123 may be developed for use with the gaming system 100.
The term “deck” is used because many common wagering games employ the use of playing cards, such as poker, Texas Hold 'Em variants, blackjack, among others. As discussed above, a non card-based game may be played that is supported by the gaming system 100. Thus, the term “deck” is not to be interpreted as requiring card deck information unless specifically stated to have such according to the game rules of the specific wagering game to be played. As the gaming system 100 includes an on-line gaming platform, the randomly selected game pieces may be thought of as virtual game pieces, such as virtual cards, virtual dice, virtual wheel positions, etc. Thus, the deck server 122 is configured to output a game piece indication which may comprise the identifier of a virtual card (e.g. the ten of hearts), a random number, one or more dice faces, a virtual wheel position, a number, a color, or the like, as well as combinations thereof. A “virtual shoe” may be referred to herein to describe the functionality of creating a virtual card deck and dispensing virtual cards as requested by the game rules server 120. In other words, the deck server 122 may generate a data file that represents the entire set of game pieces, and track the removal of cards delivered to the game such that the composition of the unused cards is also known at all times. This accounting function may prevent a card of a certain rank and suit from being dealt into the game so that the mathematics of the game is identical to a live card game and is not altered.
Using the example of a card-based game, the random number generator 123 may be used to generate one or more numbers that is used to select the card (or cards) from among the set of cards. One or more numbers may select the number and the suit of the cards. In other words, the deck server 122 serves the function of a virtual shoe to create the deck, and to hold and administer the card data for the wagering game. For example, such card data may include the initial number of cards in the set, the current number of cards in the set, the rank and suit of cards that have been removed from the set and dealt into the wagering game, the number of special cards such as promotional cards inserted into the set, the number of standard cards removed from the set to construct a special set (e.g., for the Spanish 21 game, Canasta, etc.), the number and color combination of hands dealt, the number of cards dealt to each player, the number of players in a round, etc. For poker variants, the set of cards is generally a standard deck of fifty-two cards having four standard suits. If desired, one or more jokers may be included. Blackjack games may be played with one or more combined decks of cards belonging to the set of cards. Common examples of blackjack games include one, two, four, six, or eight decks of cards. Baccarat is usually played with six or eight decks of cards belonging to the set. In the example of a non card-based game (e.g., roulette), the random number generator 123 may generate a number that is used according to the game rules of that wagering game. In creating the deck and administering the wagering game, or otherwise randomly generating the game pieces, the data may be encrypted and stored in the deck database server 124, as described below.
The deck server 122 and the game rules server 120 are separate and distinct servers. As a result, the card deck data is segregated from the game rules data on different servers. In addition, the deck server 122 and the game rules server 120 may be separated to have different access privileges to different sets of employees. Doing so may increase the security of the gaming system 100 as it limits the chances that a single employee has access to both sets of information associated with the game rules server 120 and the deck server 122. Separating the game rules data and the deck data into different servers further adds another level for a hacker to penetrate in order to obtain both sets of data during game play.
Data that is stored in the deck server 122 may be encrypted and is sent to the game rules server 120 in encrypted form, where it is decrypted and used by the game rules server 120. The encryption provides a higher level of security to the gaming system 100 and is described in more detail below. In addition, data generated by the deck server 122 may be withheld from the game rules server 120 until such information is required for the determination of the game outcome, at certain intermediate game determinations, or at a time where it is required to make such information known to the end user.
An example of a wagering game supported by the gaming system 100 is a Hold 'Em poker variant game (also referred to as “Ultimate Texas Hold 'Em” ®) as described in U.S. patent application Ser. No. 11/156,352, filed on Jun. 17, 2005, and published as U.S. Patent Publication No. US 2006/0284376 A1, the entire disclosure of which is incorporated herein by this reference. In such an Ultimate Texas Hold 'Em game, there may be multiple rounds of betting, and multiple steps of card distribution and revelation of cards to the player. The gaming system 100 may be configured to wait to transfer intermediate game information, such as additional card rank and suit information from the deck server 122 to the game rules server 120 and/or the game routing server 112 on an as-needed basis. Additional game information may include, but is not limited to, extra wagers made, decisions to withdraw a wager, decisions to buy a card, decisions to fold, set a hand, a selection of a multiplier, a decision to participate in a bonus event, decisions to take hit cards, roll dice, spin wheels, activate a virtual shuffler to dispense more cards, exchange all or part of a hand with new cards, and any other decision that may be made during play of a wagering game and before conclusion of play.
As cards (or other game pieces) are needed, the game rules server 120 may request them. For example, the game rules server 120 may verify that the appropriate wager has been placed before requesting the next set of information. For example, after confirming an initial wager, the gaming system 100 deals an initial partial hand of cards to each player, whereupon the player may be asked to place another wager prior to receiving a full hand of cards. After receiving verification that the additional wager has been made, additional card data is provided to the game rules server 120. Thus, a game may require a first wager prior to the game routing server 112 delivering partial hand information in a card game to the game rules server 120, or to the client via the client server 110 according to the rules of the wagering game. The partial hand information may be considered intermediate game information. The game may also require information indicating a second wager has been made before delivering additional card information to complete the hand. This additional card information may also be considered intermediate game information.
Some of the intermediate game information may be withheld from the client server 110 as well as the game rules server 120 until all wagers have been completed and the withheld information is needed for the final game outcome determination. In addition, even if a person were to access (e.g., hack) the client server 110 or the game rules server 120 prior to that time, the person would not have access to that card information. As a result, cheating may be more difficult for such unauthorized users. Upon receiving confirmation that the game outcome (or an appropriate intermediate step) to be determined, the game rules server 120 may request the card information regarding the intermediate game information. Preventing the transmission of intermediate game information to the game rules server 120 prior to receiving a wager confirmation ensures that the gaming system 100 does not make a payout on a wager that was not received, and further reduces the risk of the game results being viewed and wagered upon if a person successfully hacks into the client server 110 or even the game rules server 120 for the purpose of retrieving card information or game results in advance of making a wager.
The asset server 114 includes asset data that is to be retrieved and used in the presentation of the wagering games on the client interfaces and may be similar to asset server 404 in
The output format server 116 is configured to format the game data, wagering data, and graphics files to accommodate different end user devices of the client such that the client receives all data in a format that the client can process. For example, end user devices may include personal computers (PCs), smart phones (e.g., an iPhone, Android, Blackberry, etc.), laptops, tablets, gaming machines, and other electronic devices that may communicate with the client server 110 for a user to play a wagering game. The output format server 116 may detect the type of end user device, as well as the operating system, and configure the data as appropriate for the client to process.
The metrics server 118 is a business intelligence control system that analyzes usage of each server of the gaming system 100, enables data mining, generates reports, and detects system weaknesses and/or system failures. Each of the various servers of the gaming system 100 may communicate with the metrics server 118. The client server 110 may also communicate with the metrics server 118 regardless of whether or not the client server 110 is part of the gaming system 100. Each of the various servers self report information regarding its actions to the metrics server 118. For example, the client server 110 may send information regarding its actions to the metrics server 118. For example, the client server 110 may send information of actions such as “began load,” “load complete,” “started,” and “ended action” along with payload data containing the time started, system specifications, and any other information that a business intelligence group may deem relevant. As another example, the game rules server 120 may self report information regarding its actions at the end of each hand, such as reporting the game outcome along with payload data like the amount wagered, the amount won, any bonuses, and any other information the business intelligence group may deem relevant. The other various servers of the gaming system 100 may likewise self report information regarding their actions. The data stored by the metrics server 118 may be mined to generate reports for review by the business intelligence group. Such reports may be available on demand, or according to a set schedule.
The deck database server 124 is configured to receive and store game piece indications (e.g., deck data) from the deck server 122 to maintain an historical record. Thus, the deck database server 124 may communicate directly with the deck server 122 without routing through the game routing server 112. The deck data that is stored in the deck database server 124 may be data that is desired to persist during the operation of the wagering game or that is not resolved in a single client communication. For example, in a Texas Hold 'Em variant game, multiple turns are performed prior to finishing a game. Deck data from intermediate turns may be stored in the deck database server 124. The deck data stored in the deck database server 124 may be analyzed, as a security measure. For example, the client server 110 may want a running report confirming that each virtual shoe used to deal blackjack was verified as having a complete set of cards at the beginning of the deal, that the correct cards remain in the virtual shoe after the cut card appears, and that the dispensed cards equal the composition of the set of cards used by the virtual shoe. The deck data stored in the deck database server 124 may be stored independently from deck data stored elsewhere in the gaming system 100. The deck database server 124 may also be used to retain card information (e.g., card sets, card usage, etc.) from current or previous rounds of play to verify jackpot hands. This card information may also be transferred to the archive server 126 described below.
The messages server 128 is configured to store a list of messages for display to the end user, and send the appropriate message to the client server 110 upon request. Examples of system messages for display to end users may include an indication that a particular wager made was not placed, unavailable, is deficient, an indication regarding the status of the game, that an award has been earned, as well as other messages. The various servers of the gaming system 100 may request that messages be sent to the client. The game routing server 112 may process these message requests, route the message requests to the messages server 128, and receive the appropriate messages. The game routing server 112 may determine when to deliver the messages to the client server 110, such as prioritizing the transmission of a plurality of received messages to ensure that critical messages are transmitted first.
The account server 130 includes data such as user information (e.g., user names, passwords, email address, other user information, etc.), user validation (e.g., logging in, logging out, timing out, etc.), as well as user financial information (e.g., account balance, currency conversion, credits, debits, etc.). Account server 130 may be similar to account sever 410 described above with reference to
The account server 130 may cache certain types of player data for repeat access. For example, basic information that can uniquely identify a player might be stored for a period (e.g., days). The account balance of the external account may not be cached, and may be retrieved on demand at each wager.
The archive server 126 may include various data collected from the gaming system 100. For example, the deck data generated in the deck server 122 may be stored in an archived deck database of the archive server 126 after a full wagering game is resolved. Because the full wagering game is completed, the deck data stored in the archive server 126 may be unsecured. For example, the deck data may be decrypted and stored in the archive server 126 along with other game data. The archive server 126 may be selectively accessible to customer service and business intelligence employees. As an example, if a customer service representative receives a call, they may need unsecured access to verify and check the deck data and the game data to see if there was a mistake in the game play, and resolving player and/or casino client payout disputes. The data stored in the archive server 126 may be held independently of any corresponding data held in other parts of the gaming system 100. In other embodiments, the data stored in the archive server 126 may be secured.
The archive server 126 may also perform post processing of the deck data to detect cheating by comparing deck data stored in the archive server 126 with deck data stored in a secured location, such as the deck server 122 or the deck database server 124. The archive server 126 may also have the ability to call for “shift keys” from each of the servers of the gaming system 100, and in the absence of receiving the keys from the other processors (indicating an acceptable game state), the archive server 126 may shut down the gaming system 100 as a further security measure. Arrows 127 are shown to indicate that the archive server 126 may communicate with each of the servers of the gaming system 100.
Other servers 132 are also contemplated that may be part of the gaming system 100. An example of such another server 132 includes a social server. A social server may be configured to receive information regarding the game outcome and share that information with a social media platform (e.g., Facebook, Google Plus, Twitter, etc.). For example, if an end user wins a poker hand, that information may be posted on the end user's Facebook wall. Another example of another server 132 is a player's club server. A player's club server may credit the end user with rewards such as reward points for certain events, such as frequent gaming.
As discussed above, the client server 110 may be a “thin client.” As that term is used herein, the client server 110 may be little more than a script player. The client server 110 may simply send requests to the gaming system 100 rather than performing logic itself. In other words, the script stored in the client server 110 may merely include calls to functions that are externally defined. While the client may receive player inputs, the inputs are merely passed on to the game routing server 112, and the bulk of the processing of the game play is performed in the game rules server 120 and the deck server 122 described more fully below. The client may receive intermediate data and final game outcome information to display after such is determined by the game rules server 120. In addition, the externally defined functions may determine what information is displayed by the client as well as how it is displayed. Also, the assets are stored separately from the client server 110 on the asset server 114, which the client server 110 downloads while running the script. As a result, if certain features and displays are desired to be changed, the administrator of the gaming system 100 may do so without needing access to each and every client server 110 that may access the gaming system 100. As a result, modifications to the gaming system 100 may be done more efficiently, particularly for embodiments that include a third party entity that runs the client server 110 as a business partner with the administrator of the gaming system 100.
General operation of the gaming system 100 will now be discussed. The script for the client may be initiated, such as by being embedded in a webpage, opened by a computer file, opened as an application on a mobile device, etc. The end user interfaces with the client server 110 to play the wagering game. As discussed above, the script driver stored in the client server 110 enables the client server 110 communicate with the gaming system 100 to begin a wagering game. The client server 110 may initiate a game by communicating with the game rules server 120 through the game routing server 112. In response to initiating the desired wagering game, the script driver further enables the client server 110 to receive asset files (e.g., images, video, audio, etc.) from a game library in the asset server 114, and to transfer the corresponding asset files to the client server 110 to be presented by the end-user's game display. As an example, the client server 110 may inform the game routing server 112 that a game is to be initiated. The game routing server 112 may query the asset server 114 to determine what assets are needed to run the desired wagering game and return the asset list to the client server 110. The client server 110 may receive an asset list from the game routing server 112 for the particular wagering game selected. The client server 110 may request the assets directly from the asset server 114 according to the asset list provided. Given such an asset list, the game routing server 112 may cache the asset list for future use if contacted by the client server 110 or another client server 110 to initiate another wagering game of the same type.
Once set up of the wagering game is complete, the client server 110 may communicate to the game routing server 112 that the wagering game is ready to begin. The end user may play wagering game according to the game rules stored in the game rules server 120. As discussed above, the game routing server 112 may route information between the client server 110 and between the various servers of the gaming system 100. For example, the end user may input information (i.e., press buttons on the display) that communicate to the game routing server 112 the desired actions. As a thin client, the client server 110 may not have the logic to know what the actions mean, just that a certain button is selected. The game rules server 120 is configured to interpret that information for the particular wagering game being played. Also, as discussed above, the game rules server 120 and the deck server 122 communicate to request the random game pieces according to the game play as defined in the game rules of the wagering data stored in the game rules server 120. The random game pieces (e.g., deck data) may be shared with the game rules server 120 and the client server 110 at the appropriate times according to the game play, wagers, and other factors. Accordingly, the game rule data and game outcome data are kept separate and not accessible without authorization.
As an example of game play, the game rules server 120 may include a plurality of different states that are moved between depending on the game. A first state may include the selection of the wagering game to be played. The next state may be to wait for the bet to be placed. If it has not done so already, the account server 130 may communicate with the external accounts to verify the funds for a player (i.e. an end user) are available to be bet. After the bet is placed, a game piece (e.g., such as one or more cards) may be issued to the player. Depending on the specific game rules, additional bets may be made and intermediate game pieces may be issued. Another state may be to do a final verification of the bets for sufficient funds for the player, after which the final game pieces may be sent to the game rules server 120 and the game outcome may be determined. Credits or debits are made to the end user's account through the account server 130 depending on the outcome of the wagering game and the bet and/or additional bet placed by the end user.
The gaming system 100 includes a plurality of different server components, each serving a separate function. The gaming system 100 is also separated in different levels of sub-systems 101, 103 that have limited communication there between. For example, communication from the client server 110 to the servers of the second sub-system 103 may occur through the game routing server 112 adding an extra level (and extra firewall) of security to the more sensitive components of the gaming system 100, such as the game rules server 120, the deck server 122 and the account server 130. These sensitive components of the gaming system 100 are, therefore, isolated from the client server 110, and any attempts that may be made to gain unauthorized access to the second sub-system 103 via the client server 110, also require passing the security measures implemented for the first sub-system 101. Therefore, the risks of an anomaly caused by an intruder being undetected may be reduced because an intruder may need to access multiple servers undetected in order to successfully hide any alterations made to one of the servers (such as the deck server 122, the game rules server 120, or the account server 130).
In addition to the security benefits described above, embodiments of the present disclosure may result in cost benefits as well. For example, scaling of the gaming system 100 may be performed in a more efficient manner according to the embodiments of the present disclosure. By separating the data and functions performed into separate servers, some of the servers may be duplicated to increase the scale of the gaming system 100 without the need to duplicate or replace other servers having other functions. For example, the game rules server 120 may be duplicated as additional games are added to the gaming system 100, as additional client servers 110 are added to the gaming system 100, or when additional players access the gaming system 100. On the other hand, other system servers may not require scaling (e.g., duplication) at the same time the game rules server 120 demand increases. As another example, changing the assets stored on the asset server 114 may be accomplished with only minor modifications (if any) to the other servers of the first sub-system 101 (such as updating the list of assets available), and without any of the servers of the second sub-system 103 requiring modification.
Servers may also be scaled at different rates. For example, the account server 130 may need to increase in scaling prior to the need to increase the scaling of the asset server 114. As another example, as different end user devices are developed, the output format server 116 may require reconfiguration, but not the balance of the gaming system 100. Scaling may occur as new features or information are changed by the administrator. Increasing and decreasing the scaling of the individual servers of the gaming system 100 may also be performed as a result of a need to keep up with the changing demand during player usage of the gaming system 100. Conventional approaches that essentially combine functions of all of the above servers into a single non-separated server may result in unnecessary duplication of data as the system is scaled to meet demand.
It is contemplated that embodiments of the present disclosure include architectures wherein at least some of the functionality of the various servers may be combined. Doing so, however, may at least partially reduce some of the efficiencies of scalability described above. An example of such includes a server that at least partially combines the functionality of two or more of the metrics server 118, the messages server 128, and the account server 130. Another example includes a server that at least partially includes the functionality of two or more of the game routing server 112, the game rules server 120, and the output format server 116.
In addition, another method of segregating data and functions into a plurality of different servers may include segregation of servers by whether or not the data or software code is regulated by gaming regulation authorities. Such segregation may reduce costs associated with satisfying regulatory requirements over time.
As discussed above, the gaming system 100 may include wagering games on a play for pay basis, wherein the gaming system 100 manages accounts (whether internal or external to the gaming system 100) that are adjusted according to the game outcome, and that permit a player to cash out. In some embodiments, the gaming system 100 may include wagering games on a play for fun basis, wherein the gaming system 100 manages accounts (whether internal or external to the gaming system 100) that are adjusted according to the game outcome, and that do not permit a player to cash out. For example, a player may be issued (e.g., through purchase) credits (or another symbol) that may be used to place wagers during the wagering game. During game play, the credits may be increased or decreased according to the game outcome. As the credits expire, the player may need additional credits before continuing additional play. The additional credits may be purchased or issued through other methods, as described above.
The play for pay feature and the play for fun feature may be at least partially integrated into the same gaming system 100. In other words, the gaming system 100 may be configured as a dual-purpose internet platform such that the various servers (e.g., game routing server 112, game rules server 120, deck server 122, etc.) of the gaming system 100 may be shared by client servers 110 simultaneously running play for pay and play for fun wagering games. The dual-purpose internet gaming platform is configured to run a play for pay wagering game and a play for fun wagering game according to an at least partially integrated architecture that manages player accounts. The play for pay wagering game enables a user to cash out from the player accounts, and the play for fun wagering game does not enable the user to cash out from the player accounts. Partial integration means that at least two of the servers of the gaming system 100 are shared for performing play for pay and play for fun features. For example, the game rules server 120 and the deck server 122 may be used to perform both play for pay and play for fun features. In some embodiments, full integration may be achieved for all servers of the gaming system 100 to perform play for pay and play for fun features. Of course, in some embodiments, the play for pay and the play for fun features may have their own separate gaming systems 100. In other words, each gaming system 100 may be configured as a single-purpose platform to run the play for pay and the play for fun features, if both sets of features are present. Other embodiments may include at least a partial integration of gaming systems 100 that run both play for pay and play for fun features, such that one or more servers are shared.
In some embodiments, the client servers 110 that run the play for pay features of the dual-use internet platform may be separate from the client servers 110 that run the play for fun features of the dual-purpose platform. For example, the dual-purpose internet gaming platform may receives function calls from different client servers 110 to run the play for pay wagering game and the play for fun wagering game. In other embodiments, the client servers 110 that run the play for pay and the play for fun features may be the same. For example, the client servers 110 may be configured to send functions calls associated with both the play for pay wagering game and the play for fun wagering game from the same client server 110.
As discussed above, the client server 110 may communicate with the servers of the first sub-system 101, such as through the first firewall 102. For example, the client server 110 may be authorized to communicate with the game routing server 112, the asset server 114, the output format server 116, and the metrics server 118, whereas other servers may not be authorized for such communication. The asset server 114 may receive requests from the client server 110 for delivering assets to the client as discussed above. The game routing server 112 may receive instructions from the client server 110 related to playing a particular wagering game supported by the gaming system 100B. Communication from the game routing server 112 back to the client server 110 may flow through the output format server 116, which may be configured to prepare the data in an appropriate format to be processed by the end user device coupled with the client server 110. The client server 110 may include a client program embedded in a web page (e.g., casino web page) that is operable in a web browser. The client program may be supported by an inline floating frame (iFrame) or div elements. The client program may be written in an appropriate language such as HTML or Flash. As discussed above, the client server 110 may be provided with a relatively small amount of script 111 (e.g., JavaScript), also referred to as a “script driver,” including scripting language that controls the interfacing of the client server 110 with the gaming system 100. The client server 110 may be a thin client to provide the client with the ability to communicate with the gaming system 100 by sending requests to the gaming system 100 rather than performing logic itself. In other words, the script 111 may merely include calls to functions that are externally defined.
As further discussed above, the game routing server 112 may communicate with the servers of the second sub-system 103, such as through the second firewall 104. For example, the game routing server 112 may be authorized to communicate with the game rules server 120, the messages server 128, the account server 130, and possibly the other servers 132, whereas non-authorized servers may not be permitted for such communication. In some embodiments, the deck server 122 may not be configured to communicate directly with the game routing server 112. Instead, the game rules server 120 may be authorized to communicate with the deck server 122.
The other servers 132 shown in
The deck database server 124 and the archive server 126 are not shown in
The game routing server 112 may route information between the servers of the second sub-system 103 and the client server 110 during game play. The game rules server 120 may include rules for one or more wagering games, such as the Ultimate Texas Hold 'Em® (UTH) poker game, Three Card Poker (3CP) game, and other games. The wagering games may be card based, or non-card based as previously discussed. The game rules server 120 may communicate with the deck server 122 to generate the game piece indication as requested by the game rules server 120. The deck server 122 is configured to generate and output the game piece indication to the game rules server 120 in response to the request, such that the game piece indication is unavailable to the game rules server 120 until requested. In other words, the game piece indication information may not be available to the game rules server 120 until required for determining game outcome information at the desired time. For example, the deck server 122 may share the game piece indication information with the game rules server 120 after the game rules server 120 verifies that a proper wager has been made, and that advancing the game to the next decision by the player is appropriate, or that determining the final game outcome information is appropriate. Prior to such a determination, the deck server 122 may wait to provide such data to the game rules server 120. The verification of a proper wager may include the game rules server 120 communicating with the account server 130 to verify that the user account has sufficient funds to cover the wager.
As discussed above, the account server 130 may communicate with external accounts (e.g., casino account servers 140) that perform the actual maintenance of the user accounts, including executing debits, credits, and maintaining the funds of the end user. Thus, the casino account servers 140 and other external servers may be operated by one or more third parties to the gaming system 100B and may be considered part of a third sub-system 105, which may not be part of the gaming system 100B. In addition, the account server 130 may communicate with the casino account servers 140 and other external servers through a third firewall 106. In some embodiments, such as when a casino may operate the entire operations including the game play, content, client support, and account management and activity, the casino account servers 140 may be included as part of the gaming system 100B. The casino account servers and other external servers may be considered a third sub-system 105 of the gaming system 100B.
The unregulated servers 202, 203 may include one or more of the asset server 114, the output format server 116, the metrics server 118, the deck database server 124, the archive server 126, the messages server 128, the account server 130, and other servers 132, which are individually shown and described with respect to
The embodiments of the present disclosure are described in terms of the various servers of the gaming system 100 (
Each of the various server functions of the gaming system may be hosted by at least one of the plurality of servers 310, 320, 330, 340, 350; however, only a portion of the various servers of the gaming system is actually shown, for convenience. For example, only the game routing server 112, the asset server 114, the output format server 116, the metrics server 118, the game rules server 120, and the deck server 122 are shown. It should be understood, however, that the plurality of servers 310, 320, 330, 340, 350, as a whole, host the other servers of the gaming systems described above. In addition, each of the plurality of servers 310, 320, 330, 340, 350 are to be understood as being physical servers of the server architecture 300, whereas the servers (e.g., 112, 114, 116, 118, 120, 122, and others) of the gaming system are to be understood as “virtual servers.” That is, the server architecture 300 generates instances of the servers of the gaming system to have the relationships with each other as described above. For example, a first server 310 may generate virtual servers (i.e., instances) for the game routing server 112, the asset server 114, the output format server 116, the metrics server 118, while a third server 330 may generate virtual servers for the game rules server 120, and the deck server 122. The other servers (e.g., second server 320, fourth server 340, fifth server 350, and so on) may generate and host virtual servers for the other server functions of the gaming system. When the virtual servers are generated, the server architecture 300 does so according to the communication rules and logical separation set by the architecture rules. As a result, the various servers of the gaming system may share physical resources with each other while still maintaining the logical separation and communication relationships described above.
The specific configuration shown is to be understood as an example of one embodiment, and individual server functions may be combined within the same physical server according to any combination of the various servers of the gaming system. For example, even through the first server 310 is shown to generate virtual servers for the game routing server 112, the asset server 114, the output format server 116, the metrics server 118, another combination may include another combination such as the account server 130, the game routing server 112, the game rules server 120, the deck server 122, and the messages server 128. Thus, virtual servers for the first sub-system 101 may be combined with virtual servers for the second sub-system 103. Therefore, each of the physical servers 310, 320, 330, 340, 350 may generate and host virtual servers of any number or combination according to the capacity of the server.
During operation of the gaming system, the usage may vary such that one or more of the individual virtual servers may fluctuate in needed capacity. For example, at one point in time, the third server 330A may host a single instance each of the game rules server 120 and the deck server 122. At this point in time, the third server 330A may have unused server space 335 that is available for use, if needed. At another point in time, the usage of the gaming system may increase. The server architecture 300 may determine that another instance for each of the game rules server 120 and the deck server 122 is needed to meet the increased usage demand of the gaming system. As a result, the third server 330B may generate another instance for each of the game rules server 120 and the deck server 122 to occupy the unused server space 335 during that time of increased demand. As usage fluctuates over time, the server architecture 300 may increase and decrease the number of instances of the virtual servers for the gaming system to adjust in real time to the demands of the gaming system.
A second firewall is positioned between game routing servers 112, asset server 114, output format server 116, metric server 118 and messages server 128 and game rules servers 120, account server 130 and game database 135. The game database 135 includes rules and other game information for multiple games. The game database 135 can provide the game rules servers 120 with such gaming rules and information. In another embodiment the game rules server 120 is isolated by one or more additional firewalls (not shown) such that communication between the games rules server and the account server 130 and/or game database 135 is through a firewall. Some protection of the first and second firewalls can be described as a game routing server firewall which provides firewall protection for the game routing server from communication coming from any other source. For ease of discussion, the description of separate firewalls, e.g., Firewalls 1-4, can also be described as firewalls for a particular device, e.g., game rules servers firewall, deck server firewall. In embodiments, the game routing server firewall can also provide firewall protection for multiple devices within firewall 1 and firewall 2, e.g., asset server 114, output format server 116, messages server 128 and/or metric server 118. Similarly a game rules servers firewall can provide protection for multiple devices within firewall 2 and firewall 3. Similarly a deck server firewall can provide protection for multiple devices within firewall 3 and firewall 4, e.g., deck server 122 and deck database 124.
A third firewall is positioned between the game rules servers 120, account server 130 and game database 135 and the deck server 122 and deck database 124. This firewall separates the game rules servers 120 from the deck sever 122. As described herein, during online game play, the game rules servers 120 request random game pieces, e.g., cards, from the deck server 122. This third firewall helps prevent a single person from accessing both the game rules servers 120 and the deck server 122. This prevents a person with access to the game rules server 120 from accessing game pieces, e.g., cards, that haven't yet been “shown” to the player during a time where the unauthorized access could compromise the integrity of the game by, for example, communicating future card information to a player which may affect a player's bet. In another embodiment the deck server 122 is isolated by another firewall (not shown) from the deck database 124.
A fourth firewall is positioned between the deck server 122 and deck database 124 and the archive server 126. In an alternate embodiment another firewall is positioned between the deck server 122 and the deck database 124.
The architecture of these embodiments hinder the ability of a person from compromising the integrity of the game by having firewall protection between the various components of the online gaming system.
The type of firewall can include any conventional firewall system. For example, the firewalls can include whitelists that are lists or registers of entities, e.g., servers, from which communication will be accepted. For example, one or more game rules server 120 may be identified as being acceptable entities/devices with which a deck server 122 can communicate. Accordingly Firewall 3 will permit such communications. Similarly a game routing server 112 may be white listed by Firewall 2 to communicate with game rules server 120 which enables the game rules server 120 and the game routing server 112 to communicate. Other firewall strategies can be used in conjunction with or in place of whitelisting. For example, a blacklist is a list of entities that are not permitted to communicate through the firewall. Other firewall protection strategies can also be used in one or more of the firewalls.
As described above, separating the gaming functions into various components provides an additional scaling benefit. For example, the game routing server 112 may be scaled (e.g., the number of servers may be increased) to handle different games as new wagering games are released and supported by the gaming system 100 with the addition of additional game rules servers 120. Thus, a plurality of game rules servers 120 may share the game routing server 112. As a result, the more games that are added to the system, the more the cost per player per game may be reduced because resources will be shared among games. Also, as the number of clients and client servers 110 increase, the number of game routing servers 112 may be increased. This approach of scaling individual servers according to need for that particular function is unlike that of conventional gaming systems, which tend to duplicate server resources for individual games. The separation of functions in the present embodiments enables greater equipment and hosting cost savings since distinct elements can be scaled as necessary instead of requiring an additional complete system. Also scaling can be done to devices performing non-regulated functions, e.g., the asset server 114, easily and quickly since such a device need not go through an expensive compliance process performed by gaming authorities, e.g., governmental gaming regulating authorities.
In an embodiment, data encryption is also used to enhance the game integrity. In an embodiment, communications between the game routing servers 120 and the game rules servers 120 are encrypted. In another embodiment communication between the game rules severs 120 and the deck server 122 is encrypted. In another embodiment communication between the game deck sever and the archive server 126 is encrypted. In embodiments combinations of such encrypted communications can be used. In embodiments, communication between other devices is also encrypted, e.g., communication between the game rules servers 120 and account server 130.
The type of encryption can include any conventional encryption algorithm. In one embodiment communications between some or all of the devices shown in
In the signaling sequence shown in
The client script request 702F can be executed by the client server 110 to permit the player to perform the next game event. As described above, in an embodiment the client server 110 is a “thin client” so that it execute scripts instead of having rule information stored within. In the Three Card Poker example, as shown in
The game of Three Card Poker includes multiple modes of play, the player's Ante and Play bets are in competition with the player's hand against the dealer's hand. A Pair Plus bet is paid on a pay scale basis that the player hand will be a pair or better. A Six Card Bonus bet is paid on a pay scale basis based on a player using the player's three cards and the dealer's three cards to make the best possible five card poker hand. In some embodiments, the Ante, Pair Plus and Six Card Bonus are optional, but in some embodiments the Ante is mandatory. After all Ante, Pair Plus and Six Card Bonus bets are placed, three cards are dealt to each player and later to the dealer. Players that have placed the Ante bet have a choice to either fold or continue in the game by placing a Play bet equal to the Ante. In an embodiment the dealer's cards are then identified and the hands are then exposed and bets resolved. The dealer hand must be Queen high or better for the dealer hand to play. If the dealer does not play then there is no action on Play bets and Ante bets are paid 1 to 1. If the dealer does play the dealer and player hands are compared. If the player hand loses, both the Ante and Play bets lose. If the player hand wins, both the Ante and Play bets are paid 1 to 1. If the hands are tied then there is no action on the Ante and Play bets. The Pair Plus bet loses if the player has less than a pair and wins with a pair or better. The payoff applies regardless of the dealer hand as the Pair Plus bet is not in competition against the dealer hand.
After a bet has been entered the client server 110 sends 812 that game event, e.g., bets, 702G to the routing server 112. The router server 112 sends the game event 702H to the game rules server 120. The game rules server 120 performs a variety of functions, it confirms that legal bets were placed, e.g., that all bets are between the minimum and maximum bets were placed and that an Ante bet was placed. If an illegal bet was made the game rules server 120 will send an error message (not shown) to the routing server 112 which will send a script to the client server 110 in order to alert the player that a bet was not legal. The game rules server 120 may also contact an account server 130 to request 7021 confirmation that the player has sufficient funds to cover the bets. The account server 130 sends a message 702J back to the game rules server 120 with player account information. If there are not sufficient funds to cover the bet, the games rules server 120 will send a message (not shown) to the routing server 112 which will send a message/script to the client server 110 to provide an error message to the player.
If the game event, e.g., bets and account information, are legal then the game proceeds. The game rules servers 120 sends 814 a game process request 702K to the deck server 122. The deck server 122 can use a previously generated deck or can generate a deck in real-time and sends the game information, e.g., cards, that are necessary for the first portion of the game to the game rule server 120. For Three Card Poker, the deck server 122 sends card information 702L only for the three player “Up” cards. The deck server may also send pointers or references to the dealer's down cards, but, in embodiments, the values of the dealer's down cards are not sent to the game rules server 120 in order to reduce the ability of cheating/collusion. By not sending the value of the dealer's down cards there is no ability for a person with access only to the game rules server 120 to collude with a player since the only definitive information available at the game rules server is information that will be available to the player prior to the player making another decision.
That is, in embodiments, the values of game pieces generated in the deck server 122 are not sent to the game rules server 120 until after the game rules server 120 has received all user activity, e.g., bets, that can be done (placed) prior to receiving the value of the game pieces. For example, the deck server 122 does not send the value of the three player Up cards until after the user places all pre-deal bets, e.g., the Ante, Pair Plus and/or 6 Card Bonus bets in the Three Card Poker example. Similarly, the value of the dealers' cards are not sent from the deck server 122 to the game rules server 120 until the game rules server 120 has received all bets that are possible prior to receiving the value of the game pieces, e.g., the Play bet in the Three Card Poker example.
The game rules server 120 sends the card information 702L to the routing server 112 which sends the information to the client server 110. In the example shown in
After the player's cards are shown, the player has the option of playing, by placing a bet on Play in an amount equal to the Ante bet, or folding, in which case the player forfeits the Ante bet. As shown in
If 816 there are more game events, e.g., more bets, the process repeats beginning with step 812. With reference to
As shown in
In an embodiment, the game rules server 120 contacts the account server 130 to credit 702Q the player's winnings to the player's account and the account server 130 sends a confirmation message 702R. In other embodiments, the account server 130 is contacted after a player session of multiple games is complete. The account server 130 may be contacted at different frequencies in different embodiments.
Embodiments of the present disclosure include a gaming system for enabling secure on-line gaming through a client server. The gaming system comprises a gaming platform to communicate with a client server to support play of a wagering game by an end user/player. The gaming platform comprises a game rules server configured to administer a set of game rules for the wagering game, and a deck server to randomly select game pieces according to the set of game rules.
Another embodiment of the present disclosure includes a network gaming architecture. The network gaming architecture comprises a plurality of regulated servers that require validation from gaming authorities for reconfiguration of each of the plurality of regulated servers, and at least one unregulated server that does not require validation from gaming authorities for reconfiguration of the at least one unregulated server. The regulated servers include a game rules server storing game rules for a wagering game, and a deck server coupled with the game rules server. The deck server is configured to randomly select game pieces for the wagering game in response to requests received from the game rules server. The at least one unregulated server is configured to support an additional function of the gaming system.
Another embodiment of the present disclosure includes a client server for accessing a remote gaming engine, the client server comprising a computer readable medium having instructions stored thereon. When executed by a processor, the instructions cause the processor to establish a communication link with a remote gaming engine to execute a wagering game, and receive inputs from an end user and transmit the inputs to the remote gaming engine during play of the wagering game. The client server acts as a thin client to the remote gaming engine such that the remote gaming engine performs game play processing.
In another embodiment of the present disclosure, a method of enabling the play of on-line wagering games is disclosed. The method comprises providing code on an external client server to enable access to an on-line wagering platform having a game rules server and a deck server, receiving at least an indication of a placed wager from the external client server, randomly generating at least one number in the deck server, the at least one number used for selecting a virtual game piece for an on-line wagering game, determining a game outcome on the on-line wagering platform according to game rules stored in the game rules server, and transmitting the game outcome information to the external client server.
In another embodiment of the present disclosure, a dual-purpose internet gaming platform is configured to run both a play for pay wagering game and a play for fun wagering game according to an at least partially integrated architecture that manages player accounts. The play for pay wagering game enables a user to cash out from the player accounts, and the play for fun wagering game does not enable the user to cash out from the player accounts.
In another embodiment, a system for the provision of gaming over a network is disclosed. The system comprises a game rules server configured to receive an input associated with a game and to output a game outcome based on one or more game rules and a game piece indication, and a deck server separate from, and in communication with, the game rules server. The game rules server is further configured to request the game piece indication from the deck server. The deck server is configured to generate and output the game piece indication to the game rules server in response to the request, such that the game piece indication is unavailable to the game rules server until requested.
In another embodiment, a method for the provision of gaming over a network is disclosed. The method comprises receiving, at a game rules server, an input associated with a game. The method further comprises outputting, from the game rules server, a game outcome based on one or more game rules and a game piece indication. The method further comprises requesting, at the game rules server, the game piece indication from a deck server, and generating and outputting the game piece indication to the game rules server from the deck server in response to the request, such that the game piece indication is unavailable to the game rules server until requested, wherein the deck server is separate from and in communication with the game rules server.
Another embodiment includes a gaming system for enabling secure on-line gaming through a client server. The gaming system comprising a gaming platform to communicate with a client server to support play of a wagering game by an end user. The gaming platform includes a game engine configured to administer a set of game rules for the wagering game and to randomly select game pieces according to the set of game rules, and a game routing server separate from the game engine. The game routing server is configured to route communication between the client server and the game engine.
While the present disclosure has been described herein with respect to certain illustrated embodiments, those of ordinary skill in the art will recognize and appreciate that the present disclosure is not so limited. Rather, many additions, deletions, and modifications to the illustrated and described embodiments may be made without departing from the scope of the invention as hereinafter claimed along with their legal equivalents. In addition, features from one embodiment may be combined with features of another embodiment while still being encompassed within the scope of the invention as contemplated by the inventors.
This application is a divisional of U.S. patent application Ser. No. 13/609,031 filed Sep. 10, 2012, which is a continuation-in-part of U.S. patent application Ser. No. 13/353,194 filed on Jan. 18, 2012 which are incorporated by reference herein in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 13609031 | Sep 2012 | US |
Child | 13624743 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13624743 | Sep 2012 | US |
Child | 14878637 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13353194 | Jan 2012 | US |
Child | 13609031 | US |