U.S. Pat. No. 8,663,011

GAME SERVER FOR USE IN CONNECTION WITH A MESSENGER SERVER

AssigneeVerizon Patent and Licensing Inc

Issue DateOctober 31, 2007

Illustrative Figure

Abstract

A game and messenger client-server system is provided that includes a plurality of game clients, a game server, a plurality of messenger clients, and a messenger server. The game server includes logic to operate a multiplayer game using inputs from and outputs to an active game set of game clients, wherein game clients other than those in the active game set can join an active game by supplying the game server with a reference to the active game. Additionally, logic is included for coupling a game client to a messenger client to allow the game client to send the messenger client data used to initiate joining a game, whereby a message sent by the messenger client includes the data used to initiate joining a game. Also, logic is included for initiating a join of a game at an invitee client, using data received in a message to the invitee.

Description

DETAILED DESCRIPTION OF SPECIFIC EMBODIMENTS OF THE INVENTION In one embodiment of a game-messenger system that is described below, each of a plurality of end users operates a game client and a messenger client. The game clients interface with a central game server and the messenger clients interface with a central messenger server. Notwithstanding that description, it should be understood that the game client and messenger client can be merged into a single program or plug-ins to a single program, the central game server and the central messenger server can be operated as a unified server, and the central game server and/or the central messenger server can be replaced with a distributed server, all without necessarily departing from the scope of the invention. It should also be understood that the present invention is not limited to games, but that where a multiplayer game (i.e., a game configured to allow two or more players) is used as an example herein, another non-game multi-user application could be used instead. For example, instead of notifying other players of multiplayer game play, an inviter could invite other computer or computing device users to join in some other multi-user activity. In this description, the terms “inviter” and “invitee” are used to distinguish end users between those that are playing a game and notifying others and those that are notified and given a notice of the playing. Often, the “inviter” will not so much be making an invitation to invitees to join a game but would be simply notifying buddies of the inviter that the inviter is playing an online game. Thus, instead of “inviter,” “invitee” and “invitation,” the terms “notifier,” “notifyee” and “notification,” respectively, might be used instead. On the other hand, in some embodiments, an inviter is actively inviting invitees. One implementation of such ...

DETAILED DESCRIPTION OF SPECIFIC EMBODIMENTS OF THE INVENTION

In one embodiment of a game-messenger system that is described below, each of a plurality of end users operates a game client and a messenger client. The game clients interface with a central game server and the messenger clients interface with a central messenger server. Notwithstanding that description, it should be understood that the game client and messenger client can be merged into a single program or plug-ins to a single program, the central game server and the central messenger server can be operated as a unified server, and the central game server and/or the central messenger server can be replaced with a distributed server, all without necessarily departing from the scope of the invention. It should also be understood that the present invention is not limited to games, but that where a multiplayer game (i.e., a game configured to allow two or more players) is used as an example herein, another non-game multi-user application could be used instead. For example, instead of notifying other players of multiplayer game play, an inviter could invite other computer or computing device users to join in some other multi-user activity.

In this description, the terms “inviter” and “invitee” are used to distinguish end users between those that are playing a game and notifying others and those that are notified and given a notice of the playing. Often, the “inviter” will not so much be making an invitation to invitees to join a game but would be simply notifying buddies of the inviter that the inviter is playing an online game. Thus, instead of “inviter,” “invitee” and “invitation,” the terms “notifier,” “notifyee” and “notification,” respectively, might be used instead. On the other hand, in some embodiments, an inviter is actively inviting invitees. One implementation of such an embodiment might include a list of invitees maintained for the inviter that is used to limit the notification to only those users that the inviter specifically invites.

FIG. 1is a block diagram of an exemplary game-messenger client-server system10according to one embodiment of the present invention. In system10, users connect for online game play by connecting user computers12to a game server14via a network16. In a specific implementation, user computers12are Internet-connectable computers (desktop computers, laptop computers, palm-sized computers, wearable computers, set-top boxes, embedded TCP/IP clients, wireless phones with a user interface, and the like), game server14is an Internet-connected server responsive to requests at a URL designated by the operator of the game server and network16is the global inter-network of networks generally referred to as the “Internet”. The typical computer12includes a browser or other HTTP (Hyper Text Transport Protocol) client that is used to provide a user with HTTP access to the Internet and the collection of documents served by HTTP servers that is generally referred to as the “World Wide Web”, “WWW”, or simply “the Web”. A messenger server18is also provided, often over network16, so that one or more user can send messages (typically “instant messages”) over network16to other users.

An exemplary computer12includes a display and display screen (e.g., monitor, flat panel LCD, etc.) for presenting to a user a graphical user interface (GUI). Computer12comprises standard computer components (not shown) such as a disk drive, CDROM drive, display adapter, network card, random access memory (RAM), central processing unit (CPU), and other components, subsystems and devices. User input devices such as mouse having buttons, keyboard, trackball, touch-screen, digitizing tablet, etc. may be used to by a user to enter information into computer12.

Computer12includes also subsystems that are typically be found in a computing device such as computer12. Subsystems generally include an input/output (I/O) controller, a system memory (or random access memory “RAM”), a central processing unit (CPU), a display adapter, a communications port, a fixed hard drive disk, a network interface adapter, which in turn is coupled electrically to a network, and any other like subsystems. The use of a bus allows each of the subsystems to transfer data among subsystems and, most importantly, with the CPU, where the CPU might be a Sparc, an Intel CPU, a PowerPC, or the like. External devices can communicate with the CPU or other subsystems via the bus by interfacing with a subsystem on the bus. Thus, a monitor connects with the display adapter and relative pointing device (e.g., a mouse) connects through one of the communication ports. Some devices such as keyboard can communicate with the CPU by direct means without using the main data bus as, for example, via an interrupt controller and associated registers. Accord to some embodiments described herein, a game client and a messenger client operate to present a user with graphical information on a user interface for playing a game as well as notifying other friends of one's action of playing a game.

