create_player_sessions
(**kwargs)¶Reserves open slots in a game session for a group of players. New player sessions can be created in any game session with an open slot that is in ACTIVE
status and has a player creation policy of ACCEPT_ALL
. To add a single player to a game session, use CreatePlayerSession
To create player sessions, specify a game session ID and a list of player IDs. Optionally, provide a set of player data for each player ID.
If successful, a slot is reserved in the game session for each player, and new PlayerSession
objects are returned with player session IDs. Each player references their player session ID when sending a connection request to the game session, and the game server can use it to validate the player reservation with the GameLift service. Player sessions cannot be updated.
The maximum number of players per game session is 200. It is not adjustable.
Related actions
See also: AWS API Documentation
Request Syntax
response = client.create_player_sessions(
GameSessionId='string',
PlayerIds=[
'string',
],
PlayerDataMap={
'string': 'string'
}
)
[REQUIRED]
A unique identifier for the game session to add players to.
[REQUIRED]
List of unique identifiers for the players to be added.
Map of string pairs, each specifying a player ID and a set of developer-defined information related to the player. Amazon GameLift does not use this data, so it can be formatted as needed for use in the game. Any player data strings for player IDs that are not included in the PlayerIds
parameter are ignored.
dict
Response Syntax
{
'PlayerSessions': [
{
'PlayerSessionId': 'string',
'PlayerId': 'string',
'GameSessionId': 'string',
'FleetId': 'string',
'FleetArn': 'string',
'CreationTime': datetime(2015, 1, 1),
'TerminationTime': datetime(2015, 1, 1),
'Status': 'RESERVED'|'ACTIVE'|'COMPLETED'|'TIMEDOUT',
'IpAddress': 'string',
'DnsName': 'string',
'Port': 123,
'PlayerData': 'string'
},
]
}
Response Structure
(dict) --
PlayerSessions (list) --
A collection of player session objects created for the added players.
(dict) --
Represents a player session. Player sessions are created either for a specific game session, or as part of a game session placement or matchmaking request. A player session can represents a reserved player slot in a game session (when status is RESERVED
) or actual player activity in a game session (when status is ACTIVE
). A player session object, including player data, is automatically passed to a game session when the player connects to the game session and is validated. After the game session ends, player sessions information is retained for 30 days and then removed.
Related actions
PlayerSessionId (string) --
A unique identifier for a player session.
PlayerId (string) --
A unique identifier for a player that is associated with this player session.
GameSessionId (string) --
A unique identifier for the game session that the player session is connected to.
FleetId (string) --
A unique identifier for the fleet that the player's game session is running on.
FleetArn (string) --
The Amazon Resource Name ( ARN ) associated with the GameLift fleet that the player's game session is running on.
CreationTime (datetime) --
A time stamp indicating when this data object was created. Format is a number expressed in Unix time as milliseconds (for example "1469498468.057"
).
TerminationTime (datetime) --
A time stamp indicating when this data object was terminated. Format is a number expressed in Unix time as milliseconds (for example "1469498468.057"
).
Status (string) --
Current status of the player session.
Possible player session statuses include the following:
IpAddress (string) --
The IP address of the game session. To connect to a GameLift game server, an app needs both the IP address and port number.
DnsName (string) --
The DNS identifier assigned to the instance that is running the game session. Values have the following format:
<unique identifier>.<region identifier>.amazongamelift.com
.ec2-<unique identifier>.compute.amazonaws.com
. (See Amazon EC2 Instance IP Addressing.)When connecting to a game session that is running on a TLS-enabled fleet, you must use the DNS name, not the IP address.
Port (integer) --
Port number for the game session. To connect to a Amazon GameLift server process, an app needs both the IP address and port number.
PlayerData (string) --
Developer-defined information related to a player. GameLift does not use this data, so it can be formatted as needed for use in the game.
Exceptions
GameLift.Client.exceptions.InternalServiceException
GameLift.Client.exceptions.UnauthorizedException
GameLift.Client.exceptions.InvalidGameSessionStatusException
GameLift.Client.exceptions.GameSessionFullException
GameLift.Client.exceptions.TerminalRoutingStrategyException
GameLift.Client.exceptions.InvalidRequestException
GameLift.Client.exceptions.NotFoundException