{ "basePath": "", "icons": { "x16": "http://www.google.com/images/icons/product/search-16.gif", "x32": "http://www.google.com/images/icons/product/search-32.gif" }, "name": "games", "kind": "discovery#restDescription", "ownerDomain": "google.com", "schemas": { "AchievementDefinitionsListResponse": { "id": "AchievementDefinitionsListResponse", "description": "A list of achievement definition objects.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementDefinitionsListResponse`.", "type": "string" }, "nextPageToken": { "description": "Token corresponding to the next page of results.", "type": "string" }, "items": { "description": "The achievement definitions.", "type": "array", "items": { "$ref": "AchievementDefinition" } } } }, "AchievementDefinition": { "id": "AchievementDefinition", "description": "An achievement definition object.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementDefinition`.", "type": "string" }, "id": { "description": "The ID of the achievement.", "type": "string" }, "name": { "description": "The name of the achievement.", "type": "string" }, "description": { "description": "The description of the achievement.", "type": "string" }, "achievementType": { "description": "The type of the achievement.", "type": "string", "enumDescriptions": [ "Achievement is either locked or unlocked.", "Achievement is incremental." ], "enum": [ "STANDARD", "INCREMENTAL" ] }, "totalSteps": { "description": "The total steps for an incremental achievement.", "type": "integer", "format": "int32" }, "formattedTotalSteps": { "description": "The total steps for an incremental achievement as a string.", "type": "string" }, "revealedIconUrl": { "description": "The image URL for the revealed achievement icon.", "type": "string" }, "isRevealedIconUrlDefault": { "description": "Indicates whether the revealed icon image being returned is a default image, or is provided by the game.", "type": "boolean" }, "unlockedIconUrl": { "description": "The image URL for the unlocked achievement icon.", "type": "string" }, "isUnlockedIconUrlDefault": { "description": "Indicates whether the unlocked icon image being returned is a default image, or is game-provided.", "type": "boolean" }, "initialState": { "description": "The initial state of the achievement.", "type": "string", "enumDescriptions": [ "Achievement is hidden.", "Achievement is revealed.", "Achievement is unlocked." ], "enum": [ "HIDDEN", "REVEALED", "UNLOCKED" ] }, "experiencePoints": { "description": "Experience points which will be earned when unlocking this achievement.", "type": "string", "format": "int64" } } }, "AchievementIncrementResponse": { "id": "AchievementIncrementResponse", "description": "An achievement increment response", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementIncrementResponse`.", "type": "string" }, "currentSteps": { "description": "The current steps recorded for this incremental achievement.", "type": "integer", "format": "int32" }, "newlyUnlocked": { "description": "Whether the current steps for the achievement has reached the number of steps required to unlock.", "type": "boolean" } } }, "PlayerAchievementListResponse": { "id": "PlayerAchievementListResponse", "description": "A list of achievement objects.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerAchievementListResponse`.", "type": "string" }, "nextPageToken": { "description": "Token corresponding to the next page of results.", "type": "string" }, "items": { "description": "The achievements.", "type": "array", "items": { "$ref": "PlayerAchievement" } } } }, "PlayerAchievement": { "id": "PlayerAchievement", "description": "An achievement object.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerAchievement`.", "type": "string" }, "id": { "description": "The ID of the achievement.", "type": "string" }, "currentSteps": { "description": "The current steps for an incremental achievement.", "type": "integer", "format": "int32" }, "formattedCurrentStepsString": { "description": "The current steps for an incremental achievement as a string.", "type": "string" }, "achievementState": { "description": "The state of the achievement.", "type": "string", "enumDescriptions": [ "Achievement is hidden.", "Achievement is revealed.", "Achievement is unlocked." ], "enum": [ "HIDDEN", "REVEALED", "UNLOCKED" ] }, "lastUpdatedTimestamp": { "description": "The timestamp of the last modification to this achievement's state.", "type": "string", "format": "int64" }, "experiencePoints": { "description": "Experience points earned for the achievement. This field is absent for achievements that have not yet been unlocked and 0 for achievements that have been unlocked by testers but that are unpublished.", "type": "string", "format": "int64" } } }, "AchievementRevealResponse": { "id": "AchievementRevealResponse", "description": "An achievement reveal response", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementRevealResponse`.", "type": "string" }, "currentState": { "description": "The current state of the achievement for which a reveal was attempted. This might be `UNLOCKED` if the achievement was already unlocked.", "type": "string", "enumDescriptions": [ "Achievement is revealed.", "Achievement is unlocked." ], "enum": [ "REVEALED", "UNLOCKED" ] } } }, "AchievementSetStepsAtLeastResponse": { "id": "AchievementSetStepsAtLeastResponse", "description": "An achievement set steps at least response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementSetStepsAtLeastResponse`.", "type": "string" }, "currentSteps": { "description": "The current steps recorded for this incremental achievement.", "type": "integer", "format": "int32" }, "newlyUnlocked": { "description": "Whether the current steps for the achievement has reached the number of steps required to unlock.", "type": "boolean" } } }, "AchievementUnlockResponse": { "id": "AchievementUnlockResponse", "description": "An achievement unlock response", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementUnlockResponse`.", "type": "string" }, "newlyUnlocked": { "description": "Whether this achievement was newly unlocked (that is, whether the unlock request for the achievement was the first for the player).", "type": "boolean" } } }, "AchievementUpdateMultipleRequest": { "id": "AchievementUpdateMultipleRequest", "description": "A list of achievement update requests.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementUpdateMultipleRequest`.", "type": "string" }, "updates": { "description": "The individual achievement update requests.", "type": "array", "items": { "$ref": "AchievementUpdateRequest" } } } }, "AchievementUpdateRequest": { "id": "AchievementUpdateRequest", "description": "A request to update an achievement.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementUpdateRequest`.", "type": "string" }, "achievementId": { "description": "The achievement this update is being applied to.", "type": "string" }, "updateType": { "description": "The type of update being applied.", "type": "string", "enumDescriptions": [ "Achievement is revealed.", "Achievement is unlocked.", "Achievement is incremented.", "Achievement progress is set to at least the passed value." ], "enum": [ "REVEAL", "UNLOCK", "INCREMENT", "SET_STEPS_AT_LEAST" ] }, "incrementPayload": { "description": "The payload if an update of type `INCREMENT` was requested for the achievement.", "$ref": "GamesAchievementIncrement" }, "setStepsAtLeastPayload": { "description": "The payload if an update of type `SET_STEPS_AT_LEAST` was requested for the achievement.", "$ref": "GamesAchievementSetStepsAtLeast" } } }, "GamesAchievementIncrement": { "id": "GamesAchievementIncrement", "description": "The payload to request to increment an achievement.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#GamesAchievementIncrement`.", "type": "string" }, "steps": { "description": "The number of steps to be incremented.", "type": "integer", "format": "int32" }, "requestId": { "description": "The requestId associated with an increment to an achievement.", "type": "string", "format": "int64" } } }, "GamesAchievementSetStepsAtLeast": { "id": "GamesAchievementSetStepsAtLeast", "description": "The payload to request to increment an achievement.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#GamesAchievementSetStepsAtLeast`.", "type": "string" }, "steps": { "description": "The minimum number of steps for the achievement to be set to.", "type": "integer", "format": "int32" } } }, "AchievementUpdateMultipleResponse": { "id": "AchievementUpdateMultipleResponse", "description": "Response message for UpdateMultipleAchievements rpc.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementUpdateMultipleResponse`.", "type": "string" }, "updatedAchievements": { "description": "The updated state of the achievements.", "type": "array", "items": { "$ref": "AchievementUpdateResponse" } } } }, "AchievementUpdateResponse": { "id": "AchievementUpdateResponse", "description": "An updated achievement.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#achievementUpdateResponse`.", "type": "string" }, "achievementId": { "description": "The achievement this update is was applied to.", "type": "string" }, "updateOccurred": { "description": "Whether the requested updates actually affected the achievement.", "type": "boolean" }, "currentState": { "description": "The current state of the achievement.", "type": "string", "enumDescriptions": [ "Achievement is hidden.", "Achievement is revealed.", "Achievement is unlocked." ], "enum": [ "HIDDEN", "REVEALED", "UNLOCKED" ] }, "currentSteps": { "description": "The current steps recorded for this achievement if it is incremental.", "type": "integer", "format": "int32" }, "newlyUnlocked": { "description": "Whether this achievement was newly unlocked (that is, whether the unlock request for the achievement was the first for the player).", "type": "boolean" } } }, "Application": { "id": "Application", "description": "The Application resource.", "type": "object", "properties": { "id": { "description": "The ID of the application.", "type": "string" }, "name": { "description": "The name of the application.", "type": "string" }, "author": { "description": "The author of the application.", "type": "string" }, "description": { "description": "The description of the application.", "type": "string" }, "category": { "description": "The category of the application.", "$ref": "ApplicationCategory" }, "assets": { "description": "The assets of the application.", "type": "array", "items": { "$ref": "ImageAsset" } }, "instances": { "description": "The instances of the application.", "type": "array", "items": { "$ref": "Instance" } }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#application`.", "type": "string" }, "lastUpdatedTimestamp": { "description": "The last updated timestamp of the application.", "type": "string", "format": "int64" }, "achievement_count": { "description": "The number of achievements visible to the currently authenticated player.", "type": "integer", "format": "int32" }, "leaderboard_count": { "description": "The number of leaderboards visible to the currently authenticated player.", "type": "integer", "format": "int32" }, "enabledFeatures": { "description": "A list of features that have been enabled for the application.", "type": "array", "items": { "type": "string", "enumDescriptions": [ "Saved Games (snapshots)." ], "enum": [ "SNAPSHOTS" ] } }, "themeColor": { "description": "A hint to the client UI for what color to use as an app-themed color. The color is given as an RGB triplet (e.g. \"E0E0E0\").", "type": "string" } } }, "ApplicationCategory": { "id": "ApplicationCategory", "description": "An application category object.", "type": "object", "properties": { "primary": { "description": "The primary category.", "type": "string" }, "secondary": { "description": "The secondary category.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#applicationCategory`.", "type": "string" } } }, "ImageAsset": { "id": "ImageAsset", "description": "An image asset object.", "type": "object", "properties": { "name": { "description": "The name of the asset.", "type": "string" }, "width": { "description": "The width of the asset.", "type": "integer", "format": "int32" }, "height": { "description": "The height of the asset.", "type": "integer", "format": "int32" }, "url": { "description": "The URL of the asset.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#imageAsset`.", "type": "string" } } }, "Instance": { "id": "Instance", "description": "The Instance resource.", "type": "object", "properties": { "platformType": { "description": "The platform type.", "type": "string", "enumDescriptions": [ "Instance is for Android.", "Instance is for iOS.", "Instance is for Web App." ], "enum": [ "ANDROID", "IOS", "WEB_APP" ] }, "name": { "description": "Localized display name.", "type": "string" }, "turnBasedPlay": { "description": "Flag to show if this game instance supports turn based play.", "type": "boolean" }, "realtimePlay": { "description": "Flag to show if this game instance supports realtime play.", "type": "boolean" }, "androidInstance": { "description": "Platform dependent details for Android.", "$ref": "InstanceAndroidDetails" }, "iosInstance": { "description": "Platform dependent details for iOS.", "$ref": "InstanceIosDetails" }, "webInstance": { "description": "Platform dependent details for Web.", "$ref": "InstanceWebDetails" }, "acquisitionUri": { "description": "URI which shows where a user can acquire this instance.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#instance`.", "type": "string" } } }, "InstanceAndroidDetails": { "id": "InstanceAndroidDetails", "description": "The Android instance details resource.", "type": "object", "properties": { "packageName": { "description": "Android package name which maps to Google Play URL.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#instanceAndroidDetails`.", "type": "string" }, "enablePiracyCheck": { "description": "Flag indicating whether the anti-piracy check is enabled.", "type": "boolean" }, "preferred": { "description": "Indicates that this instance is the default for new installations.", "type": "boolean" } } }, "InstanceIosDetails": { "id": "InstanceIosDetails", "description": "The iOS details resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#instanceIosDetails`.", "type": "string" }, "bundleIdentifier": { "description": "Bundle identifier.", "type": "string" }, "itunesAppId": { "description": "iTunes App ID.", "type": "string" }, "supportIphone": { "description": "Flag to indicate if this instance supports iPhone.", "type": "boolean" }, "supportIpad": { "description": "Flag to indicate if this instance supports iPad.", "type": "boolean" }, "preferredForIphone": { "description": "Indicates that this instance is the default for new installations on iPhone devices.", "type": "boolean" }, "preferredForIpad": { "description": "Indicates that this instance is the default for new installations on iPad devices.", "type": "boolean" } } }, "InstanceWebDetails": { "id": "InstanceWebDetails", "description": "The Web details resource.", "type": "object", "properties": { "launchUrl": { "description": "Launch URL for the game.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#instanceWebDetails`.", "type": "string" }, "preferred": { "description": "Indicates that this instance is the default for new installations.", "type": "boolean" } } }, "ApplicationVerifyResponse": { "id": "ApplicationVerifyResponse", "description": "A third party application verification response resource.", "type": "object", "properties": { "player_id": { "description": "The ID of the player that was issued the auth token used in this request.", "type": "string" }, "alternate_player_id": { "description": "An alternate ID that was once used for the player that was issued the auth token used in this request. (This field is not normally populated.)", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#applicationVerifyResponse`.", "type": "string" } } }, "EndPoint": { "id": "EndPoint", "description": "Container for a URL end point of the requested type.", "type": "object", "properties": { "url": { "description": "A URL suitable for loading in a web browser for the requested endpoint.", "type": "string" } } }, "PlayerEventListResponse": { "id": "PlayerEventListResponse", "description": "A ListByPlayer response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerEventListResponse`.", "type": "string" }, "nextPageToken": { "description": "The pagination token for the next page of results.", "type": "string" }, "items": { "description": "The player events.", "type": "array", "items": { "$ref": "PlayerEvent" } } } }, "PlayerEvent": { "id": "PlayerEvent", "description": "An event status resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerEvent`.", "type": "string" }, "definitionId": { "description": "The ID of the event definition.", "type": "string" }, "playerId": { "description": "The ID of the player.", "type": "string" }, "numEvents": { "description": "The current number of times this event has occurred.", "type": "string", "format": "int64" }, "formattedNumEvents": { "description": "The current number of times this event has occurred, as a string. The formatting of this string depends on the configuration of your event in the Play Games Developer Console.", "type": "string" } } }, "EventDefinitionListResponse": { "id": "EventDefinitionListResponse", "description": "A ListDefinitions response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventDefinitionListResponse`.", "type": "string" }, "nextPageToken": { "description": "The pagination token for the next page of results.", "type": "string" }, "items": { "description": "The event definitions.", "type": "array", "items": { "$ref": "EventDefinition" } } } }, "EventDefinition": { "id": "EventDefinition", "description": "An event definition resource.", "type": "object", "properties": { "id": { "description": "The ID of the event.", "type": "string" }, "visibility": { "description": "The visibility of event being tracked in this definition.", "type": "string", "enumDescriptions": [ "This event should be visible to all users.", "This event should only be shown to users that have recorded this event at least once." ], "enum": [ "REVEALED", "HIDDEN" ] }, "displayName": { "description": "The name to display for the event.", "type": "string" }, "imageUrl": { "description": "The base URL for the image that represents the event.", "type": "string" }, "childEvents": { "description": "A list of events that are a child of this event.", "type": "array", "items": { "$ref": "EventChild" } }, "description": { "description": "Description of what this event represents.", "type": "string" }, "isDefaultImageUrl": { "description": "Indicates whether the icon image being returned is a default image, or is game-provided.", "type": "boolean" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventDefinition`.", "type": "string" } } }, "EventChild": { "id": "EventChild", "description": "An event child relationship resource.", "type": "object", "properties": { "childId": { "description": "The ID of the child event.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventChild`.", "type": "string" } } }, "EventRecordRequest": { "id": "EventRecordRequest", "description": "An event period update resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventRecordRequest`.", "type": "string" }, "requestId": { "description": "The request ID used to identify this attempt to record events.", "type": "string", "format": "int64" }, "currentTimeMillis": { "description": "The current time when this update was sent, in milliseconds, since 1970 UTC (Unix Epoch).", "type": "string", "format": "int64" }, "timePeriods": { "description": "A list of the time period updates being made in this request.", "type": "array", "items": { "$ref": "EventPeriodUpdate" } } } }, "EventPeriodUpdate": { "id": "EventPeriodUpdate", "description": "An event period update resource.", "type": "object", "properties": { "timePeriod": { "description": "The time period being covered by this update.", "$ref": "EventPeriodRange" }, "updates": { "description": "The updates being made for this time period.", "type": "array", "items": { "$ref": "EventUpdateRequest" } }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventPeriodUpdate`.", "type": "string" } } }, "EventPeriodRange": { "id": "EventPeriodRange", "description": "An event period time range.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventPeriodRange`.", "type": "string" }, "periodStartMillis": { "description": "The time when this update period begins, in millis, since 1970 UTC (Unix Epoch).", "type": "string", "format": "int64" }, "periodEndMillis": { "description": "The time when this update period ends, in millis, since 1970 UTC (Unix Epoch).", "type": "string", "format": "int64" } } }, "EventUpdateRequest": { "id": "EventUpdateRequest", "description": "An event period update resource.", "type": "object", "properties": { "definitionId": { "description": "The ID of the event being modified in this update.", "type": "string" }, "updateCount": { "description": "The number of times this event occurred in this time period.", "type": "string", "format": "int64" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventUpdateRequest`.", "type": "string" } } }, "EventUpdateResponse": { "id": "EventUpdateResponse", "description": "An event period update resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventUpdateResponse`.", "type": "string" }, "batchFailures": { "description": "Any batch-wide failures which occurred applying updates.", "type": "array", "items": { "$ref": "EventBatchRecordFailure" } }, "eventFailures": { "description": "Any failures updating a particular event.", "type": "array", "items": { "$ref": "EventRecordFailure" } }, "playerEvents": { "description": "The current status of any updated events", "type": "array", "items": { "$ref": "PlayerEvent" } } } }, "EventBatchRecordFailure": { "id": "EventBatchRecordFailure", "description": "A batch update failure resource.", "type": "object", "properties": { "range": { "description": "The time range which was rejected; empty for a request-wide failure.", "$ref": "EventPeriodRange" }, "failureCause": { "description": "The cause for the update failure.", "type": "string", "enumDescriptions": [ "A batch request was issued with more events than are allowed in a single batch.", "A batch was sent with data too far in the past to record.", "A batch was sent with a time range that was too short.", "A batch was sent with a time range that was too long.", "An attempt was made to record a batch of data which was already seen.", "An attempt was made to record data faster than the server will apply updates." ], "enum": [ "TOO_LARGE", "TIME_PERIOD_EXPIRED", "TIME_PERIOD_SHORT", "TIME_PERIOD_LONG", "ALREADY_UPDATED", "RECORD_RATE_HIGH" ] }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventBatchRecordFailure`.", "type": "string" } } }, "EventRecordFailure": { "id": "EventRecordFailure", "description": "An event update failure resource.", "type": "object", "properties": { "eventId": { "description": "The ID of the event that was not updated.", "type": "string" }, "failureCause": { "description": "The cause for the update failure.", "type": "string", "enumDescriptions": [ "An attempt was made to set an event that was not defined.", "An attempt was made to increment an event by a non-positive value." ], "enum": [ "NOT_FOUND", "INVALID_UPDATE_VALUE" ] }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#eventRecordFailure`.", "type": "string" } } }, "Leaderboard": { "id": "Leaderboard", "description": "The Leaderboard resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#leaderboard`.", "type": "string" }, "id": { "description": "The leaderboard ID.", "type": "string" }, "name": { "description": "The name of the leaderboard.", "type": "string" }, "iconUrl": { "description": "The icon for the leaderboard.", "type": "string" }, "isIconUrlDefault": { "description": "Indicates whether the icon image being returned is a default image, or is game-provided.", "type": "boolean" }, "order": { "description": "How scores are ordered.", "type": "string", "enumDescriptions": [ "Larger values are better; scores are sorted in descending order", "Smaller values are better; scores are sorted in ascending order" ], "enum": [ "LARGER_IS_BETTER", "SMALLER_IS_BETTER" ] } } }, "LeaderboardListResponse": { "id": "LeaderboardListResponse", "description": "A list of leaderboard objects.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#leaderboardListResponse`.", "type": "string" }, "nextPageToken": { "description": "Token corresponding to the next page of results.", "type": "string" }, "items": { "description": "The leaderboards.", "type": "array", "items": { "$ref": "Leaderboard" } } } }, "MetagameConfig": { "id": "MetagameConfig", "description": "The metagame config resource", "type": "object", "properties": { "currentVersion": { "description": "Current version of the metagame configuration data. When this data is updated, the version number will be increased by one.", "type": "integer", "format": "int32" }, "playerLevels": { "description": "The list of player levels.", "type": "array", "items": { "$ref": "PlayerLevel" } }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#metagameConfig`.", "type": "string" } } }, "PlayerLevel": { "id": "PlayerLevel", "description": "1P/3P metadata about a user's level.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerLevel`.", "type": "string" }, "level": { "description": "The level for the user.", "type": "integer", "format": "int32" }, "minExperiencePoints": { "description": "The minimum experience points for this level.", "type": "string", "format": "int64" }, "maxExperiencePoints": { "description": "The maximum experience points for this level.", "type": "string", "format": "int64" } } }, "CategoryListResponse": { "id": "CategoryListResponse", "description": "A third party list metagame categories response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#categoryListResponse`.", "type": "string" }, "nextPageToken": { "description": "Token corresponding to the next page of results.", "type": "string" }, "items": { "description": "The list of categories with usage data.", "type": "array", "items": { "$ref": "Category" } } } }, "Category": { "id": "Category", "description": "Data related to individual game categories.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#category`.", "type": "string" }, "category": { "description": "The category name.", "type": "string" }, "experiencePoints": { "description": "Experience points earned in this category.", "type": "string", "format": "int64" } } }, "Player": { "id": "Player", "description": "A Player resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#player`", "type": "string" }, "playerId": { "description": "The ID of the player.", "type": "string" }, "displayName": { "description": "The name to display for the player.", "type": "string" }, "avatarImageUrl": { "description": "The base URL for the image that represents the player.", "type": "string" }, "bannerUrlPortrait": { "description": "The url to the portrait mode player banner image.", "type": "string" }, "bannerUrlLandscape": { "description": "The url to the landscape mode player banner image.", "type": "string" }, "originalPlayerId": { "description": "The player ID that was used for this player the first time they signed into the game in question. This is only populated for calls to player.get for the requesting player, only if the player ID has subsequently changed, and only to clients that support remapping player IDs.", "type": "string" }, "profileSettings": { "description": "The player's profile settings. Controls whether or not the player's profile is visible to other players.", "$ref": "ProfileSettings" }, "name": { "description": "A representation of the individual components of the name.", "type": "object", "properties": { "familyName": { "description": "The family name of this player. In some places, this is known as the last name.", "type": "string" }, "givenName": { "description": "The given name of this player. In some places, this is known as the first name.", "type": "string" } } }, "experienceInfo": { "description": "An object to represent Play Game experience information for the player.", "$ref": "PlayerExperienceInfo" }, "title": { "description": "The player's title rewarded for their game activities.", "type": "string" }, "friendStatus": { "description": "The friend status of the given player, relative to the requester. This is unset if the player is not sharing their friends list with the game.", "type": "string", "enumDescriptions": [ "There is no relationship between the players.", "The player and requester are friends." ], "enum": [ "NO_RELATIONSHIP", "FRIEND" ] }, "gamePlayerId": { "description": "Per-application unique player identifier.", "type": "string" } } }, "ProfileSettings": { "id": "ProfileSettings", "description": "Profile settings", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#profileSettings`.", "type": "string" }, "profileVisible": { "description": "Whether the player's profile is visible to the currently signed in player.", "type": "boolean" }, "friendsListVisibility": { "type": "string", "enumDescriptions": [ "The friends list is currently visible to the game.", "The developer does not have access to the friends list, but can call the Android API to show a consent dialog.", "The friends list is currently unavailable for this user, and it is not possible to request access at this time, either because the user has permanently declined or the friends feature is not available to them. In this state, any attempts to request access to the friends list will be unsuccessful." ], "enum": [ "VISIBLE", "REQUEST_REQUIRED", "UNAVAILABLE" ] } } }, "PlayerExperienceInfo": { "id": "PlayerExperienceInfo", "description": "1P/3P metadata about the player's experience.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerExperienceInfo`.", "type": "string" }, "currentExperiencePoints": { "description": "The current number of experience points for the player.", "type": "string", "format": "int64" }, "lastLevelUpTimestampMillis": { "description": "The timestamp when the player was leveled up, in millis since Unix epoch UTC.", "type": "string", "format": "int64" }, "currentLevel": { "description": "The current level of the player.", "$ref": "PlayerLevel" }, "nextLevel": { "description": "The next level of the player. If the current level is the maximum level, this should be same as the current level.", "$ref": "PlayerLevel" } } }, "ScopedPlayerIds": { "id": "ScopedPlayerIds", "description": "Scoped player identifiers.", "type": "object", "properties": { "gamePlayerId": { "description": "Game-scoped player identifier. This is the same id that is returned in GetPlayer game_player_id field.", "type": "string" }, "developerPlayerKey": { "description": "Identifier of the player across all games of the given developer. Every player has the same developer_player_key in all games of one developer. Developer player key changes for the game if the game is transferred to another developer. Note that game_player_id will stay unchanged.", "type": "string" } } }, "GetMultipleApplicationPlayerIdsResponse": { "id": "GetMultipleApplicationPlayerIdsResponse", "description": "Response message for GetMultipleApplicationPlayerIds rpc.", "type": "object", "properties": { "playerIds": { "description": "Output only. The requested applications along with the scoped ids for tha player, if that player has an id for the application. If not, the application is not included in the response.", "readOnly": true, "type": "array", "items": { "$ref": "ApplicationPlayerId" } } } }, "ApplicationPlayerId": { "id": "ApplicationPlayerId", "description": "Primary scoped player identifier for an application.", "type": "object", "properties": { "applicationId": { "description": "The application that this player identifier is for.", "type": "string" }, "playerId": { "description": "The player identifier for the application.", "type": "string" } } }, "PlayerListResponse": { "id": "PlayerListResponse", "description": "A third party player list response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerListResponse`.", "type": "string" }, "nextPageToken": { "description": "Token corresponding to the next page of results.", "type": "string" }, "items": { "description": "The players.", "type": "array", "items": { "$ref": "Player" } } } }, "RevisionCheckResponse": { "id": "RevisionCheckResponse", "description": "A third party checking a revision response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#revisionCheckResponse`.", "type": "string" }, "revisionStatus": { "description": "The result of the revision check.", "type": "string", "enumDescriptions": [ "The revision being used is current.", "There is currently a newer version available, but the revision being used still works.", "The revision being used is not supported in any released version." ], "enum": [ "OK", "DEPRECATED", "INVALID" ] }, "apiVersion": { "description": "The version of the API this client revision should use when calling API methods.", "type": "string" } } }, "PlayerLeaderboardScoreListResponse": { "id": "PlayerLeaderboardScoreListResponse", "description": "A list of player leaderboard scores.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerLeaderboardScoreListResponse`.", "type": "string" }, "nextPageToken": { "description": "The pagination token for the next page of results.", "type": "string" }, "player": { "description": "The Player resources for the owner of this score.", "$ref": "Player" }, "items": { "description": "The leaderboard scores.", "type": "array", "items": { "$ref": "PlayerLeaderboardScore" } } } }, "PlayerLeaderboardScore": { "id": "PlayerLeaderboardScore", "description": "A player leaderboard score object.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerLeaderboardScore`.", "type": "string" }, "leaderboard_id": { "description": "The ID of the leaderboard this score is in.", "type": "string" }, "scoreValue": { "description": "The numerical value of this score.", "type": "string", "format": "int64" }, "scoreString": { "description": "The formatted value of this score.", "type": "string" }, "publicRank": { "description": "The public rank of the score in this leaderboard. This object will not be present if the user is not sharing their scores publicly.", "$ref": "LeaderboardScoreRank" }, "socialRank": { "description": "The social rank of the score in this leaderboard.", "$ref": "LeaderboardScoreRank" }, "friendsRank": { "description": "The rank of the score in the friends collection for this leaderboard.", "$ref": "LeaderboardScoreRank" }, "timeSpan": { "description": "The time span of this score.", "type": "string", "enumDescriptions": [ "The score is an all-time score.", "The score is a weekly score.", "The score is a daily score." ], "enum": [ "ALL_TIME", "WEEKLY", "DAILY" ] }, "writeTimestamp": { "description": "The timestamp at which this score was recorded, in milliseconds since the epoch in UTC.", "type": "string", "format": "int64" }, "scoreTag": { "description": "Additional information about the score. Values must contain no more than 64 URI-safe characters as defined by section 2.3 of RFC 3986.", "type": "string" } } }, "LeaderboardScoreRank": { "id": "LeaderboardScoreRank", "description": "A score rank in a leaderboard.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#leaderboardScoreRank`.", "type": "string" }, "rank": { "description": "The rank in the leaderboard.", "type": "string", "format": "int64" }, "formattedRank": { "description": "The rank in the leaderboard as a string.", "type": "string" }, "numScores": { "description": "The number of scores in the leaderboard.", "type": "string", "format": "int64" }, "formattedNumScores": { "description": "The number of scores in the leaderboard as a string.", "type": "string" } } }, "LeaderboardScores": { "id": "LeaderboardScores", "description": "A ListScores response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#leaderboardScores`.", "type": "string" }, "nextPageToken": { "description": "The pagination token for the next page of results.", "type": "string" }, "prevPageToken": { "description": "The pagination token for the previous page of results.", "type": "string" }, "numScores": { "description": "The total number of scores in the leaderboard.", "type": "string", "format": "int64" }, "playerScore": { "description": "The score of the requesting player on the leaderboard. The player's score may appear both here and in the list of scores above. If you are viewing a public leaderboard and the player is not sharing their gameplay information publicly, the `scoreRank`and `formattedScoreRank` values will not be present.", "$ref": "LeaderboardEntry" }, "items": { "description": "The scores in the leaderboard.", "type": "array", "items": { "$ref": "LeaderboardEntry" } } } }, "LeaderboardEntry": { "id": "LeaderboardEntry", "description": "The Leaderboard Entry resource.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#leaderboardEntry`.", "type": "string" }, "player": { "description": "The player who holds this score.", "$ref": "Player" }, "scoreRank": { "description": "The rank of this score for this leaderboard.", "type": "string", "format": "int64" }, "formattedScoreRank": { "description": "The localized string for the rank of this score for this leaderboard.", "type": "string" }, "scoreValue": { "description": "The numerical value of this score.", "type": "string", "format": "int64" }, "formattedScore": { "description": "The localized string for the numerical value of this score.", "type": "string" }, "timeSpan": { "description": "The time span of this high score.", "type": "string", "enumDescriptions": [ "The score is an all-time score.", "The score is a weekly score.", "The score is a daily score." ], "enum": [ "ALL_TIME", "WEEKLY", "DAILY" ] }, "writeTimestampMillis": { "description": "The timestamp at which this score was recorded, in milliseconds since the epoch in UTC.", "type": "string", "format": "int64" }, "scoreTag": { "description": "Additional information about the score. Values must contain no more than 64 URI-safe characters as defined by section 2.3 of RFC 3986.", "type": "string" } } }, "PlayerScoreResponse": { "id": "PlayerScoreResponse", "description": "A list of leaderboard entry resources.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerScoreResponse`.", "type": "string" }, "beatenScoreTimeSpans": { "description": "The time spans where the submitted score is better than the existing score for that time span.", "type": "array", "items": { "type": "string", "enumDescriptions": [ "The score is an all-time score.", "The score is a weekly score.", "The score is a daily score." ], "enum": [ "ALL_TIME", "WEEKLY", "DAILY" ] } }, "unbeatenScores": { "description": "The scores in time spans that have not been beaten. As an example, the submitted score may be better than the player's `DAILY` score, but not better than the player's scores for the `WEEKLY` or `ALL_TIME` time spans.", "type": "array", "items": { "$ref": "PlayerScore" } }, "formattedScore": { "description": "The formatted value of the submitted score.", "type": "string" }, "leaderboardId": { "description": "The leaderboard ID that this score was submitted to.", "type": "string" }, "scoreTag": { "description": "Additional information about this score. Values will contain no more than 64 URI-safe characters as defined by section 2.3 of RFC 3986.", "type": "string" } } }, "PlayerScore": { "id": "PlayerScore", "description": "A player score.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerScore`.", "type": "string" }, "timeSpan": { "description": "The time span for this player score.", "type": "string", "enumDescriptions": [ "The score is an all-time score.", "The score is a weekly score.", "The score is a daily score." ], "enum": [ "ALL_TIME", "WEEKLY", "DAILY" ] }, "score": { "description": "The numerical value for this player score.", "type": "string", "format": "int64" }, "formattedScore": { "description": "The formatted score for this player score.", "type": "string" }, "scoreTag": { "description": "Additional information about this score. Values will contain no more than 64 URI-safe characters as defined by section 2.3 of RFC 3986.", "type": "string" } } }, "PlayerScoreSubmissionList": { "id": "PlayerScoreSubmissionList", "description": "A list of score submission requests.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerScoreSubmissionList`.", "type": "string" }, "scores": { "description": "The score submissions.", "type": "array", "items": { "$ref": "ScoreSubmission" } } } }, "ScoreSubmission": { "id": "ScoreSubmission", "description": "A request to submit a score to leaderboards.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#scoreSubmission`.", "type": "string" }, "leaderboardId": { "description": "The leaderboard this score is being submitted to.", "type": "string" }, "score": { "description": "The new score being submitted.", "type": "string", "format": "int64" }, "scoreTag": { "description": "Additional information about this score. Values will contain no more than 64 URI-safe characters as defined by section 2.3 of RFC 3986.", "type": "string" }, "signature": { "description": "Signature Values will contain URI-safe characters as defined by section 2.3 of RFC 3986.", "type": "string" } } }, "PlayerScoreListResponse": { "id": "PlayerScoreListResponse", "description": "A list of score submission statuses.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#playerScoreListResponse`.", "type": "string" }, "submittedScores": { "description": "The score submissions statuses.", "type": "array", "items": { "$ref": "PlayerScoreResponse" } } } }, "Snapshot": { "id": "Snapshot", "description": "An snapshot object.", "type": "object", "properties": { "id": { "description": "The ID of the snapshot.", "type": "string" }, "driveId": { "description": "The ID of the file underlying this snapshot in the Drive API. Only present if the snapshot is a view on a Drive file and the file is owned by the caller.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#snapshot`.", "type": "string" }, "type": { "description": "The type of this snapshot.", "type": "string", "enumDescriptions": [ "A snapshot representing a save game." ], "enum": [ "SAVE_GAME" ] }, "title": { "description": "The title of this snapshot.", "type": "string" }, "description": { "description": "The description of this snapshot.", "type": "string" }, "lastModifiedMillis": { "description": "The timestamp (in millis since Unix epoch) of the last modification to this snapshot.", "type": "string", "format": "int64" }, "durationMillis": { "description": "The duration associated with this snapshot, in millis.", "type": "string", "format": "int64" }, "coverImage": { "description": "The cover image of this snapshot. May be absent if there is no image.", "$ref": "SnapshotImage" }, "uniqueName": { "description": "The unique name provided when the snapshot was created.", "type": "string" }, "progressValue": { "description": "The progress value (64-bit integer set by developer) associated with this snapshot.", "type": "string", "format": "int64" } } }, "SnapshotImage": { "id": "SnapshotImage", "description": "An image of a snapshot.", "type": "object", "properties": { "width": { "description": "The width of the image.", "type": "integer", "format": "int32" }, "height": { "description": "The height of the image.", "type": "integer", "format": "int32" }, "mime_type": { "description": "The MIME type of the image.", "type": "string" }, "url": { "description": "The URL of the image. This URL may be invalidated at any time and should not be cached.", "type": "string" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#snapshotImage`.", "type": "string" } } }, "SnapshotListResponse": { "id": "SnapshotListResponse", "description": "A third party list snapshots response.", "type": "object", "properties": { "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#snapshotListResponse`.", "type": "string" }, "nextPageToken": { "description": "Token corresponding to the next page of results. If there are no more results, the token is omitted.", "type": "string" }, "items": { "description": "The snapshots.", "type": "array", "items": { "$ref": "Snapshot" } } } }, "StatsResponse": { "id": "StatsResponse", "description": "A third party stats resource.", "type": "object", "properties": { "churn_probability": { "description": "The probability of the player not returning to play the game in the next day. E.g., 0, 0.1, 0.5, ..., 1.0. Not populated if there is not enough information.", "type": "number", "format": "float" }, "num_purchases": { "description": "Number of in-app purchases made by the player in this game. E.g., 0, 1, 5, 10, ... . Not populated if there is not enough information.", "type": "integer", "format": "int32" }, "spend_percentile": { "description": "The approximate spend percentile of the player in this game. E.g., 0, 0.25, 0.5, 0.75. Not populated if there is not enough information.", "type": "number", "format": "float" }, "days_since_last_played": { "description": "Number of days since the player last played this game. E.g., 0, 1, 5, 10, ... . Not populated if there is not enough information.", "type": "integer", "format": "int32" }, "num_sessions": { "description": "The approximate number of sessions of the player within the last 28 days, where a session begins when the player is connected to Play Games Services and ends when they are disconnected. E.g., 0, 1, 5, 10, ... . Not populated if there is not enough information.", "type": "integer", "format": "int32" }, "num_sessions_percentile": { "description": "The approximation of the sessions percentile of the player within the last 30 days, where a session begins when the player is connected to Play Games Services and ends when they are disconnected. E.g., 0, 0.25, 0.5, 0.75. Not populated if there is not enough information.", "type": "number", "format": "float" }, "avg_session_length_minutes": { "description": "Average session length in minutes of the player. E.g., 1, 30, 60, ... . Not populated if there is not enough information.", "type": "number", "format": "float" }, "spend_probability": { "description": "The probability of the player going to spend the game in the next seven days. E.g., 0, 0.25, 0.50, 0.75. Not populated if there is not enough information.", "type": "number", "format": "float" }, "high_spender_probability": { "description": "The probability of the player going to spend beyond a threshold amount of money. E.g., 0, 0.25, 0.50, 0.75. Not populated if there is not enough information.", "type": "number", "format": "float" }, "total_spend_next_28_days": { "description": "The predicted amount of money that the player going to spend in the next 28 days. E.g., 1, 30, 60, ... . Not populated if there is not enough information.", "type": "number", "format": "float" }, "kind": { "description": "Uniquely identifies the type of this resource. Value is always the fixed string `games#statsResponse`.", "type": "string" } } }, "LinkPersonaRequest": { "id": "LinkPersonaRequest", "description": "Request to link an in-game account with a PGS principal (encoded in the session id).", "type": "object", "properties": { "sessionId": { "description": "Required. Opaque server-generated string that encodes all the necessary information to identify the PGS player / Google user and application.", "type": "string" }, "persona": { "description": "Required. Stable identifier of the in-game account. Please refrain from re-using the same persona for different games.", "type": "string" }, "token": { "description": "Required. Value of the token to create. Opaque to Play Games and assumed to be non-stable (encrypted with key rotation).", "type": "string" }, "cardinalityConstraint": { "description": "Required. Cardinality constraint to observe when linking a persona to a player in the scope of a game.", "type": "string", "enumDescriptions": [ "1:1 cardinality between in-game personas and Play Games Services players. By the end of the linking operation only one entry for the player and the persona should remain in the scope of the application. Whether a new link is created or not when this constraint is specified is determined by the chosen `ConflictingLinksResolutionPolicy`: * If `KEEP_EXISTING_LINKS` is specified and the provided persona is already linked to a different player, or the player is already linked to a different persona, no new link will be created and the already existing link(s) will remain as is(are). * If `CREATE_NEW_LINK` is specified and the provided persona is already linked to a different player, or the player is already linked to another persona, the older link(s) will be removed in favour of the new link being created." ], "enum": [ "ONE_PERSONA_TO_ONE_PLAYER" ] }, "conflictingLinksResolutionPolicy": { "description": "Required. Resolution policy to apply when the linking of a persona to a player would result in violating the specified cardinality constraint.", "type": "string", "enumDescriptions": [ "If link(s) between a player and persona already exists which would result in violating the specified `RecallTokensCardinalityConstraint` if the new link was created, keep the already existing link(s). For example, if Persona1-Player1 is already linked in the scope of application1 and a new link Persona1-Player2 is attempted to be created in the scope of application1, then the old link will remain and no new link will be added. Note that if the already existing links do violate the specified policy (which could occur if not all `LinkPersona` calls use the same `RecallTokensCardinalityConstraint`) this policy will leave these violations unresolved; in order to resolve conflicts, the {@link `CREATE_NEW_LINK` policy needs to be used to rewrite links resolving conflicts.", "If an existing link between a player and persona already exists which would result in violating the specified `RecallTokensCardinalityConstraint` if the new link was created, replace the already existing link(s) with the new link. For example, if Persona1-Player1 is already linked in the scope of application1 and a new link Persona1-Player2 is attempted to be created in the scope of application1, then the old link will be removed and the new link will be added to replace it." ], "enum": [ "KEEP_EXISTING_LINKS", "CREATE_NEW_LINK" ] }, "expireTime": { "description": "Input only. Optional expiration time.", "type": "string", "format": "google-datetime" }, "ttl": { "description": "Input only. Optional time-to-live.", "type": "string", "format": "google-duration" } } }, "LinkPersonaResponse": { "id": "LinkPersonaResponse", "description": "Outcome of a persona linking attempt.", "type": "object", "properties": { "state": { "description": "Output only. State of a persona linking attempt.", "readOnly": true, "type": "string", "enumDescriptions": [ "The link specified in the request was created.", "The link specified in the request was not created because already existing links would result in the new link violating the specified `RecallTokensCardinalityConstraint` if created." ], "enum": [ "LINK_CREATED", "PERSONA_OR_PLAYER_ALREADY_LINKED" ] } } }, "RetrievePlayerTokensResponse": { "id": "RetrievePlayerTokensResponse", "description": "Response for the RetrievePlayerTokens RPC", "type": "object", "properties": { "tokens": { "description": "Required. Recall tokens associated with the requested PGS Player principal", "type": "array", "items": { "$ref": "RecallToken" } } } }, "RecallToken": { "id": "RecallToken", "description": "Recall token data returned from RetrievePlayerTokens RPC", "type": "object", "properties": { "token": { "description": "Required. Value of the Recall token as it is provided by the client via LinkPersona RPC", "type": "string" }, "multiPlayerPersona": { "description": "Required. Whether the persona identified by the token is linked to multiple PGS Players", "type": "boolean" }, "expireTime": { "description": "Optional. Optional expiration time of the token", "type": "string", "format": "google-datetime" } } }, "RetrieveDeveloperGamesLastPlayerTokenResponse": { "id": "RetrieveDeveloperGamesLastPlayerTokenResponse", "description": "Recall token data returned from for the RetrieveDeveloperGamesLastPlayerToken RPC", "type": "object", "properties": { "token": { "description": "The recall token associated with the requested PGS Player principal. It can be unset if there is no recall token associated with the requested principal.", "$ref": "RecallToken" } } }, "UnlinkPersonaRequest": { "id": "UnlinkPersonaRequest", "description": "Request to remove a Recall token linking PGS principal and an in-game account", "type": "object", "properties": { "sessionId": { "description": "Required. Opaque server-generated string that encodes all the necessary information to identify the PGS player / Google user and application.", "type": "string" }, "token": { "description": "Value of the Recall token as it was provided by the client in LinkPersona RPC", "type": "string" }, "persona": { "description": "Value of the 'persona' field as it was provided by the client in LinkPersona RPC", "type": "string" } } }, "UnlinkPersonaResponse": { "id": "UnlinkPersonaResponse", "description": "Response for the UnlinkPersona RPC", "type": "object", "properties": { "unlinked": { "description": "Required. Whether a Recall token specified by the request was deleted. Can be 'false' when there were no Recall tokens satisfied the criteria from the request.", "type": "boolean" } } }, "ResetPersonaRequest": { "id": "ResetPersonaRequest", "description": "Request to remove all Recall tokens associated with a persona for an app.", "type": "object", "properties": { "persona": { "description": "Value of the 'persona' field as it was provided by the client in LinkPersona RPC", "type": "string" } } }, "ResetPersonaResponse": { "id": "ResetPersonaResponse", "description": "Response for the ResetPersona RPC", "type": "object", "properties": { "unlinked": { "description": "Required. Whether any tokens were unlinked as a result of this request.", "type": "boolean" } } } }, "mtlsRootUrl": "https://games.mtls.googleapis.com/", "canonicalName": "Games", "resources": { "achievementDefinitions": { "methods": { "list": { "id": "games.achievementDefinitions.list", "path": "games/v1/achievements", "flatPath": "games/v1/achievements", "httpMethod": "GET", "parameters": { "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of achievement resources to return in the response, used for paging. For any response, the actual number of achievement resources returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [], "response": { "$ref": "AchievementDefinitionsListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Lists all the achievement definitions for your application." } } }, "achievements": { "methods": { "increment": { "id": "games.achievements.increment", "path": "games/v1/achievements/{achievementId}/increment", "flatPath": "games/v1/achievements/{achievementId}/increment", "httpMethod": "POST", "parameters": { "achievementId": { "description": "The ID of the achievement used by this method.", "location": "path", "required": true, "type": "string" }, "requestId": { "description": "A randomly generated numeric ID for each request specified by the caller. This number is used at the server to ensure that the request is handled correctly across retries.", "location": "query", "type": "string", "format": "int64" }, "stepsToIncrement": { "description": "Required. The number of steps to increment.", "location": "query", "required": true, "type": "integer", "format": "int32" } }, "parameterOrder": [ "achievementId", "stepsToIncrement" ], "response": { "$ref": "AchievementIncrementResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Increments the steps of the achievement with the given ID for the currently authenticated player." }, "list": { "id": "games.achievements.list", "path": "games/v1/players/{playerId}/achievements", "flatPath": "games/v1/players/{playerId}/achievements", "httpMethod": "GET", "parameters": { "playerId": { "description": "A player ID. A value of `me` may be used in place of the authenticated player's ID.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of achievement resources to return in the response, used for paging. For any response, the actual number of achievement resources returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" }, "state": { "description": "Tells the server to return only achievements with the specified state. If this parameter isn't specified, all achievements are returned.", "location": "query", "type": "string", "enumDescriptions": [ "List all achievements. This is the default.", "List only hidden achievements.", "List only revealed achievements.", "List only unlocked achievements." ], "enum": [ "ALL", "HIDDEN", "REVEALED", "UNLOCKED" ] } }, "parameterOrder": [ "playerId" ], "response": { "$ref": "PlayerAchievementListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Lists the progress for all your application's achievements for the currently authenticated player." }, "reveal": { "id": "games.achievements.reveal", "path": "games/v1/achievements/{achievementId}/reveal", "flatPath": "games/v1/achievements/{achievementId}/reveal", "httpMethod": "POST", "parameters": { "achievementId": { "description": "The ID of the achievement used by this method.", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "achievementId" ], "response": { "$ref": "AchievementRevealResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Sets the state of the achievement with the given ID to `REVEALED` for the currently authenticated player." }, "setStepsAtLeast": { "id": "games.achievements.setStepsAtLeast", "path": "games/v1/achievements/{achievementId}/setStepsAtLeast", "flatPath": "games/v1/achievements/{achievementId}/setStepsAtLeast", "httpMethod": "POST", "parameters": { "achievementId": { "description": "The ID of the achievement used by this method.", "location": "path", "required": true, "type": "string" }, "steps": { "description": "Required. The minimum value to set the steps to.", "location": "query", "required": true, "type": "integer", "format": "int32" } }, "parameterOrder": [ "achievementId", "steps" ], "response": { "$ref": "AchievementSetStepsAtLeastResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Sets the steps for the currently authenticated player towards unlocking an achievement. If the steps parameter is less than the current number of steps that the player already gained for the achievement, the achievement is not modified." }, "unlock": { "id": "games.achievements.unlock", "path": "games/v1/achievements/{achievementId}/unlock", "flatPath": "games/v1/achievements/{achievementId}/unlock", "httpMethod": "POST", "parameters": { "achievementId": { "description": "The ID of the achievement used by this method.", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "achievementId" ], "response": { "$ref": "AchievementUnlockResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Unlocks this achievement for the currently authenticated player." }, "updateMultiple": { "id": "games.achievements.updateMultiple", "path": "games/v1/achievements/updateMultiple", "flatPath": "games/v1/achievements/updateMultiple", "httpMethod": "POST", "parameters": {}, "parameterOrder": [], "request": { "$ref": "AchievementUpdateMultipleRequest" }, "response": { "$ref": "AchievementUpdateMultipleResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Updates multiple achievements for the currently authenticated player." } } }, "applications": { "methods": { "get": { "id": "games.applications.get", "path": "games/v1/applications/{applicationId}", "flatPath": "games/v1/applications/{applicationId}", "httpMethod": "GET", "parameters": { "applicationId": { "description": "The application ID from the Google Play developer console.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "platformType": { "description": "Restrict application details returned to the specific platform.", "location": "query", "type": "string", "enumDescriptions": [ "Retrieve applications that can be played on Android.", "Retrieve applications that can be played on iOS.", "Retrieve applications that can be played on desktop web." ], "enum": [ "ANDROID", "IOS", "WEB_APP" ] } }, "parameterOrder": [ "applicationId" ], "response": { "$ref": "Application" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Retrieves the metadata of the application with the given ID. If the requested application is not available for the specified `platformType`, the returned response will not include any instance data." }, "played": { "id": "games.applications.played", "path": "games/v1/applications/played", "flatPath": "games/v1/applications/played", "httpMethod": "POST", "parameters": {}, "parameterOrder": [], "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Indicate that the currently authenticated user is playing your application." }, "verify": { "id": "games.applications.verify", "path": "games/v1/applications/{applicationId}/verify", "flatPath": "games/v1/applications/{applicationId}/verify", "httpMethod": "GET", "parameters": { "applicationId": { "description": "The application ID from the Google Play developer console.", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "applicationId" ], "response": { "$ref": "ApplicationVerifyResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Verifies the auth token provided with this request is for the application with the specified ID, and returns the ID of the player it was granted for." }, "getEndPoint": { "id": "games.applications.getEndPoint", "path": "games/v1/applications/getEndPoint", "flatPath": "games/v1/applications/getEndPoint", "httpMethod": "POST", "parameters": { "applicationId": { "description": "The application ID from the Google Play developer console.", "location": "query", "type": "string" }, "endPointType": { "description": "Type of endpoint being requested.", "location": "query", "type": "string", "enumDescriptions": [ "Request a URL to create a new profile.", "Request a URL for the Settings view." ], "enum": [ "PROFILE_CREATION", "PROFILE_SETTINGS" ] } }, "parameterOrder": [], "response": { "$ref": "EndPoint" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Returns a URL for the requested end point type." } } }, "events": { "methods": { "listByPlayer": { "id": "games.events.listByPlayer", "path": "games/v1/events", "flatPath": "games/v1/events", "httpMethod": "GET", "parameters": { "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of events to return in the response, used for paging. For any response, the actual number of events to return may be less than the specified maxResults.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [], "response": { "$ref": "PlayerEventListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Returns a list showing the current progress on events in this application for the currently authenticated user." }, "listDefinitions": { "id": "games.events.listDefinitions", "path": "games/v1/eventDefinitions", "flatPath": "games/v1/eventDefinitions", "httpMethod": "GET", "parameters": { "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of event definitions to return in the response, used for paging. For any response, the actual number of event definitions to return may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [], "response": { "$ref": "EventDefinitionListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Returns a list of the event definitions in this application." }, "record": { "id": "games.events.record", "path": "games/v1/events", "flatPath": "games/v1/events", "httpMethod": "POST", "parameters": { "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" } }, "parameterOrder": [], "request": { "$ref": "EventRecordRequest" }, "response": { "$ref": "EventUpdateResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Records a batch of changes to the number of times events have occurred for the currently authenticated user of this application." } } }, "leaderboards": { "methods": { "get": { "id": "games.leaderboards.get", "path": "games/v1/leaderboards/{leaderboardId}", "flatPath": "games/v1/leaderboards/{leaderboardId}", "httpMethod": "GET", "parameters": { "leaderboardId": { "description": "The ID of the leaderboard.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" } }, "parameterOrder": [ "leaderboardId" ], "response": { "$ref": "Leaderboard" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Retrieves the metadata of the leaderboard with the given ID." }, "list": { "id": "games.leaderboards.list", "path": "games/v1/leaderboards", "flatPath": "games/v1/leaderboards", "httpMethod": "GET", "parameters": { "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of leaderboards to return in the response. For any response, the actual number of leaderboards returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [], "response": { "$ref": "LeaderboardListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Lists all the leaderboard metadata for your application." } } }, "metagame": { "methods": { "getMetagameConfig": { "id": "games.metagame.getMetagameConfig", "path": "games/v1/metagameConfig", "flatPath": "games/v1/metagameConfig", "httpMethod": "GET", "parameters": {}, "parameterOrder": [], "response": { "$ref": "MetagameConfig" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Return the metagame configuration data for the calling application." }, "listCategoriesByPlayer": { "id": "games.metagame.listCategoriesByPlayer", "path": "games/v1/players/{playerId}/categories/{collection}", "flatPath": "games/v1/players/{playerId}/categories/{collection}", "httpMethod": "GET", "parameters": { "playerId": { "description": "A player ID. A value of `me` may be used in place of the authenticated player's ID.", "location": "path", "required": true, "type": "string" }, "collection": { "description": "The collection of categories for which data will be returned.", "location": "path", "required": true, "type": "string", "enumDescriptions": [ "Retrieve data for all categories. This is the default." ], "enum": [ "ALL" ] }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of category resources to return in the response, used for paging. For any response, the actual number of category resources returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [ "playerId", "collection" ], "response": { "$ref": "CategoryListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "List play data aggregated per category for the player corresponding to `playerId`." } } }, "players": { "methods": { "get": { "id": "games.players.get", "path": "games/v1/players/{playerId}", "flatPath": "games/v1/players/{playerId}", "httpMethod": "GET", "parameters": { "playerId": { "description": "A player ID. A value of `me` may be used in place of the authenticated player's ID.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "playerIdConsistencyToken": { "description": "Consistency token of the player id. The call returns a 'not found' result when the token is present and invalid. Empty value is ignored. See also GlobalPlayerIdConsistencyTokenProto", "location": "query", "type": "string" } }, "parameterOrder": [ "playerId" ], "response": { "$ref": "Player" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Retrieves the Player resource with the given ID. To retrieve the player for the currently authenticated user, set `playerId` to `me`." }, "getScopedPlayerIds": { "id": "games.players.getScopedPlayerIds", "path": "games/v1/players/me/scopedIds", "flatPath": "games/v1/players/me/scopedIds", "httpMethod": "GET", "parameters": {}, "parameterOrder": [], "response": { "$ref": "ScopedPlayerIds" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Retrieves scoped player identifiers for currently authenticated user." }, "getMultipleApplicationPlayerIds": { "id": "games.players.getMultipleApplicationPlayerIds", "path": "games/v1/players/me/multipleApplicationPlayerIds", "flatPath": "games/v1/players/me/multipleApplicationPlayerIds", "httpMethod": "GET", "parameters": { "applicationIds": { "description": "Required. The application IDs from the Google Play developer console for the games to return scoped ids for.", "location": "query", "repeated": true, "type": "string" } }, "parameterOrder": [], "response": { "$ref": "GetMultipleApplicationPlayerIdsResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Get the application player ids for the currently authenticated player across all requested games by the same developer as the calling application. This will only return ids for players that actually have an id (scoped or otherwise) with that game." }, "list": { "id": "games.players.list", "path": "games/v1/players/me/players/{collection}", "flatPath": "games/v1/players/me/players/{collection}", "httpMethod": "GET", "parameters": { "collection": { "description": "Collection of players being retrieved", "location": "path", "required": true, "type": "string", "enumDescriptions": [ "Retrieve a list of players that are also playing this game in reverse chronological order.", "Retrieve a list of players in the user's social graph that are visible to this game.", "Retrieve a list of players who are friends of the user in alphabetical order." ], "enumDeprecated": [ true, true, false ], "enum": [ "CONNECTED", "VISIBLE", "FRIENDS_ALL" ] }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of player resources to return in the response, used for paging. For any response, the actual number of player resources returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [ "collection" ], "response": { "$ref": "PlayerListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Get the collection of players for the currently authenticated user." } } }, "revisions": { "methods": { "check": { "id": "games.revisions.check", "path": "games/v1/revisions/check", "flatPath": "games/v1/revisions/check", "httpMethod": "GET", "parameters": { "clientRevision": { "description": "Required. The revision of the client SDK used by your application. Format: `[PLATFORM_TYPE]:[VERSION_NUMBER]`. Possible values of `PLATFORM_TYPE` are: * `ANDROID` - Client is running the Android SDK. * `IOS` - Client is running the iOS SDK. * `WEB_APP` - Client is running as a Web App.", "location": "query", "required": true, "type": "string" } }, "parameterOrder": [ "clientRevision" ], "response": { "$ref": "RevisionCheckResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Checks whether the games client is out of date." } } }, "scores": { "methods": { "get": { "id": "games.scores.get", "path": "games/v1/players/{playerId}/leaderboards/{leaderboardId}/scores/{timeSpan}", "flatPath": "games/v1/players/{playerId}/leaderboards/{leaderboardId}/scores/{timeSpan}", "httpMethod": "GET", "parameters": { "playerId": { "description": "A player ID. A value of `me` may be used in place of the authenticated player's ID.", "location": "path", "required": true, "type": "string" }, "leaderboardId": { "description": "The ID of the leaderboard. Can be set to 'ALL' to retrieve data for all leaderboards for this application.", "location": "path", "required": true, "type": "string" }, "timeSpan": { "description": "The time span for the scores and ranks you're requesting.", "location": "path", "required": true, "type": "string", "enumDescriptions": [ "Get the high scores for all time spans. If this is used, maxResults values will be ignored.", "Get the all time high score.", "List the top scores for the current day.", "List the top scores for the current week." ], "enum": [ "ALL", "ALL_TIME", "WEEKLY", "DAILY" ] }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "includeRankType": { "description": "The types of ranks to return. If the parameter is omitted, no ranks will be returned.", "location": "query", "type": "string", "enumDescriptions": [ "Retrieve all supported ranks. In HTTP, this parameter value can also be specified as `ALL`.", "Retrieve public ranks, if the player is sharing their gameplay activity publicly.", "(Obsolete) Retrieve the social rank.", "Retrieve the rank on the friends collection." ], "enumDeprecated": [ false, false, true, false ], "enum": [ "ALL", "PUBLIC", "SOCIAL", "FRIENDS" ] }, "maxResults": { "description": "The maximum number of leaderboard scores to return in the response. For any response, the actual number of leaderboard scores returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [ "playerId", "leaderboardId", "timeSpan" ], "response": { "$ref": "PlayerLeaderboardScoreListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Get high scores, and optionally ranks, in leaderboards for the currently authenticated player. For a specific time span, `leaderboardId` can be set to `ALL` to retrieve data for all leaderboards in a given time span. `NOTE: You cannot ask for 'ALL' leaderboards and 'ALL' timeSpans in the same request; only one parameter may be set to 'ALL'." }, "list": { "id": "games.scores.list", "path": "games/v1/leaderboards/{leaderboardId}/scores/{collection}", "flatPath": "games/v1/leaderboards/{leaderboardId}/scores/{collection}", "httpMethod": "GET", "parameters": { "leaderboardId": { "description": "The ID of the leaderboard.", "location": "path", "required": true, "type": "string" }, "collection": { "description": "The collection of scores you're requesting.", "location": "path", "required": true, "type": "string", "enumDescriptions": [ "List all scores in the public leaderboard.", "(Obsolete) Legacy G+ social scores.", "List only scores of friends." ], "enumDeprecated": [ false, true, false ], "enum": [ "PUBLIC", "SOCIAL", "FRIENDS" ] }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "timeSpan": { "description": "Required. The time span for the scores and ranks you're requesting.", "location": "query", "required": true, "type": "string", "enumDescriptions": [ "The score is an all-time score.", "The score is a weekly score.", "The score is a daily score." ], "enum": [ "ALL_TIME", "WEEKLY", "DAILY" ] }, "maxResults": { "description": "The maximum number of leaderboard scores to return in the response. For any response, the actual number of leaderboard scores returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [ "leaderboardId", "collection", "timeSpan" ], "response": { "$ref": "LeaderboardScores" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Lists the scores in a leaderboard, starting from the top." }, "listWindow": { "id": "games.scores.listWindow", "path": "games/v1/leaderboards/{leaderboardId}/window/{collection}", "flatPath": "games/v1/leaderboards/{leaderboardId}/window/{collection}", "httpMethod": "GET", "parameters": { "leaderboardId": { "description": "The ID of the leaderboard.", "location": "path", "required": true, "type": "string" }, "collection": { "description": "The collection of scores you're requesting.", "location": "path", "required": true, "type": "string", "enumDescriptions": [ "List all scores in the public leaderboard.", "(Obsolete) Legacy G+ social scores.", "List only scores of friends." ], "enumDeprecated": [ false, true, false ], "enum": [ "PUBLIC", "SOCIAL", "FRIENDS" ] }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "timeSpan": { "description": "Required. The time span for the scores and ranks you're requesting.", "location": "query", "required": true, "type": "string", "enumDescriptions": [ "The score is an all-time score.", "The score is a weekly score.", "The score is a daily score." ], "enum": [ "ALL_TIME", "WEEKLY", "DAILY" ] }, "maxResults": { "description": "The maximum number of leaderboard scores to return in the response. For any response, the actual number of leaderboard scores returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "resultsAbove": { "description": "The preferred number of scores to return above the player's score. More scores may be returned if the player is at the bottom of the leaderboard; fewer may be returned if the player is at the top. Must be less than or equal to maxResults.", "location": "query", "type": "integer", "format": "int32" }, "returnTopIfAbsent": { "description": "True if the top scores should be returned when the player is not in the leaderboard. Defaults to true.", "location": "query", "type": "boolean" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [ "leaderboardId", "collection", "timeSpan" ], "response": { "$ref": "LeaderboardScores" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Lists the scores in a leaderboard around (and including) a player's score." }, "submit": { "id": "games.scores.submit", "path": "games/v1/leaderboards/{leaderboardId}/scores", "flatPath": "games/v1/leaderboards/{leaderboardId}/scores", "httpMethod": "POST", "parameters": { "leaderboardId": { "description": "The ID of the leaderboard.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "score": { "description": "Required. The score you're submitting. The submitted score is ignored if it is worse than a previously submitted score, where worse depends on the leaderboard sort order. The meaning of the score value depends on the leaderboard format type. For fixed-point, the score represents the raw value. For time, the score represents elapsed time in milliseconds. For currency, the score represents a value in micro units.", "location": "query", "required": true, "type": "string", "format": "int64" }, "scoreTag": { "description": "Additional information about the score you're submitting. Values must contain no more than 64 URI-safe characters as defined by section 2.3 of RFC 3986.", "pattern": "[a-zA-Z0-9-._~]{0,64}", "location": "query", "type": "string" } }, "parameterOrder": [ "leaderboardId", "score" ], "response": { "$ref": "PlayerScoreResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Submits a score to the specified leaderboard." }, "submitMultiple": { "id": "games.scores.submitMultiple", "path": "games/v1/leaderboards/scores", "flatPath": "games/v1/leaderboards/scores", "httpMethod": "POST", "parameters": { "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" } }, "parameterOrder": [], "request": { "$ref": "PlayerScoreSubmissionList" }, "response": { "$ref": "PlayerScoreListResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Submits multiple scores to leaderboards." } } }, "snapshots": { "methods": { "get": { "id": "games.snapshots.get", "path": "games/v1/snapshots/{snapshotId}", "flatPath": "games/v1/snapshots/{snapshotId}", "httpMethod": "GET", "parameters": { "snapshotId": { "description": "The ID of the snapshot.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" } }, "parameterOrder": [ "snapshotId" ], "response": { "$ref": "Snapshot" }, "scopes": [ "https://www.googleapis.com/auth/drive.appdata", "https://www.googleapis.com/auth/games" ], "description": "Retrieves the metadata for a given snapshot ID." }, "list": { "id": "games.snapshots.list", "path": "games/v1/players/{playerId}/snapshots", "flatPath": "games/v1/players/{playerId}/snapshots", "httpMethod": "GET", "parameters": { "playerId": { "description": "A player ID. A value of `me` may be used in place of the authenticated player's ID.", "location": "path", "required": true, "type": "string" }, "language": { "description": "The preferred language to use for strings returned by this method.", "location": "query", "type": "string" }, "maxResults": { "description": "The maximum number of snapshot resources to return in the response, used for paging. For any response, the actual number of snapshot resources returned may be less than the specified `maxResults`.", "location": "query", "type": "integer", "format": "int32" }, "pageToken": { "description": "The token returned by the previous request.", "location": "query", "type": "string" } }, "parameterOrder": [ "playerId" ], "response": { "$ref": "SnapshotListResponse" }, "scopes": [ "https://www.googleapis.com/auth/drive.appdata", "https://www.googleapis.com/auth/games" ], "description": "Retrieves a list of snapshots created by your application for the player corresponding to the player ID." } } }, "stats": { "methods": { "get": { "id": "games.stats.get", "path": "games/v1/stats", "flatPath": "games/v1/stats", "httpMethod": "GET", "parameters": {}, "parameterOrder": [], "response": { "$ref": "StatsResponse" }, "scopes": [ "https://www.googleapis.com/auth/games" ], "description": "Returns engagement and spend statistics in this application for the currently authenticated user." } } }, "recall": { "methods": { "linkPersona": { "id": "games.recall.linkPersona", "path": "games/v1/recall:linkPersona", "flatPath": "games/v1/recall:linkPersona", "httpMethod": "POST", "parameters": {}, "parameterOrder": [], "request": { "$ref": "LinkPersonaRequest" }, "response": { "$ref": "LinkPersonaResponse" }, "scopes": [ "https://www.googleapis.com/auth/androidpublisher" ], "description": "Associate the PGS Player principal encoded in the provided recall session id with an in-game account" }, "retrieveTokens": { "id": "games.recall.retrieveTokens", "path": "games/v1/recall/tokens/{sessionId}", "flatPath": "games/v1/recall/tokens/{sessionId}", "httpMethod": "GET", "parameters": { "sessionId": { "description": "Required. Opaque server-generated string that encodes all the necessary information to identify the PGS player / Google user and application.", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "sessionId" ], "response": { "$ref": "RetrievePlayerTokensResponse" }, "scopes": [ "https://www.googleapis.com/auth/androidpublisher" ], "description": "Retrieve all Recall tokens associated with the PGS Player principal encoded in the provided recall session id. The API is only available for users that have active PGS Player profile." }, "lastTokenFromAllDeveloperGames": { "id": "games.recall.lastTokenFromAllDeveloperGames", "path": "games/v1/recall/developerGamesLastPlayerToken/{sessionId}", "flatPath": "games/v1/recall/developerGamesLastPlayerToken/{sessionId}", "httpMethod": "GET", "parameters": { "sessionId": { "description": "Required. Opaque server-generated string that encodes all the necessary information to identify the PGS player / Google user and application.", "location": "path", "required": true, "type": "string" } }, "parameterOrder": [ "sessionId" ], "response": { "$ref": "RetrieveDeveloperGamesLastPlayerTokenResponse" }, "scopes": [ "https://www.googleapis.com/auth/androidpublisher" ], "description": "Retrieve the last Recall token from all developer games that is associated with the PGS Player principal encoded in the provided recall session id. The API is only available for users that have active PGS Player profile." }, "unlinkPersona": { "id": "games.recall.unlinkPersona", "path": "games/v1/recall:unlinkPersona", "flatPath": "games/v1/recall:unlinkPersona", "httpMethod": "POST", "parameters": {}, "parameterOrder": [], "request": { "$ref": "UnlinkPersonaRequest" }, "response": { "$ref": "UnlinkPersonaResponse" }, "scopes": [ "https://www.googleapis.com/auth/androidpublisher" ], "description": "Delete a Recall token linking the PGS Player principal identified by the Recall session and an in-game account identified either by the 'persona' or by the token value." }, "resetPersona": { "id": "games.recall.resetPersona", "path": "games/v1/recall:resetPersona", "flatPath": "games/v1/recall:resetPersona", "httpMethod": "POST", "parameters": {}, "parameterOrder": [], "request": { "$ref": "ResetPersonaRequest" }, "response": { "$ref": "ResetPersonaResponse" }, "scopes": [ "https://www.googleapis.com/auth/androidpublisher" ], "description": "Delete all Recall tokens linking the given persona to any player (with or without a profile)." } } } }, "auth": { "oauth2": { "scopes": { "https://www.googleapis.com/auth/androidpublisher": { "description": "View and manage your Google Play Developer account" }, "https://www.googleapis.com/auth/drive.appdata": { "description": "See, create, and delete its own configuration data in your Google Drive" }, "https://www.googleapis.com/auth/games": { "description": "Create, edit, and delete your Google Play Games activity" } } } }, "batchPath": "batch", "title": "Google Play Game Services", "id": "games:v1", "version": "v1", "servicePath": "", "protocol": "rest", "revision": "20240416", "discoveryVersion": "v1", "baseUrl": "https://games.googleapis.com/", "description": "The Google Play games service allows developers to enhance games with social leaderboards, achievements, game state, sign-in with Google, and more.", "parameters": { "access_token": { "type": "string", "description": "OAuth access token.", "location": "query" }, "alt": { "type": "string", "description": "Data format for response.", "default": "json", "enum": [ "json", "media", "proto" ], "enumDescriptions": [ "Responses with Content-Type of application/json", "Media download with context-dependent Content-Type", "Responses with Content-Type of application/x-protobuf" ], "location": "query" }, "callback": { "type": "string", "description": "JSONP", "location": "query" }, "fields": { "type": "string", "description": "Selector specifying which fields to include in a partial response.", "location": "query" }, "key": { "type": "string", "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token.", "location": "query" }, "oauth_token": { "type": "string", "description": "OAuth 2.0 token for the current user.", "location": "query" }, "prettyPrint": { "type": "boolean", "description": "Returns response with indentations and line breaks.", "default": "true", "location": "query" }, "quotaUser": { "type": "string", "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.", "location": "query" }, "upload_protocol": { "type": "string", "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").", "location": "query" }, "uploadType": { "type": "string", "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").", "location": "query" }, "$.xgafv": { "type": "string", "description": "V1 error format.", "enum": [ "1", "2" ], "enumDescriptions": [ "v1 error format", "v2 error format" ], "location": "query" } }, "rootUrl": "https://games.googleapis.com/", "documentationLink": "https://developers.google.com/games/", "ownerName": "Google" }