The network provides the communication means, such as physical interconnective links comprising copper wire, fiber optic cable, or the like, for transmitting and receiving signals. Wireless communication means, such as radio waves or the like, are also understood to provide means to transfer information from a source to a destination.

As is well known in the art of network communications, networks are configured to communicate electrical information, such as a computer data signal comprising data (e.g., binary data bits) superimposed upon a radio or any other carrier wave. A person having ordinary skill in the art would appreciate that a carrier wave is electromagnetic energy propagated from a source by radiation, optical or conduction waves and is suitable for embodying an information-bearing signal, such as a computer data signal. In one embodiment, a carrier wave behaves, or is modulated, according to a network protocol, such as Ethernet, IEEE 1394, TCP/IP, or any other communication protocol, so as to include computer data information. The carrier wave can be, for example, a direct current, an alternating current, or a pulse chain. In modulation of the carrier wave, it may be processed in such a way that its amplitude, frequency, or some other property varies so as to embody data for transfer.

In the figures, distinct instances of like objects are distinguished with parenthetical indices. For example, user computer12might refer to12(1) or12(2). In this example,12(1) refers to an inviter client operated by an inviter, who invites a user operating invitee client12(2) to join a game. In a typical system, there may be many inviters, many games and many invitees. Also, if allowed by a game, an invitee might be an invitee in one instance and later be an inviter. As shown inFIG. 1, invitee client12(2) is in a state prior to being invited and joining a game.

Game server14can be a conventional game server or one specially designed for this application. A typical game server maintains data, such as game state, user position, and user statistics, for active users participating in a game. While data storage for only two games are shown inFIG. 1, a game server often hosts many more simultaneous games. A game server might be referenced by a URL for the game server, with a specific port reference or URL string that specifies a specific game in progress. The reference to the game being served to client12(1) is known to a game client20(1) running on client12(1), or can be obtained by game client20(1). As shown, a messenger client22(1) is also running on client12(1) and is capable of receiving an operating system (“O/S”) message from game client20(1).

As shown, messenger clients22are coupled to messenger server18for sending messages, such as instant messages, between clients12. Messenger server18is shown with two databases, a buddy list database and a user list database. Generally, the user list database maintains information about a user, such as their connection address and their connection status (i.e., off-line or on-line). Buddy list database maintains a list, for each enrolled user, of other enrolled users that the user wishes to notify when they are online, typically friends, family and other users with which the user associated with the buddy list has chosen to alert when the user is online. Thus, if a user A were to get online and if user B is on or is associated with user A's buddy list, then user B would be notified when User A is online, affording user B a chance to send an instant message to user A when user B is online and notified that user A is also online. It should be understood that the databases can be embodied in many different forms of data structures, such as relational tables maintained by a relational database management system or text files containing data in predetermined formats.

Referring now toFIG. 2, additional details of a game client and a messaging client are there shown. Game client20(1), in this case the inviter game client, is shown including a network interface30, an O/S messaging interface32, invocation program code34and client variables36. Network interface30connects game client20(1) to network16, in turn connecting game client20(1) to a game server. O/S messaging interface32allows game client20(1) to send messages to other processes running on client12(1), such as a messenger client. Invocation program code34is information usable by an invitee to invoke their own game client and connect to a game in which game client20(1) is currently playing. Client variables36include data (i.e., game data) such as an identifier of the particular game being played and how to invoke the game client.

This game data can be provided in an O/S message38to messenger client22(1). Where a multiplayer game is already written, it can be simply retrofitted by the maker of the game to output O/S message38when a messenger client is running in a space reachable by O/S message38, typically running on the same computer as the game client. For example, a small subroutine might be added to a game client such that upon initiation of the game client and connection to a game server the game client checks for the presence of a messenger client (or at least the ability of a messenger client to receive a message) and, if present, sends an O/S message containing invocation data (described in more detail below, with reference toFIG. 5).

As shown inFIG. 3, a messenger client22(2) running on an invitee client12(2), is coupled to receive messages, such as state message26indicating that a particular buddy changed state (e.g., changed from online to offline or any other state relevant to the game-messenger application). Messenger client22(2) is shown including a local copy of a buddy list40, a message list42and invoker program code (an “invoker”)44. When messenger client22(2) receives a state message indicating that an inviter has joined a game, messenger client22(2) changes the status of that inviter in buddy list40and may add a message to message list42. The status message can be construed as an invitation, but it might just be construed as an indication or a notice to the buddies of the inviter that the inviter is playing a particular game, as well as an indication of how to join the game.

If the invitee opts to join the game, invoker44handles sending an invocation command to operating system services46. In one embodiment, game programs are invoked using command lines and registry entries and the invocation parameters are sufficient to join the game client to the correct game at the correct server.

Since the game clients are preferably provided from a common source, the O/S message sent from the inviter game client to the inviter messenger client can easily be designed to contain enough information to invoke that game client on another machine, assuming that the invitee owns and has installed the game client in a condition to be invoked on the invitee client. Also, if the game clients are provided from a common source, the messenger clients and servers do not have to necessarily understand the contents of the message or specially process the message, except for the optional display of a game-specific icon. Of course, a good security design for a messaging system would require that the messages conform to some limits set by the system to control the uses of the messaging system. The messages might be constrained to conform to the formats shown for the returned file described in more detail below.

Where invocation information varies from client to client, such as where the invocation might depend on the installed directory location for the game client executables, that information can be stored in a registry or similar construct and be referenced by the game client installation using a reference that is common, or at least known, to other game clients.

