This application claims priority to Australian Provisional Patent Application No. 2007903982, having a filing date of Jul. 24, 2007, which is incorporated herein by reference in its entirety.
[Not Applicable]
[Not Applicable]
1. Technical Field
The present invention relates generally to handling jackpots in a gaming network.
2. Background
Gaming systems have been proposed that employ a client/server architecture. Such architectures can support very large numbers of gaming clients and accordingly present challenges for the management of prizes that can be awarded to one of a plurality of gaming machines such as a jackpot.
In a first aspect, there is provided a method of processing a jackpot win in a gaming network, the method comprising:
providing a jackpot server:
receiving jackpot claim data at the jackpot server;
locking a jackpot record corresponding to the jackpot claim data;
aggregating any outstanding jackpot contributions for the jackpot record from contributing parts of the gaming network to form a prize; and
communicating prize data corresponding to the prize to a network destination identified by the jackpot claim data.
In an embodiment the method comprises opening a new jackpot record to which new jackpot contributions may be made while outstanding jackpot contributions are aggregated.
In an embodiment opening a new jackpot record comprises generating a new jackpot record.
In an embodiment a new jackpot identifier is allocated to the new jackpot record and the method comprises communicating the new jackpot identifier to each participating gaming server.
In an embodiment the method comprises maintaining a record at the jackpot server for each participating gaming server.
In a second aspect, the invention provides a jackpot server for a gaming network, the jackpot server arranged to:
receive jackpot claim data;
lock a jackpot record corresponding to the jackpot claim data;
aggregate any outstanding jackpot contributions for the jackpot record from contributing parts of the gaming network to form a prize; and
communicate prize data corresponding to the prize to a network destination identified by the jackpot claim data.
In an embodiment, the jackpot server comprises a jackpot database comprising the jackpot record.
In an embodiment, the jackpot server is arranged to open a new jackpot record in the jackpot database to which new jackpot contributions may be made while outstanding jackpot contributions are aggregated.
In an embodiment, the jackpot database comprises a game server contribution record for each of a plurality of participating game servers for each jackpot record, whereby the jackpot server can track game server contributions to each jackpot by each game server.
In a third aspect the invention provides a gaming network comprising:
a jackpot server;
a plurality of participating gaming servers each of which is connected to one or more participating gaming clients, the participating gaming clients and gaming servers implementing game instances that contribute to a jackpot,
the jackpot server arranged to:
receive jackpot claim data from one of the participating gaming servers;
lock a jackpot record corresponding to the jackpot claim data;
aggregate any outstanding jackpot contributions for the jackpot record from contributing gaming servers to form a prize; and
communicate prize data corresponding to the gaming server identified by the jackpot claim data.
In an embodiment, the jackpot server comprises a jackpot database comprising the jackpot record.
In an embodiment, the jackpot server is arranged to open a new jackpot record in the jackpot database to which new jackpot contributions may be made while outstanding jackpot contributions are aggregated.
In an embodiment, the jackpot database comprises a game server contribution record for each of a plurality of participating game servers for each jackpot record, whereby the jackpot server can track game server contributions to each jackpot by each game server.
In an embodiment the gaming clients are connected to the gaming servers by application servers.
The invention is further explained by means of the following non-limiting examples and in conjunction with the accompanying drawings, in which:
In the embodiment the described method steps and functions are realized by computer system components, computer software code portions, or combinations thereof. It is within the knowledge of the skilled person to select appropriate components for the realization of the invention.
Persons skilled in the art will appreciate that game server 110 will typically be one of a plurality of game servers 310, 320 in a gaming network as illustrated in
It will be appreciated that not all of the game servers 310, 320 may contribute to the same jackpot. Further jackpots can be defined at a number of levels, for example a global jackpot, a jackpot for servers from the first jurisdiction, a jackpot for a single server 320B of the second jurisdiction etc. Herein game servers 310, 320 that contribute to a jackpot are said to be participating servers. Similarly not all gaming clients may contribute, for example, only gaming clients playing certain games may contribute. Gaming clients that contribute, are similarly referred to as participating gaming clients.
“Communicatively coupled” in this text means that there is a communication link over which information signals can be communicated between two coupled units, for example in the form data packets or the like. The communication link can for example be continuously activated in an on-line state or be activated on request when a message, e.g. in the shape of a request or a response, is communicated.
The gaming system according to the present embodiment of is based on a client/server architecture where the game software is divided into a client game module and a server game module with access to a central database. In order to run a game the client game module must be associated with and use functions available at a server game module. When a game is played via a client gaming machine, a game session is established and game session data is generated in the course of the game. Each game session has a specific identity and is assigned a game session identify code. The game session data is stored in the game server database 110 associated with the game session identity code.
The server 204 is provided with a game application program interface, in short called server game API 206, enabling communication between a server module of a specific game application program 208 and general server gaming functions 210,212,214,216 installed on the server. The general server gaming functions are provided to be available for any specific game application program independently of the specific game content. These general server gaming functions are typically functions such as a database 210, a random number generator 212, an account service function 214, a log service function 216, or other functions that can be beneficially shared and used by different specific game application programs.
The client gaming machine 202 is also provided with a game application program interface, in short called client game API 220, enabling communication between a client game module 218 of the specific game application program and general client gaming functions 222,224,226,228 installed on the client gaming machine 202 and used by different client game modules. The general client gaming functions are designed for assisting in implementing and executing a specific game on the client gaming machine 202 and are available for the client game module 218. These general client gaming functions are in different embodiments a selection of a graphical user interface (GUI) 222, a cashbox function 224, a sound function 226, user input interface function, for example buttons, 228, data storage 229, a printer 203, a bar code reader 233 and other functions that are related to the performance of a game. The client game module 218 is communicatively coupled to the corresponding server game module 208 for communicating requests 209 and responses 211 in order to utilize the general gaming functions provided in the server. For each game a message protocol for communication between the client module and the server module is generated, the protocol is for example based on XML and is shared by the client and the server.
A specific game application program thus has a server game module 208 and a client game module 218 that communicate either directly or via an application program interface on the client side and the server side respectively as shown in
Establishment of the gaming session involves the gaming server loading the relevant server module, and providing (if necessary) the relevant client module to the client gaming machine.
Exemplary Database Configuration
As indicated above the gaming network may run a series of concurrent jackpot instances. Accordingly, the jackpot database 120A is arranged such that:
As indicated above, the back office database (e.g. BODB) needs to store information that is used to define the jackpot, to log ‘current’ status and historic payouts, and (eventually in a future release) to keep track of the sponsor monetary status. The jackpot database stores the data in a number of tables:
Jackpot_Definition Table
This table is used to store all the basic information on a jackpot. There is one record for each jackpot.
Jackpot_Def_Level Table
This table is used to store all the basic information on a jackpot level. There is one record for each jackpot level.
Jackpot_Status Table
This table is used to store different status ids used in the Jackpot_Instance_GS_Sync and Jackpot_Instance_Win tables.
Jackpot_Instance Table
This table is used to log current information on a jackpot instance. BODB uses it to store up-to-date values each jackpot, as well as keeping track of the sequence numbers.
Jackpot_Instance_Win Table
This table is used to log jackpot wins.
Jackpot_Instance_GS_Sync Table
This table is used to log the current BODB information from a GSDB on a jackpot. At win time the current sequence record is copied to the Jackpot_Instance_GS_Win table.
GS_Jackpot_Instance_Client Table
This table is used to hold the current jackpot instance information. There is one record for each active client and jackpot instance Jn. The client creates a new record whenever needed, i.e. when the sequence number in the GS_Jackpot_Sequence table was updated.
Exemplary Game Server Database Configuration
Each of the GSDBs has a set of requirements:
To store this data, the GSDB employs the following table.
GS_Jackpot_Sequence Table
This table is used to find the current jackpot instance. There is one record for each active jackpot J. This is read before each contribution is stored to use the latest sequence. The sequence is updated when the GSDB syncs money to the common jackpot database (i.e. BODB) and, from BODB, when a Jackpot (level) is won.
Jackpot_Instance_GS_Win Table
This table is used to log the win record for each GSDB on a jackpot. At win time the current sequence record is copied from the Jackpot_Instance_GS_Sync table.
Exemplary Setup
During setup, the jackpot definition is created in BODB 118. The BODB starts a new jackpot set. This is done at installation time of the game.
The following tables provided in the BODB 118 and populated for a jackpot at setup:
The following table is provided in the GSDB 110 and should be populated for a jackpot at setup:
Each game server database is initialized with all available jackpots, i.e. records created in the jackpot instance table.
1. When an application server logs in to a GSDB 110, the GSDB is checked for the presence of all available jackpots by checking the BODB.
2. Any missing jackpot is added to the GSDB and to the back office jackpot instance GSDB table (there should be a table in the back office with a record for each GSDB and jackpot instance).
3. Jackpots are defined and identified by their jackpot instance number.
4. For each jackpot there is a Sequence number defining the current summarization set, i.e. the synchronization with the BODB.
5. The Sequence number is updated each time jackpot amounts are reported to the BODB, i.e. for the normal reporting frequency and at each jackpot win.
6. The Sequence number is used to store jackpot information for each game round event that contributes to the jackpot at the GSDB.
Exemplary Management of Contributions
The back office database is updated with the latest jackpot amounts from each game server database at a regular basis. This process handles any GSDB being offline and in an unknown state in regard to the jackpot state, e.g. are there contributions outstanding.
1. The process is asynchronous between the actions on the BODB and on each GSDB for timing, performance and consistency reasons.
2. Actions by the BODB:
Exemplary Game Sessions
1. A number of players start game sessions in the game that holds the jackpot.
2. Game round event information comes to the GSDB with information about the jackpot contribution amount and the jackpot instance id.
3. The jackpot instance information for the game session is updated using the current Sequence number, or inserted if this is a new Sequence number.
4. The process repeats it self indefinitely, until the jackpot is closed.
Exemplary Processing of a Jackpot Win
1. The game module of a gaming client may at any time ask for a jackpot win id eventually be used to register a win.
2. Jackpot win
3. The client requests jackpot win status and amounts.
Exemplary Application Server
1. The application server receives a push message from the database alerting it that updated jackpot values are available.
2. The application server requests current jackpot balances for all active jackpots from the database and caches them locally.
3. When the application server receives a request for jackpot balances from a client (IVT or ICT), it uses the cached jackpot data.
Exemplary Reconnect
Occasionally a game session may be ended with an outstanding jackpot claim. A reconnect voucher will be issued which will allow the player to claim the jackpot.
1. At the reconnect entitlement activation
2. At reconnect time
The invention has been described by way of exemplifying embodiments, but naturally there are various manners of realising the invention within the scope of the claims. In particular, it will be apparent that features of certain of the above embodiments and examples can be employed to form further embodiments.
In the claims which follow and in the preceding description of the invention, except where the context requires otherwise due to express language or necessary implication, the word “comprise” or variations such as “comprises” or “comprising” is used in an inclusive sense, i.e. to specify the presence of the stated features but not to preclude the presence or addition of further features in various embodiments of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2007903982 | Jul 2007 | AU | national |
Number | Name | Date | Kind |
---|---|---|---|
20020047044 | Orus | Apr 2002 | A1 |
20020094859 | Hirsch | Jul 2002 | A1 |
20050137010 | Enzminger et al. | Jun 2005 | A1 |
20050239542 | Olsen | Oct 2005 | A1 |
20060052162 | Soukup | Mar 2006 | A1 |
20060079320 | Erickson | Apr 2006 | A1 |
20060100008 | Wright | May 2006 | A1 |
20060183529 | Acres | Aug 2006 | A1 |
20060211465 | Moshal | Sep 2006 | A1 |
20060287077 | Grav | Dec 2006 | A1 |
20070032301 | Acres | Feb 2007 | A1 |
Number | Date | Country |
---|---|---|
1014377 | Sep 2003 | BE |
2525527 | Dec 2004 | CA |
2559412 | Mar 2007 | CA |
2006180891 | Jul 2006 | JP |
20030041374 | May 2003 | KR |
13130 | Apr 2004 | LV |
PA05004612 | Mar 2006 | MX |
03067534 | Aug 2003 | WO |
2004097756 | Nov 2004 | WO |
2006081022 | Aug 2006 | WO |
2007049115 | May 2007 | WO |
Number | Date | Country | |
---|---|---|---|
20090156301 A1 | Jun 2009 | US |