Referring now toFIG. 4, a flowchart there shows one series of steps, labeled S1, S2, etc., in the order most likely to be carried out, for a method of invoking a game at an invitee client. In step S1, the inviter client invokes a game client. As explained elsewhere, the inviter might have been itself an invitee. At step S2, the inviter's game client connects to a game server to join or start a game. In response, the game server serves up an active game (S3) and provides (S4) the inviter with enough information, such as IP address and port number, so the inviter can play the game.

The inviter game client then checks for the availability of a messenger client and, if a messenger client is such that it can receive a message, the game client creates a message (S5) and sends the message to the messenger client. The messenger client then sends the message to the messenger server (S6), which then forwards the message to all the online users on the inviter's buddy list (S7). In some variations, the message is only forwarded to select users from the buddy list.

When the invitee receives the message (S8) and the invitee decides to join the game referenced in the message (S9), the invitee's messenger client sends an invocation message to the operating system services of the invitee client with enough information to invoke the game client and point the game client to the game the inviter is playing (S10). The invitee thus joins a game (S11) and the game server serves that joined client as one of the players (S12).

When a client ends a game or terminates a game client, the game client might also include code that executes just before the game client terminates. Such code might generate a message similar to an invocation message and cause the messenger client to send a message indicating the new state (e.g., “out of game”) to the buddies, to inform all that one of the game players is no longer actively in the game. Such a message is also useful for providing some indication, or reversal of a prior indication, at the invitee messenger client that there is no longer a game in which to be invited. One possible implementation is to change the icon presented by the invitee messenger client from the game icon next to the inviter's name to a regular messenger icon next to the name of the inviter (now just a messenger buddy).

FIG. 5shows one example of what invocation message24might look like. As shown there, following a message header, the message includes a game identifier, GameID, with a value of “ChaseandRace2000” indicating the game that is to be invoked (and, of course, the game from which the message originated). The message also includes a game identifier (Game#=176), an invoking command line (commandline=“+connect IP:192.168.0.17:28001”), a server descriptor (ServerDesc=“The Game Server”), a registry entry for handling client specific details (RegistryEntry=“ . . . /software/ChaseandRace/Location”), a fallback URL to be presented to the invitee that tries to join a game but does not have a game client “(FallbackURL=“ . . . /nogameinstalled.html”), a version number and a state value.

FIG. 6shows a flowchart illustrating an exemplary method of invoking an inviter's game client according to the present invention.FIG. 6shows but one series of steps and/or acts (of many alternative steps and/or acts) in an order most likely to be carried out. For example, at S100a user joins an online game. After joining the game, it is determined if a messenger client is present at the user's end (S101). If so, an invocation message is sent through the O/S messaging system (S102). If a messenger client is not present, the process moves on to step S103, where a game client is invoked for the user. Additionally, after sending the invocation message, a game client is invoked for the user (S103). The user can then play the online game (S104).

FIG. 7is an exemplary flowchart depicting a method used by an invitee messenger client to display messages from invitees and invoke games, according to one embodiment of the present invention. In S200, the user gets a state message from the messenger server. States of other inviter game clients or other game clients playing the game are displayed using a game specific icon (S201), where such states include “available,” “invisible,” “unavailable,” “playing a game,” etc. At S202, the process determines if the user has selected the game-specific icon. If not, the process moves back to S200, to retrieve a state message from the messenger server and update the states of other game clients. However, if the game-specific icon is selected, a game client of the invitee is invoked using the invocation data from the state message (S203).

Thus, the game client might send the Y! Messenger a state message such as that shown inFIG. 5, or a similar state message with more or fewer fields. The Y! Messenger client forwards this information to the user's friends (i.e., those enrolled Y! Messenger users that are on the sender's buddy list), and then each friend's Y! Messenger client validates the game by looking up the game name with a Yahoo! web server. This step is optional but preferred, since it would serve to prevent someone from making up destructive games and having the destructive game unwittingly executed by recipients of the state message.

In a specific embodiment, the game clients use Yahoo!'s Y! Messenger clients and servers to send state messages to allow a potential player to view their friends' state, i.e., which game, if any, the friend is playing. The process is transparent to both the inviter and the invitee, if desired. For example, the invitee client could be configured to send out a state message any time the invitee joins an online, multiplayer game, thus being transparent to the inviter. The process can also be transparent for the invitee, as the invitee need not know the details of how to invoke a game client or how to find and connect to the game server the invitee's friend is currently engaged with.

FIG. 8, for example, shows a buddy or friend list for “debbie95055,” which is shown as a messenger window in a graphical user interface. The friend's list of debbie95055includes “brian_the_dork,” “priscillalus,” and “tom123494949” and represents users brian_the_dork and priscillalus as being offline (i.e., in offline state) with a “sleeping” face adjacent to their user identifier (e.g., Yahoo! ID). User “tom123494949” is represented as being online (i.e., in online state) with a “smiley” face displayed adjacent to the user's identifier for tom123494949. The friend's list shown in the exemplary instant messenger configuration is implemented in a proprietary messenger service, such as Yahoo! Messenger.

InFIG. 9, debbie95055's messenger window is configured to show when one of debbie95055's friends is engaged in a game with Y! Messenger running and connected to the Internet, for example. RegardingFIG. 9, tom123494949is shown to be a friend of debbie95055and is associated with debbie95055's buddy list. While tom123494949is playing a game, such as “DumbChat,” tom123494949's engagement in playing a game is shown, for example, in parentheses or in connection to a game-related icon adjacent to the player's identifier. For example, as tom123494949enters a game to play, the “available” smiley indicator next to tom123494949's user identifier ofFIG. 8switches to an activity name in which tom123494949is interacting with as shown inFIG. 9. In this case, debbie95055might be considered an invitee and hence is notified of another's action of playing a game. Tom123494949then might be considered to be the inviter that transparently notifies tom123494949's friends that he/she is playing a game a that point in time.

FIG. 10shows an exemplary invitee's messenger window as displayed on a user interface, for example. When a Y! Messenger user such as debbie95055notices an icon change and sees what game is being played by a friend, he/she will be able to also easily join that friend. For example, as shown inFIG. 10, debbie95055need only right-click on that friend's identifier, such as tom123494949. When right-clicking on the gainer's ID “tom123494949,” user debbie95055will be presented other options, such as “Send a Message,” “Invite for conference,” “Invite for voice conference,” and “Send a file.” In one embodiment, there is also a another menu option for joining the friend's game and getting more information about the game that the friend is playing.

In this example, user Tom (associated with ID tom123494949) is playing a game called “DumbChat” on an Internet server, and he has Y! Messenger running on his machine. User Debbie (associated with ID debbie95055) sees on her Y! Messenger that Tom is playing DumbChat (by the change in icon and text surrounding his name) and she decides she wants to surprise him by jumping into the game. She right-clicks on his name in her friends list, and chooses the menu option “Play DumbChat with tom123494949.”

In another embodiment, prior to Y! Messenger displaying the game's icon in a person's friends list, Y! Messenger will actually check a user's computer to see if they have the correct game installed. If the game is installed, then the “Play with . . . ” and “More Information on . . . ” options are made available in the right-click menu. If a user does not have the correct game installed, the only game-related option available to present such a user is the “More Information on . . . ” selection in the right-click menu.

Returning to the Tom and Debbie example, once Debbie chooses “Play DumbChat with Tom” from the right-click menu, Y! Messenger starts the DumbChat game executable with the correct command line arguments to connect her to the same game server where Tom is playing.

In yet another embodiment, a preference setting allows a user to choose whether or not people on a friends list is able to see a game participant's gaming status. For example, a user may “invisibly” (i.e., without notifying the other friends on the list) play a game by indicating as such by checking or un-checking a box (in a privacy category, for example). Such an action will determine whether people on your friends list will be able to see your gaming status. If a message or other Y! Messenger-spawned event occurs while a user is playing a game, Y! Messenger will not take the focus away from a player's game. That is, a game player need not shut down a messaging client before playing games. The messages that come in while a user is playing a game will be waiting on the desktop for the player.

In a specific embodiment, a game manufacturer would include a small subroutine or section of code that sends a message to the Y! Messenger window, if the game exists on a client machine, with the game manufacturer including in the message any information needed to invoke the game client at another location and connect to the same game and game server as the game client sending the message. Accordingly, an entity such as Yahoo! generates a SDK under the trademark name of GameProwler™ and distributes the SDK to third party game developers to include the developer's new game server, for example, for use with the entity's web server (e.g., Yahoo! web server)). GameProwler includes various embodiments of the method and system of the present invention, as described herein.

The Yahoo! web server (or the message itself, preferably validated) provides several pieces of information about the game, including a registry key which points to the an executable to launch to invoke the game, a URL to launch if the game isn't installed (fallback message), and the icon to display on the friends' Y! Messenger clients next to the name of the game player (inviter). The friends can then select the user and join their game, which will launch the executable pointed to by the registry key, with the command line parameters as sent by the original game. If the game is not installed, Y! Messenger launches the game-specific URL in the default web browser.

In a specific embodiment of a user client having a windowing environment and a window messaging system, the game program grabs a handle for the Y! Messenger, and then sends a registered window message with a string encoding the game data, such as:

HWND hwnd = the window handle to Y! MessengerUINT wm = RegisterWindowMessage(“Yahoo! Messenger GameSystem”);ATOM a = GlobalAddAtom(“l\tChaseandRace3\ti\t0\t +connect192.168.0.17:28001\tCrusher.dm CTF r001z”);PostMessage(hwnd,wm,a,0);

If the ATOM value needs to be longer than is allowed by the window messaging system, the game client can be programmed to output the game invoking data to a file and pass the file name to Y! Messenger.

FIG. 11Adepicts a simplified game-messenger client according to the present invention. Further to the Tom and Debbie example, GameProwler according to the present invention includes information sent by a game client to Y! Messenger. The communication between the game client and the Y! Messenger client is performed by the following exemplary tiny bit of code provided by Yahoo! in the GameProwler SDK:

ATOM atom;HWND ym_wnd = FindWindow(“YahooBuddyMain”,NULL);if (ym_wnd != NULL){UINT wm = RegisterWindowMessage(“Yahoo! Messenger GamingSystem”);atom = GlobalAddAtom(s);PostMessage(ym_wnd,win,atom,0);}

This code fragment is design to find the Y! Messenger client window, if it is running. It then registers a string in the global Windows string table and sends the atom for that string in a registered message to Y! Messenger. Y! Messenger looks up the atom with the system, and gets a copy of the original string. The actual string that is sent to Y! Messenger is built from a helper function (not shown). It includes a short game name, the command line to launch to the same game server, a description of the particular game server, and some flags. A helper function takes those parameters and builds them into one string.

Exemplary GameProwler code is contained in files, such as ymessage.c and ymessage.h. A game developer then may compile and link ymessage.c into a game and include ymessage.h. The complied files include, for example, prototypes for at least two functions that are needed to call from a game developer's game: YahooMessengerConnect( ) and YahooMessengerDisconnect( ), for example.

When a game connects to a game server call YahooMessengerConnect( ), at least four of following parameters are employed according to a specific embodiment, as similarly depicted inFIG. 5. First, a game parameter is used to identify the game with a short name of the game containing lowercase letters and numbers. This name must be unique among all games that support GameProwler. Second, a command line is used to launch another copy of the game to the same game server. Third, a description of the particular game server that a player-client is connected to. And, fourth, one or more flags include game type flags, such as YMESSAGE DO NOT DISTURB for all standard games. On the other hand, when the game disconnects from a game server (including if the user quits the game entirely) call YahooMessagerDisconnect( ) is activated with the short game name. This call is also used to resolve a user's state if the game quits without calling YahooMessengerDisconnect.

When the Y! Messenger client receives a message from a game, it either throws it away, or forwards a state message to an arbitrary subset or all of the buddies listed as buddies of the inviter, based on user settings as shown inFIG. 11B. The message from the game to the inviter messenger client is discarded if the user has disabled the system by setting an option. This is useful to give the user an option of not notifying buddies of the game play. The buddy list is stored on the client and the server. Each of the friends' Y! Messenger clients must then verify the legitimacy of the data, to ensure that it will only launch legitimate games. This verification is done through, for example, a secondary lookup to a Yahoo! Web server ofFIG. 11Cbased on the short game name.

If forwarded, the Y! Messenger client sends a state message on to the Y! Messenger server and from there on to the specified buddies. The updated state of the inviter can, but need not be, stored on the messenger server. If a buddy logs on with their messenger client, each buddy is notified of the new state (e.g., “logged on”). If one of those notified buddies is in a game, that buddy's messenger will send back a message to the newly logged on user with the game information so the newly logged on buddy will have the information to display a game icon, invoke a game, etc.

An optional census process can run on the messenger server to roughly track usage of the game-messenger invocation. One way to implement this feature is to have the invoking messenger client set an internal flag and watch for the O/S message that the game client normally sends to the messenger client when the game starts up and detects the messenger client. When the messenger client receives that message from the game client, the messenger sends the message to the messenger server and includes the state of the flag. After sending that message, the messenger client resets the flag.

Using such a mechanism, the messenger server will receive messages from many messenger clients that include invocation instructions. Where the game was invoked directly by the user, the flag is not set and where the game was invoked from the messenger client, the flag is set. While there may be some cases where the flag is not entirely accurate, this census is accurate enough for many purposes. When a game is invoked from the messenger, the computer fails before the game client sends its O/S messenger and then later the user invokes the game client directly, the message to the messenger server will incorrectly indicate that the game was invoked from within the messenger client, but such instances are likely to be rare enough to not significantly effect the statistics gathered. The count of set flags and reset flags can be used to count the number of times the messenger-game system is used and on which games.

When an invitee messenger client receives a message that a buddy is playing a game, the invitee messenger client decodes the message as needed to invoke the game and optionally send a message to the census process. For example, the invitee messenger client might send an HTTP request, prior to invoking the game, to the URL http:///messengergames/lookupname.txt?v=1, where the “?v=1” part of the URL specifies the version number of the messenger client being used by the invitee. The server name () should be configurable on the inviter and invitee clients, to allow game developers to test their game clients and the game-messenger system locally on their network. The configurability might be provided by using a registry entry to specify the domain and filename portion of the URL. Preferably, if the server name is not a subdomain of the operator of the messenger service, the messenger client would warn the invitee client user that the game to which the invitee is being invited has not been verified by the messenger service operator. That step would reduce the incidence of malicious network users sending invitations to join online games that have undesirable or unintended effects on the invitee. This step would also serve to remind game developers to register the game with the messenger service operator for verification before releasing the game to the users.

When the invitee client gets the state message from an inviter client, it looks up data about the game from a game data server. The game data server might be a Yahoo! HTTP server where the game data is “looked up” by downloading a text file from a HTTP server using a standard http lookup. The game data file can be a unix formatted text file, with one field per line. The fields present in the same data file might depend on the values of fields of the message. A few examples are shown below. For example, the file might begin with a field called “tag” that signals whether the game entry is valid (tag=1), if the game entry is an invalid executable game entry (tag=2) or if the game entry is a valid URL game entry (tag=3). Thus, the file

tag=2

would indicate that the game is not supported. Note that no other fields are present, or needed, in such a file. If an invitee messenger client receives such a file, the client will just discard the game info for the buddy inviter. Another file

tag=1icon=.bmpregkey=fallbackURL=infoURL-menutext=infomenuitem=
would be interpreted by the invitee messenger client as a reference to a valid game that is executable locally. In that message, the icon field references a (local or remote) URL of a bitmap of the icon of the game to be displayed by the invitee messenger client. The bitmap might be a 16 by 16 pixel array having up to 256 colors with a particular color, such as magenta, being interpreted as no color (i.e., transparent). The regkey field indicates a registry key that contains a fully qualified path and executable to run to invoke the game client at the invitee client. The fallbackURL key provides a reference to a URL to launch if the game client is not installed and the invitee user tries to join his/her buddy in the game. In this example file, labels enclosed in “” represent space holders for text or numbers who's actual value is not relevant here. The file also includes a reference to a URL to launch if the invitee wants more information about the game (infoURL), text for menu item the invitee would use to launch the game (menutext, example: “Play game X with % s”) and text for menu item for more game info (infomenuitem).

Yet another file is

tag-3icon=.bmpgameURL=fallbackURL=infoURL= menutext=%Ninfomenuitem=
where several of the fields are the same as a tag=1 file, but the gameURL field provides a prefix of a URL used to load the game client at the invitee client.

The invitee messenger client can cache this information about a game for every message it receives about a friend playing each game while the messenger client is operating. If a valid game data file is returned from the game data server, the invitee messenger client retrieves the game icon and displays it next to the buddy's name, in place of the standard messenger icon, such as the “smiley face” icon. If the invitee user pauses a cursor over the buddy's name or game icon, a tooltip might pop up with the description of the game. The right click menu for the buddy might have, two extra entries, one for launching the game and one for more game information, as specified in the fields of the sent file.

Returning to the Tom and Debbie example,FIG. 11Cshows an exemplary web server used for verification purposes, among other things. According to this example, Y! Messenger retrieves the URL by default by using exemplary URL: http:gameprowler_yahoo_com/messengergames/shortname_txt?_msg ver=3,0,0,838, where underscores are understood to represent “dots.” The text after the question mark is designed to change with future versions of Y! Messenger.

The web server may return a text file including several lines of data. The first line contains the character “1”, meaning a standard game. The second line contains a URL to a bitmap to show next to the game player's name in the friend list. This bitmap must be a standard 16×16 256-color .bmp file. For example, pure magenta specifies transparency. A third line contains a registry key that points to a path that Y! Messenger will set as the current directory before launching the game. A fourth line contains a registry key that points to the fully qualified path of the executable to launch. A fifth line contains the URL to a Yahoo! web page to launch if Y! Messenger is unable to launch the game. A sixth line contains the URL to a Yahoo! web page to launch if the user wants more information about the game. A seventh line contains the menu text to display to play the game (with % s representing the friend's name), and an eighth line contains the menu text to display for more information. Additional lines to enhance functionality or fewer lines to reduce quantity of data exchanged is within the scope of the present invention.

In this example of Tom and Debbie, the DumbChat sample program developed in connection with the GameProwler SDK uses the short name “dumbchat,” and corresponds with a URL http:gameprowler_yahoo_com/messengergames/dumbchat_txt. An exemplary, program includes the following:

1DumbChathttp://gameprowler.yahoo.com/messengergames/icons/dumbchat.bmpHKEY_CURRENT_USER\Software\Yahoo\DumbChat\PathHKEY_CURRENT USER\Software\Yahoo\DumbChat\Executablehttp://gameprowler.yahoo.com/messengergames/dumbchat-missing.htmlhttp://gameprowler.yahoo.com/messengergames/dumbchat.htmlPlay DumbChat with %sMore information on DumbChat

For development purposes, a game developer may configure a specific Y! Messenger to retrieve game information from a local web server. Using the system registry editor, change the value of HKEY_CURRENT_USER\Software\Yahoo\Pager\Game\Server to a web server on a network. If necessary, installation of a Personal Web Server (for Windows 9x or Windows NT) might be required. A registered game operable with Yahoo! might be required before a game is released for GameProwler to also work for a developer's users.

FIGS. 11D and 11Eshow an example of a game and a messenger client and an exemplary system, respectively. After a Y! Messenger client receives a game play message from a friend and verifies it with a web server, the game icon is displayed next to the friend's name in the friend list, as described in connection withFIG. 9. At this point, the game is ready to be launched. When the user right clicks the friend's name or game icon, the popup menu contains entries to play the game or get more information on the game. Selecting more information launches a web browser to a Yahoo! web page describing the game.

If the user tries to join the game, then Y! Messenger looks up the game's executable registry key, and tries to launch that executable with the command line specified from the friend. If this succeeds, the game will execute and should connect to the same game server as the friend. If the game launch fails, then there is an initiation of an indication of a setup error with the game. Y! Messenger launches a web browser to a Yahoo! web page that will show both troubleshooting information and other general information about the game.

According to a method and system including an exemplary GameProwler development kit, such a kit includes a small amount of code that is preferably included in a developer's constructed game, as well as a sample chat program using this code called “DumbChat.” To support GameProwler, a developed game preferably supports being launched with command line parameters to connect to a remote game server.

When a game player successfully joins a new networked game, a command line is used to launch his/her copy of the developed game. The player then connects to the same game server, for example. For many games, it would look like this:

+connect ip:port

where ip is the IP address of the remote game server, and port is the port on the remote game server to send packets to. It is up to each copy of the game to interpret this command line correctly.

A game developer preferably builds up a string that describes the particular game server the developer is connected to. This could include information such as skill level, game name, game type (capture the flag, deathwatch, etc.), number of connected users, etc. Then, the game server takes this information and sends it to YahooMessengerConnect( ) like this:

YahooMessengerConnect(“shortname”,command_line,description,YMESSAGE_DO_NOT_DISTURB);

Preferably, a file ymessage.h (from the GameProwler SDK) is used to provide a function prototype having a YMESSEGE_DO_NOT_DISTURB constant. When the game disconnects from a network server (because the user quit, the application is closed, a network error occurred, or any other similar reason), call YahooMessengerDisconnect( ) is used to remove the game playing status like this:

YahooMessengerDisconnect (“shortname”)

The above examples show fields in a “label=string” format. In some implementations, the labels are not present, but are inferred and the fields always appear in the same, predefined order.

If the invitee selects the menu item that launches a game client, then the messenger client attempts to execute the indicated program according to the game data file with the command line parameters sent by the buddy. If this fails, because the game program does not exist on the invitee client or for other failure reasons, then the invitee messenger client presents the fallback message. One method of displaying a fallback message is to launch a web browser with the fallback URL specified in the game data file. If the game is marked as a URL type game (tag=3), then the invitee messenger client it concatenates a URL suffix to the game URL prefix (gameURL) and launches a web browser with that concatenated URL. The URL suffix is passed by the inviter client, in lieu of command line parameters. If the user selects the “infomenuitem” menu item, then the specified URL is launched in a web browser.

A basic system for game-messenger integration and a few variations have now been described. Many variations of the basic system will become apparent upon review of the disclosure and some variations are described in detail below.

One such variation is where game clients are written using Java™ code. Since such game clients are typically invoked at a game server, to be executed on a client, a client-side O/S messaging might not be possible, since Java programs are designed not to be able to access certain operating system services. With such games, the communications paths can be modified from the system shown inFIG. 1to the system shown inFIG. 12.

FIG. 12shows a client12(1) starts a game by invoking it in a normal manner, such as downloading a Java program112embodying the game client from a game server114over network16. When game server114serves the game client to an identified user using client12(1), the game server also sends a message to a messenger server118so that messenger server118can send a state message to the messenger clients122of buddies of the user of client12(1).

The game server might also send state messages when users leave a game. Such game server-messenger server messages might be HTTP messages. A game server can be operated by the same operator of the messenger system, such as the Y! Games servers and the Y! Messenger servers, or the servers can be independently operated.

In the Java variation, the game servers act like the messenger client, in that the game server duplicates the configuration of which friends to tell about the user's room changes. Thus, the game servers might need to hold onto more information than if the clients initiated the messages.

Besides just passively changing the state of a buddy's messenger client, the game message could also contain an “invite” flag. When the buddy's messenger client receives the game message, if the invite flag is reset, the buddy's messenger client just changes the state. However, if the invite flag is set, the buddy's messenger client invokes a dialog box with the game information and a button to accept the invitation to join the game. This invite flag feature could be extended to be used with other messenger users that use “fake” messenger clients that are actually software agents, such as a “tournament buddy” that would guide users through playing game tournaments, or a “chat events buddy” that would invite users to all chat events. This concept could be extended to non-game guiding of users throughout an online environment.

While the above description explains operating system-level messages from a game client to a messenger client, messages might also be sent in the other direction in some implementations. For example, when a game is a full screen application, it is not always desirable to have the messenger client pop up. In such environments, the game clients might be further modified to accept messages from the messenger client and display selected messages in the context of the game. With such a capability, two or more players of a game could be playing in one multiplayer game while each of them have their messenger client running in the background. When a messenger client receives a message from one of the other players, that message is forwarded to the game client of the recipient, which can display the message in the context of the game, and even allow the recipient to reply to the message in the context of the game.

FIG. 13illustrates another variation of the game-messenger client combination. In a system200shown inFIG. 13, messages between user clients are sent peer-to-peer rather than going through a messaging server. One method of message transport is using TCP/IP packets, such as message204, that are transported over network16between clients12directly, without needing an intervening server.

As mentioned previously, while the primary example described herein relates to games and one game player inviting other game players to join a game, where the invitation is delivered as a message that includes invocation instructions, the system would work well with non-game multi-user applications. For example, consider a whiteboarding application, used by multiple people in a collaborative drawing session. The inviter in this case would be a user that is using a client-server whiteboard program that is preferably pre-enabled to send invocation messages. When the inviter makes an invitation, the inviter's messenger client sends a message to the invitees on the inviter's buddy list, who can then invoke the whiteboard application and connect to the correct session on a whiteboard server, all using the data provided in the message. Such an activity, whether whiteboarding, game or any other activity, may include an “activity client” and an “activity server” to effectuate an embodiment of the present invention.

FIG. 14illustrates a screen shot300for an invitee messenger client according to one embodiment. As shown, the section fellow garners302includes a Yahoo! game expert icon304and game friend icon306. The icons304and306can represent the status of the associated gamers. For example, the icons304and306can represent whether or not the garners are currently playing a game or alternatively, can represent whether a user is online or offline. Additionally, icons304and306can change when the status of the associated garners change. Friends308can include friends of the invitee. The friends308are friends the invitee can establish connections with where instant messages can be sent in between the invitee and friends308.

FIG. 15illustrates a screen shot502generated using an exemplary inviter game client and messenger client according to one embodiment of the present invention. As shown, “user sammyjo7867” is, or is about to participant in an online game of Euchre. Sammyjo7867plays Euchre with the use of the game client as described herein. Also shown is a messenger window504including Sammyjo7867's friends on a Group1friends list506(i.e., Freakazoid, kelly, mikey, Pootchie, and Snookey). Although each of the friends are shown to be inactive or unavailable, the messenger window will indicate that a friend is online by changing an icon adjacent to the online friend's ID to match the change in status (i.e., change in state). As user sammyjo7867continues playing a game, sammyjo7867may optionally elect to allow his/her “friends to find me”508by, for example, checking such a selection or may play in stealth or invisible mode. Additionally, user sammyjo7867may decline all invitations510or restrict instant messages (IMs) from only friends512on an associated friends list.

The above description is illustrative and not restrictive. Many variations of the invention will become apparent to those of skill in the art upon review of this disclosure. The scope of the invention should, therefore, be determined not with reference to the above description, but instead should be determined with reference to the appended claims along with their full scope of equivalents.

Claims

  1. A method comprising: enabling an inviter game client to check for current running of an inviter messenger client in a same operating system, on initiation of the inviter game client and connection of the inviter game client to a remote game server;enabling the inviter game client to send, based on an affirmative result of the check, an operating system message to the inviter messenger client that causes at least one game state message to be sent from the inviter messenger client over a network to a messenger server that forwards the at least one game state message to an invitee messenger client, wherein the at least one game state message indicates that the inviter game client is currently active in a particular game, and is sent from the inviter messenger client executing separately from the inviter game client;and enabling at least one field of data in an invocation message that is used by the invitee messenger client for sending to an invitee game client to initiate joining the particular game, a content of said at least one field of data being provided by the remote game server to the inviter messenger client for inclusion in the at least one game state message, wherein the at least one field of data enables the invitee game client to be invoked that is associated with the invitee messenger client and further enables the invitee game client to initiate joining the currently active particular game to which the inviter game client is joined, and wherein the at least one field of data includes a link to be presented if the invitee game client is not installed.
  1. The method of claim 1 , wherein a messaging interface causes the data to be provided to the inviter messenger client.
  2. The method of claim 1 , further comprising sending the at least one game state message from the inviter messenger client to the invitee messenger client.
  3. The method of claim 1 , wherein the data includes a game server network address that identifies the game server, a game identifier that identifies the active game on the identified game server, a and a port identifier that identifies a port on the identified game server.
  4. The method of claim 1 , wherein the invitee messenger client is associated with a member of a buddy list of the inviter messenger client, and wherein the inviter messenger client sends the at least one game state message automatically to members of the buddy list.
  5. A computer program product encoded on a computer readable nontransitory medium and operable to run on a computer as an inviter client, comprising: program code operable to cause an inviter game client to check for current running of an inviter messenger client in a same operating system, on initiation of the inviter game client and connection of the inviter game client to a remote game server;program code operable to cause the inviter game client to send, based on an affirmative result of the check, an operating system message to the inviter messenger client that causes at least one game state message to be sent from the inviter messenger client over a network to a messenger server that forwards the at least one game state message to an invitee messenger client, wherein the at least one game state message indicates that the inviter game client is currently active in a particular game, and is sent from the inviter messenger client executing separately from the inviter game client;and program code operable to cause at least one field of data in an invocation message that is used by the invitee messenger client for sending to an invitee game client to initiate joining the particular game, a content of said at least one field of data being provided by the remote game server to the inviter messenger client for inclusion in the at least one game state message, wherein the at least one field of data enables the invitee game client to be invoked that is associated with the invitee messenger client and further enables the invitee game client to initiate joining the currently active particular game to which the inviter game client is joined, and wherein the at least one field of data includes a link to be presented if the invitee game client is not installed.
  6. The computer program product of claim 6 , further comprising: program code operable to provide a messaging interface, wherein the messaging interface causes the data to be provided to the inviter messenger client.
  7. The computer program product of claim 6 , further comprising program code operable to send the at least one game state message from the inviter messenger client to the invitee messenger client.
  8. The computer program product of claim 6 , wherein the data includes a game server network address that identifies the game server, a game identifier that identifies the active game on the identified game server, and a port identifier that identifies a port on the identified game server.
  9. The computer program product of claim 6 , wherein the invitee messenger client is associated with a member of a buddy list of the inviter messenger client, and wherein the inviter messenger client sends the at least one game state message automatically to members of the buddy list.
  10. A system comprising: an inviter client computer including: a first memory for storing at least data;and a first processor that is arranged to enable actions by at least executing modules, comprising: an inviter game module configured to check for current running of an inviter messenger module in the same operating system, on initiation of the inviter game module and connection of the inviter game module to a server computer, configured to send, based on an affirmative result of the check, an operating system message to the inviter messenger module that causes at least one game state message to be sent from the inviter messenger module over a network to a messenger server configured to forward the at least one game state message to an invitee messenger module at an invitee client computer, wherein the at least one game state message indicates that the inviter game module is currently active in a particular game;and the inviter messenger module for receiving data, wherein the inviter messenger module configured to execute separately from the inviter game module within the first processor;and the server computer including: a second memory for storing at least data;and a second processor that is arranged to enable actions by at least executing modules, comprising: a first sever module for providing at least one field of data in an invocation message that is used by the invitee messenger client for sending to an invitee game client to initiate joining the particular game, a content of said at least one field of data being provided by the remote game server to the inviter messenger client for inclusion in the at least one game state message, wherein the at least one field of data enables the invitee game client to be invoked that is associated with the invitee messenger client and further enables the invitee game client to initiate joining the currently active particular game to which the inviter game client is joined, and wherein the at least one field of data includes a link to be presented if the invitee game client is not installed.
  11. The system of claim 11 , wherein the inviter messenger module further provides a messaging interface, wherein the messaging interface causes the data to be received by the inviter messenger module.
  12. The system of claim 11 , wherein the inviter messenger module further sends the at least one game state message from the inviter messenger module to the invitee messenger module at the invitee client computer.
  13. The system of claim 11 , wherein the data includes a game server network address that identifies the server computer, a game identifier that identifies the active game on the identified server computer, and a port identifier that identifies a port on the identified server computer.
  14. The system of claim 11 , wherein the invitee messenger module is associated with a member of a buddy list of the inviter messenger module, and wherein the inviter messenger module sends the at least one game state message automatically to members of the buddy list.
  15. An apparatus, comprising: a memory configured to store at least data including executable instructions;and a processor configured to execute the instruction for enabling actions, including: enabling an inviter game client to check for current running of an inviter messenger client in a same operating system, on initiation of the inviter game client and connection of the inviter game client to a remote game server;enabling the inviter game client to send, based on an affirmative result of the check, an operating system message to the inviter messenger client that causes the inviter messenger client to send at least one game state message over a network to a messenger server that forwards the at least one game state message to an invitee messenger client, wherein the at least one game state message indicates that the inviter game client is currently active in a particular game, and is sent from the inviter messenger client executing separately from the inviter game client;and providing at least one field of data in an invocation message that is used by the invitee messenger client for sending to an invitee game client to initiate joining the particular game, a content of said at least one field of data being provided by the remote game server to the inviter messenger client for inclusion in the at least one game state message, wherein the at least one field of data enables the invitee game client to be invoked that is associated with the invitee messenger client and further enables the invitee game client to initiate joining the currently active particular game to which the inviter game client is joined, and wherein the at least one field of data includes a link to be presented if the invitee game client is not installed.
  16. The apparatus of claim 16 , wherein the actions further comprise: providing a messaging interface, wherein the messaging interface causes the data to be provided to the inviter messenger client.
  17. The apparatus of claim 16 , further comprising sending the at least one game state message from the inviter messenger client to the invitee messenger client.
  18. The apparatus of claim 16 , wherein the data includes a game server network address that identifies the game server, a game identifier that identifies the active game on the identified game server, and a port identifier that identifies a port on the identified game server.
  19. The apparatus of claim 16 , wherein the invitee messenger client is associated with a member of a buddy list of the inviter messenger client, and wherein the inviter messenger client sends the at least one game state message automatically to members of the buddy list.

Disclaimer: Data collected from the USPTO and may be malformed, incomplete, and/or otherwise inaccurate.