PGOS Change Log
V0.34.0(2025-09-18)
New Features:
- DSHosting- 支持 Parallel放置模式,允许在一个 DS 上放置多个 Battle Session
 
- 支持 
- Lobby- 新增 TerminateLobbyHTTP API,用于从后端强制解散一个房间
 
- 新增 
- Matchmaking- Ruleset 新增 algorithm区段,支持配置expansionMode选项。该选项配置成strict时,对局内所有玩家均满足放宽条件时才会执行放宽动作。作为对比,默认情况下只要锚点票据达成放宽条件时,就会执行放宽动作
 
- Ruleset 新增 
- 其他 Bug 修复和性能优化
SDK Download Link:PGOS_SDK_V0.34.0
V0.33.2(2025-07-30)
新功能:
- Lobby - SearchLobby 和 QuickJoinLobby 时,支持按子集、交集的方式过滤 Lobby KVData 中的元素
 
SDK Download Link:PGOS_SDK_V0.33.2
V0.33.1 (2025-07-09)
新功能:
- 获取潜在好友接口名由 GetPotentialPlayers更新为GetPotentialFriends. 此接口用于获取潜在好友,支持分页检索,并且按共同好友数降序排列。
 
- 获取潜在好友接口名由 
SDK Download Link:PGOS_SDK_V0.33.1
V0.33.0 (2025-06-30)
新功能:
- World Filter中增加Category(属性的类别): - 预定义属性: PGOS 目前支持两个预定义属性,其名称和数据源都是固定的: - PublishPlatform(发布平台): 玩家登录游戏的发布平台。示例值包括 “FAS”、“Steam”、“PlayStation”、“Xbox”、“Switch”、‘AppStore’、“GooglePlay ”等。 
- DeploymentZone(部署区域):开发者打算部署/放置 BattleSession 的目标区域。示例值包括 “cn_souch”、“ap_singapore”、‘eu_germany’、“na_east ”等。 
 
- 自定义属性: 自定义属性允许开发人员配置参数,包括名称、数据源、数据类型、默认值等。 
 
 
- 添加 GetMutualFriendsCountAPI:您可以使用该 API 查询当前用户与其他用户之间的共同好友数量。该 API 支持批量查询:开发者可以在一个列表中指定多个玩家 ID(单个请求中最多可指定 20 个玩家 ID),响应将返回当前用户与每个指定用户之间的相互好友数。
 
- 添加 
- In-game Mail: 添加了两个 HTTP API: - GetPlayerMailsByID和- MarkAttachmentAsClaimed。- 允许为单个玩家设置store category虚拟时间 - 全局配置
 - 时光机可在 - Store Category Schedule > Time Machine中配置。此处的配置将影响所有访问此商店类别的玩家。- 玩家配置
 - 时间机器也可为单个玩家配置,请在 - player detail page > Economy > Time Machine中配置。此配置仅适用于该玩家。
 
CLI Tools
- DS hosting中添加新的API- describe-placer
- describe-local-placer
- describe-p2p-placer
 
SDK 下载链接:PGOS_SDK_V0.33.0
V0.32.0 (2025-05-27)
新功能:
- 排行榜 - 在周期中添加了“锁定时间”。在锁定时间后,Stat Item data 不会更新,排行榜从现在开始直到下一个周期开始(周期重置之前)都不会更新。
- 添加了“GetLeaderboardInfo”HTTP API,用于获取排行榜信息。
- 在 UpdateStatItems API 中添加了自定义数据。
 
- PgosSDK配置- title_region_id:指定服务器应访问的title region。此配置仅适用于未使用 PGOS DS Hosting 服务的服务器,而使用 PGOS DS Hosting 服务的在线 DS(部署在 PGOS 云环境中)和本地 DS(配置了本地部署 ID)均无需此配置。
- ds_hosting_feature_enable:启用或禁用 PGOS DS Hosting 功能。如果未使用此功能,禁用它可以加快 SDK 初始化速度。“true”表示启用,“false”表示禁用。
 
CLI Tools
- DS Hosting添加新的API :- cooldown-fleet
- warmup-fleet
 
SDK 下载链接:PGOS_SDK_V0.32.0
V0.31.0 (2025-05-12)
新功能:
- 玩家登录: 支持登录排队。玩家登录排队系统可确保在高流量时段(例如游戏发布、重大更新或高峰时段)平稳过渡登录流量高峰。此功能允许玩家逐步进入游戏,防止服务器过载,并确保玩家获得更流畅的体验,而不会让服务器一下子过载。
- 好友: 为了方便开发者进行测试,PGOS 允许开发者在门户网站上管理好友列表和黑名单。
- 匹配: 在玩家属性的 partyAggregation字段中新增use_leader参数,方便游戏将队伍数据存储在队长玩家数据中并传递给 PGOS。
- P2P 对战:支持主机迁移,当原host出现异常时,会自动从玩家中选择新的主机。
- 经济:支持获取部分物品栏数据。如果游戏中玩家拥有大量物品,您可以选择使用 GetInventoryWithFilter按需获取部分物品栏数据。
- DevOps: 导入大区配置时,您可以选择所需的资源,不需要导入的所有配置。
修复问题:
- 同一个会华中出现重复 kick EventPlayerLogoutPGOS事件
- 优化  OnWorldBattleSessionUpdated事件
CLI 工具
- 新增P2P 对战API: - create-p2p-placer
- update-p2p-placer
- list-p2p-placer
 
- P2P 对局接口新增参数: - EnableHostMigration
- HostHealthCheckingTimeout
- NewHostSelectedTimeout
- ElectionThresholdPercent
 
SDK升级说明:
为了解决 UE 插件的数据结构与第三方插件冲突的问题,我们在所有数据结构(客户端 SDK 类型为 PgosClient,服务器 SDK 类型为 PgosServer)中添加了 Pgos 前缀
- 蓝图增加了CoreRedirects,不需要修改。
- 对于 C++ 代码,我们将原始数据结构的名称放在命名空间 Pgos 中(对于客户端 SDK 类型,则放在 Pgos::Client 中;对于服务器 SDK 类型,则放在 Pgos::Server 中)。升级 SDK V0.31.0 时,需要添加使用命名空间 Pgos/Pgos::Client/Pgos::Server,其中使用了 Pgos 数据结构。
SDK 下载链接:PGOS_SDK_V0.31.0
V0.31.0 (2025-05-12)
新功能:
- 玩家登录: 支持登录排队。玩家登录排队系统可确保在高流量时段(例如游戏发布、重大更新或高峰时段)平稳过渡登录流量高峰。此功能允许玩家逐步进入游戏,防止服务器过载,并确保玩家获得更流畅的体验,而不会让服务器一下子过载。
- 好友: 为了方便开发者进行测试,PGOS 允许开发者在门户网站上管理好友列表和黑名单。
- 匹配: 在玩家属性的 partyAggregation字段中新增use_leader参数,方便游戏将队伍数据存储在队长玩家数据中并传递给 PGOS。
- P2P 对战:支持主机迁移,当原host出现异常时,会自动从玩家中选择新的主机。
- 经济:支持获取部分物品栏数据。如果游戏中玩家拥有大量物品,您可以选择使用 GetInventoryWithFilter按需获取部分物品栏数据。
- DevOps: 导入大区配置时,您可以选择所需的资源,不需要导入的所有配置。
修复问题:
- 同一个会华中出现重复 kick EventPlayerLogoutPGOS事件
- 优化  OnWorldBattleSessionUpdated事件
CLI 工具
- 新增P2P 对战API: - create-p2p-placer
- update-p2p-placer
- list-p2p-placer
 
- P2P 对局接口新增参数: - EnableHostMigration
- HostHealthCheckingTimeout
- NewHostSelectedTimeout
- ElectionThresholdPercent
 
SDK升级说明:
为了解决 UE 插件的数据结构与第三方插件冲突的问题,我们在所有数据结构(客户端 SDK 类型为 PgosClient,服务器 SDK 类型为 PgosServer)中添加了 Pgos 前缀
- 蓝图增加了CoreRedirects,不需要修改。
- 对于 C++ 代码,我们将原始数据结构的名称放在命名空间 Pgos 中(对于客户端 SDK 类型,则放在 Pgos::Client 中;对于服务器 SDK 类型,则放在 Pgos::Server 中)。升级 SDK V0.31.0 时,需要添加使用命名空间 Pgos/Pgos::Client/Pgos::Server,其中使用了 Pgos 数据结构。
SDK 下载链接:PGOS_SDK_V0.31.0
V0.30.0 (2025-03-20)
新功能:
- 匹配:支持 规则集 
- PGOS 提供以下功能,帮助游戏开发者构建 P2P 游戏:: - P2P 匹配,考虑 NAT 类型的网络,以下是 规则集示例 供您参考
- P2P 对战会话
- P2P 连接
- P2P 网络驱动程序
 
- DS Hosting: - 在 FPgosHostingAPI::GetDeploymentInfo()API 中添加title_region_id字段,以便 DS 获取游戏区域信息。
- 添加了 Load Status字段,游戏可以通过 Machine Overload Setting 定义机器在何种状态下被视为Overload。
 
- 在 
- Economy: 我们为非 production的 title region的商店类别提供了时间机器功能。此功能允许用户指定仅适用于特定商店类别的后端虚拟时间,方便验证过去或未来有效的商店类别计划。 
- DevOps 
- 添加了 DS hosting 监控指标- machine_cpu_usage_avg
- machine_cpu_usage_max
- machine_cpu_usage_min
- machine_memory_usage_avg
- machine_memory_usage_max
- machine_memory_usage_min
- machine_network_traffic_in
- machine_network_traffic_out
- machine_network_packet_in
- machine_network_packet_out
 
- Prometheus exporter: 支持导出“过载”状态的机器的指标
- Portal: 允许开发人员编辑title region名称。
修复问题:
- 修复错误以确保最新的“OnWorldBattleSessionUpdated”事件和回调始终包含战斗会话的最新数据。
CLI Tools:
- Added New APIs for VS - start-virtual-server
- stop-virtual-server
 
- Added VolumeConfigreturn filed in below APIs- list-virtual-server
- describe-virtual-server
 
- Added VolumeConfigrequest filed in below APIs- create-virtual-server
- update-virtual-server
 
SDK 下载链接:PGOS_SDK_V0.30.0
V0.29.0 (2025-01-17)
新功能:
- World:在 PGOS 控制台中列出用户所有的world服务战斗会话。 
- DevOps:我们为 Prometheus Exporter 添加了 DS 和 VS 的数据指标。开发者可以导出这些指标并与 Grafana 结合,在监控面板上可视化显示。 
- PGOS Audit:审计日志系统记录 PGOS 中的所有用户请求和服务器响应,帮助开发者排查错误并进行操作审计。 
- P2P 匹配(即将于 4 月推出~):结合 P2P 网络和 ClientHosting,支持 P2P 战斗会话。 
CLI Tools
- 允许使用 CLI API 验证开发者帐户和服务器/客户端密钥。 
- 您可以为不同类型的region(开发/测试/生产)启用密钥。 
- Added New APIs for VS metric config - update-virtual-server-metric-config
 
- Added New APIs for P2P Local Placer - update-local-placer
- create-p2p-placer
- update-p2p-placer
- delete-p2p-placer
- list-p2p-placer
 
- Added New APIs in MatchConfig for P2P Placer - list-match-config
- describe-match-config
- create-match-config
- update-match-config
 
- Added New APIs in BattleSession for P2P Placer - list-p2p-battle-session
- describe-p2p-battle-session
 
- Added ActiveBattleSessionTimeout in LocalPlacer APIs - create-local-placer
- update-local-placer
- delete-local-placer
- list-local-placer
 
Upgrade SDK Note:
- 重构一些结构::- FServerPlayerDesc -> FPlayerDesc
- FServerBattleTeam -> FBattleTeam
- FServerBattleSourceData -> FBattleSourceData
 
SDK 下载链接:PGOS_SDK_V0.29.0
V0.28.0 (2024-12-05)
新服务:
- 工单系统 (Beta): 允许开发人员提交与PGOS服务相关的问题和技术问题的工单,并确保所有请求都被记录、优先处理并及时处理。
新功能:
- Player Auth: 添加了新的Add-on插件以支持 PlayStation、Xbox 和 NintendoSwitch 登录身份验证。 
- Player Data: 支持导出玩家数据.  
- Player Settings: - 新增昵称区分大小写配置,需要在创建大区时确认,大区创建后无法在网页上修改。
- 修改玩家显示名称时增加冷却时间。 
 
- DS Hosting: - 在门户的数据中心配置中添加了一个开关“Enable Placement”,以控制是否可以将战斗会话放置在该数据中心。
 
- 支持上传同一崩溃堆栈的多个DS crash core dump。
- 在仪表板上添加了机器利用率趋势图、DS 利用率趋势图、战斗会话平均放置时间趋势图。
 
- 在门户的数据中心配置中添加了一个开关“Enable Placement”,以控制是否可以将战斗会话放置在该数据中心。
- World: 在bucket中添加了一个“Max Sessions Count”参数。 
- Lobby: 添加了新的 API “QuickJoin”,支持通过Lobby自定义数据过滤搜索结果,并允许玩家找到Lobby并加入。 
- 在游戏内物品中添加了 StackLimit功能,以限制物品的堆叠数量。
- 支持游戏内物品的免费定价。
- 添加了新的 API:BatchSetInstanceTags、BatchSetInstanceCustomData、BatchRevokeInstances
- 支持商店类别轮换
 
- 在游戏内物品中添加了 
- HTTP API: HTTP API 的 - idempotency_token有效期更改为 90 天。
- Virtual Server: - 我们新增了 VS Market,其中包含主流软件镜像和安装指南。这将使部署更加轻松快捷,并显著提高您的工作效率。
- UE 插件的 API InvokeVirtualServer支持二进制body and response。并且FVirtualServerReq.body和FVirtualServerResp.resp_body的类型已从FString更改为TArray<uint8>。
 
- Leaderboard: 添加了新的接口 - GetFriendsRankingList支持查询好友排行榜列表
- System: 添加了新的API - GetServerTime,支持以秒为单位获取服务器的当前UTC时间。
- PgosSDK: 除了已经提供的发布版本二进制文件之外,PgosSDK 还将提供适用于 Windows 和 Xbox 的调试版本二进制文件。 
修复问题:
- 修复读取资源配置文件异常导致崩溃的问题。
Upgrade SDK Note
- PgosSDK:移除部分标记为弃用的 API。- FakeAccount模块 API:- RefreshToken和- SwitchAccount已被移除。
- Friend模块 API:- BatchOpenIDToPlatformPlayerInfo和- BatchAccountIDToPlayerID已被移除,可使用- PlayerProfile模块中同名 API 替换。
 
- PgosSDKUE 插件:移除编辑器插件设置中的“服务器密钥 (Sever Secret Key)”配置选项。自 v0.27.0 起,游戏服务器无需配置 PGOS 密钥 (PGOS Secret Key)。
PGOS Tools: 更新 CLI APIs:
Added New CLI APIs
- Economy Store Category Rotation - reset-store-category-rotation-schedule
- modify-store-category-rotation-periods
- list-store-category-rotation-periods
 
- collect-virtual-server-logs
- delete-virtual-server-log-collection
- list-virtual-server-log-collection
- describe-virtual-server-log-collection
 
Updated Parameters
- Added - RotationConfigurationfield in the following APIs:- list-store-category
- describe-store-category
- set-store-category-schedule
- export-store
- check-store
- import-store
 
- Renamed - Schedulefiled to- ManualConfigurationin the following APIs: (Still compatible with- Schedulefield, but the field in API response was already replaced with- ManualConfiguratio
- list-store-category 
- describe-store-category 
- set-store-category-schedule 
- export-store 
- check-store 
- import-store 
- Added - MaxBSCountPerBucketfield in the World Configuration- create-world-config
- list-world-config
- update-world-config
- describe-world-config
 
- Added - StackLimitin in-game items-related APIs:- list-ingame-item
- describe-ingame-item
- create-ingame-item
- update-ingame-item
- export-ingame-item
- check-ingame-item
- import-ingame-item
 
- Added - EventTypefield in the Event handler APIs:- describe-event-handler
- update-event-handler
- delete-event-handler
 
SDK Download Link:PGOS_SDK_V0.28.0
在 V0.28.0 中,以下 HTTP API 响应发生了变化:部分字符串类型字段调整为 int64 数字。旧版 PGOS SDK 兼容字符串和 int64;请在 VS 中修改 API 响应类型。否则,API 调用将失败。
| HTTP API Name | HTTP API URL | 变更字段 in Response | 
|---|---|---|
| QueryBattleSessions | /dsm/query_battle_sessions | body.battle_sessions.created_time body.battle_sessions.terminated_time | 
| DescribeBattleSessionPlacement | /dsm/describe_battle_session_placement | body.created_time body.terminated_time body.player_battle_sessions.created_time body.player_battle_sessions.terminated_time | 
| QueryPlayerBattleSessions | /dsm/query_player_battle_sessions | body.player_battle_sessions.created_time body.player_battle_sessions.terminated_time | 
| AddPlayersToBattleSession | /dsm/add_players_to_battle_session | body.new_player_battle_sessions.created_time body.new_player_battle_sessions.terminated_time | 
| GetPlayerBattleRecord | /dsm/get_player_battle_record | body.battle_data_list.battle_created_time | 
| GetFriendList | /friend/get_friend_list | body.friend_info_list.created_time | 
| GetPlayerStat | /gamestat/get_player_stat | body.latest_login_time body.latest_logout_time | 
| GetGroupMembers | /group/get_group_members | body.group_members.joined_time body.muted_members.mute_created_time body.muted_members.mute_expired_time body.muted_members.joined_time | 
| GetGroupInfo | /group/get_group_info | body.group_info.created_time | 
| GetItemInstanceInfo | /inventory/get_item_instance_info | body.item_instances.created_time body.item_instances.updated_time body.item_instances.expired_time | 
| GetRankingList | /leaderboard/get_ranking_list | body.items.updated_time | 
| GetRankItemPosInfo | /leaderboard/get_rank_item_pos_info | body.item.updated_time body.preceding_items.updated_time body.subsequent_items.updated_time | 
| GetPartyInfo | /party/get_party_info | body.party_info.created_time | 
| CheckPlayerDeletionStatus | /player/check_player_deletion_status | body.marked_time | 
| GetPlayerDetail | /player/get_player_detail | body.first_login_time body.last_login_time body.last_logout_time body.total_time body.cur_login_time | 
| GetPlayerDetailByDisplayName | /player/get_player_detail_by_display_name | body.first_login_time body.last_login_time body.last_logout_time body.total_time body.cur_login_time | 
| BatchGetPlayerDetail | /player/batch_get_player_detail | body.data.first_login_time body.data.last_login_time body.data.last_logout_time body.data.total_time body.data.cur_login_time | 
| GetPlayerDetailListByDisplayName | /player/get_player_detail_list_by_display_name | body.player_detail_list.first_login_time body.player_detail_list.last_login_time body.player_detail_list.last_logout_time body.player_detail_list.total_time body.player_detail_list.cur_login_time | 
| BatchGetPlayerDetailListByDisplayNames | /player/batch_get_player_detail_list_by_display_names | body.player_detail_list.first_login_time body.player_detail_list.last_login_time body.player_detail_list.last_logout_time body.player_detail_list.total_time body.player_detail_list.cur_login_time | 
| BatchGetPlayerDetailsByDisplayNames | /player/batch_get_player_details_by_display_names | body.player_detail_infos.displayname.first_login_time body.player_detail_infos.displayname.last_login_time body.player_detail_infos.displayname.last_logout_time body.player_detail_infos.displayname.total_time body.player_detail_infos.displayname.cur_login_time | 
| GetPlayerBanInfo | /player/get_player_ban_info | body.created_time body.expired_time | 
| QueryPlayersPunishItems | /player/query_players_punish_items | body.punish_map.playerid.items.start_time body.punish_map.playerid.items.deadline | 
| GetTitleFileInfo | /title/get_title_file_info | body.data.updated_time body.data.file_size | 
| GetAllOverallBanInfo | /title/get_all_overall_ban_info | body.ban_info_list.ban_start_time body.ban_info_list.ban_expire_time body.ban_info_list.created_time body.ban_info_list.updated_time | 
| CreateECT | /ect/create_ect | body.created_time body.updated_time body.actions.updated_time | 
| GetPlayerUncompletedECTs | /ect/get_player_uncompleted_ects | body.ect_list.created_time body.ect_list.updated_time body.ect_list.actions.updated_time | 
| CancelECT | /ect/cancel_ect | body.created_time body.updated_time body.actions.updated_time | 
| UpdateECT | /ect/update_ect | body.created_time body.updated_time body.actions.updated_time | 
| UpdateECTActions | /ect/update_ect_actions | body.created_time body.updated_time body.actions.updated_time | 
| GetECTInfo | /ect/get_ect_info | body.created_time body.updated_time body.actions.updated_time | 
| GetPlayerCurrency | /inventory/get_player_currency | body.currencies.amount body.currencies.total_spend body.currencies.created_time | 
| GetPlayerMails | /mail/get_player_mails | body.mail_list.sent_time_stamp | 
| GetStatItems | /statistics/get_stat_items | body.round_start_time body.round_end_time body.items.updated_time | 
| GetPersistentStatItems | /statistics/get_persistent_stat_items | body.items.updated_time | 
| UpdateStatItems | /statistics/update_stat_items | body.items.latest_item.updated_time | 
| GetCycleCurrentRound | /statistics/get_cycle_current_round | body.round_info_map.round_start_time body.round_info_map.round_end_time | 
V0.27.1 (2024-10-11)
新功能:
- Web Console of DS Hosting: 允许用户在 Web 控制台页面上选择已激活的 DS 实例并进入他们的终端(Linux SSH 或 Windows RDP)。

- Add-on: 适用于 ACE SDK 并提Add-on插件以启用敏感词过滤功能。  
Fixed Bugs
- 修复本地DS中ActivateBattleSession调用提供服务器端口无效的问题。
- 修复使用镜像资源创建VS时,由于镜像未标记导致CI流程失败的问题。
- 仅将后端和 Web 门户更新至 V0.27.1,开发者无需升级 PGOS SDK。 
- 将门户上的Backend API/Title CLI 域移至详情页面。  
V0.27.0 (2024-09-20)
新服务:
- Message Bus: 在游戏拥有自己的后台系统且仅使用 PGOS 部分服务(例如 DS 托管)的场景下,游戏后台可能需要与 DS或 VS通信,并接收 PGOS 事件。通常,DS/VS 可以通过公网直接与游戏后台通信。然而,这需要游戏后台拥有公网网关。此外,即使游戏后台已经拥有公网网关,游戏仍然需要进行一些适配工作。因此,PGOS 提供了一种名为消息总线 (Message Bus) 的即用型通信机制,用于支持与游戏后台服务进行数据交换。
- Eventual Consistent Transaction (ECT): ECT 用于跟踪游戏事务。当游戏需要执行包含多个有序操作的事务来修改玩家数据或库存时,游戏可以创建一个 ECT 实例来在后端(Game Server或VS)跟踪事务状态。
- Player Punishment: 玩家惩罚是指玩家在指定时间内无法使用某些功能。游戏会实施惩罚措施,以惩戒那些做出不良行为(例如作弊或辱骂他人)的玩家。游戏可以通过门户控制台或后端 HTTP API 管理(添加/撤销)玩家惩罚。玩家惩罚设有截止时间,到达截止时间后,惩罚将自动解除。
新功能
- World: - 支持多人离开世界: 玩家可以使用 InviteLeaveWorldAPI 邀请其他玩家离开指定的世界。
- 在世界配置中添加 DS 审批:开发者可以选择 DS 审批策略来指定如何处理客户端的 JoinWorldBattleSession请求。- 会话锁定时需要审批:只有直接加入锁定的世界战斗会话时才需要 DS 审批。
- 所有会话加入请求都需要审批:所有来自 JoinWorldBattleSession接口的加入请求都需要 DS 审批,无论世界战斗会话是否锁定。
- 世界战斗会话 ID 重命名 & 区域已移至 BattleSessionInfo
 
 
- 支持多人离开世界: 玩家可以使用 
- Matchmaking: Simulator支持模拟多模式匹配 
- DS Hosting: - 优化了战斗会话放置策略](../manual/service_manual/ds_hosting/placers.html#1-battle-session-placement-strategy):PGOS 将根据战斗会话玩家到 DS 的延迟情况,选择最佳的 DS 实例来放置战斗会话。
- 在 DS SDK 托管模块中新增 API GetDeploymentInfo,用于获取游戏服务器的部署详情,例如机器类型、region等。
- 支持使用 CLI 配置本地Placer。
- 在线 DS 无需配置服务器 secret_key。您可以从PgosSDKUE 插件设置(DefaultGame.ini)或代码中移除服务器secret_key,以防止其意外泄露。
 
- In-game mail: 支持发送全员邮件。 
- Economy: 虚拟货币新增“最大余额”字段,限制玩家可获得的虚拟货币最大数量。 
- Title File: 支持server-only属性,允许游戏指定某些文件只能从服务器获取其可下载的URL。 
- Virtual Server: - VS Storage 添加 Cloud Disk.
- VS支持“云盘”。现在您可以将磁盘挂载为VS持久存储。
- 支持 Browser Access. 现在您可以通过门户直接在浏览器中访问您的VS。
- 支持 Access Log. 开启后,PGOS 将为VS生成默认 Nginx 格式的访问日志,您可以在“日志”中查询。
- Supported Intranet Communication. PGOS 为每个VS分配内网连接,以便您可以直接访问其他VS。
 - 现在,您可以使用 Docker 镜像在VS中部署大多数软件,例如 Prometheus 和 Grafana,以监控 PGOS 服务、数据库、您的VS以及任何其他您需要的软件。VS已成为一个完整的生态系统,可用于开发和部署几乎所有游戏后端服务器。VS应用市场即将发布,以帮助您更高效地安装我们或其他开发者共享的软件。
 
- VS Storage 添加 
- 优化事件通知可靠性:- 新增OnPartyInfoUpdated事件:由于网络问题或其他原因导致长连接中断,服务器可能无法通过此连接通知客户端队伍信息的变更(例如玩家加入或离开队伍)。如果客户端长时间未察觉队伍信息的变更,可能会导致游戏功能异常。为了解决此问题,PGOS SDK 会在检测到长连接中断后定期(通常每 30 到 60 秒)获取最新的队伍信息,然后通过OnPartyInfoUpdated事件通知游戏。
- Applicable to OnLobbyInfoUpdatedas well.
 
- 新增
- PGOS SDK 适配Nintendo SDK 18.3.2.
修复问题:
- Local Placer缺少 OnPlayerBattleSessionsTerminated通知。
- 缺少 OnTitleRegionClosed事件。
PGOS Tools: 更新 CLI APIs
Added New CLI APIs:
- Local Placer- create-local-placer
- delete-local-placer
- list-local-placers
 
Update Parameters:
- Added - LaunchArgsparameter in the following APIs, default by- [].- create-virtual-server
- update-virtual-server
- list-virtual-server
- describe-virtual-server
 
- Added - JoinRequireDSApprovalparameter in the following APIs, default by- False.- create-world-config
- update-world-config
- list-world-config
- describe-world-config
 
- Added - ServerOnlyparameter in the following APIs, default by- False.- create-title-file
- list-title-file
- describe-title-file
 
- Added - MaxDepositparameter in the following APIs, default by 0.- list-virtual-currency 
- describe-virtual-currency 
- create-virtual-currency 
- update-virtual-currency 
- check-virtual-currency 
- import-virtual-currency 
- export-virtual-currency 
 
- Added - PlacementRulesparameter in the following APIs, default by- []- create-placer
- update-placer
 
- Deleted BattlesessionPlaceTimeout parameter in the following APIs. - create-placer
- update-placer
 
SDK Download Link:PGOS_SDK_V0.27
预告:
以下 HTTP API 响应将在 V0.28.0 中发生变化:将一些字符串类型字段调整为 int64 数字。
| HTTP API Name | HTTP API URL | Changed Fields in Response | 
|---|---|---|
| QueryBattleSessions | /dsm/query_battle_sessions | body.battle_sessions.created_time body.battle_sessions.terminated_time | 
| DescribeBattleSessionPlacement | /dsm/describe_battle_session_placement | body.created_time body.terminated_time body.player_battle_sessions.created_time body.player_battle_sessions.terminated_time | 
| QueryPlayerBattleSessions | /dsm/query_player_battle_sessions | body.player_battle_sessions.created_time body.player_battle_sessions.terminated_time | 
| AddPlayersToBattleSession | /dsm/add_players_to_battle_session | body.new_player_battle_sessions.created_time body.new_player_battle_sessions.terminated_time | 
| GetPlayerBattleRecord | /dsm/get_player_battle_record | body.battle_data_list.battle_created_time | 
| GetFriendList | /friend/get_friend_list | body.friend_info_list.created_time | 
| GetPlayerStat | /gamestat/get_player_stat | body.latest_login_time body.latest_logout_time | 
| GetGroupMembers | /group/get_group_members | body.group_members.joined_time body.muted_members.mute_created_time body.muted_members.mute_expired_time body.muted_members.joined_time | 
| GetGroupInfo | /group/get_group_info | body.group_info.created_time | 
| GetItemInstanceInfo | /inventory/get_item_instance_info | body.item_instances.created_time body.item_instances.updated_time body.item_instances.expired_time | 
| GetRankingList | /leaderboard/get_ranking_list | body.items.updated_time | 
| GetRankItemPosInfo | /leaderboard/get_rank_item_pos_info | body.item.updated_time body.preceding_items.updated_time body.subsequent_items.updated_time | 
| GetPartyInfo | /party/get_party_info | body.party_info.created_time | 
| CheckPlayerDeletionStatus | /player/check_player_deletion_status | body.marked_time | 
| GetPlayerDetail | /player/get_player_detail | body.first_login_time body.last_login_time body.last_logout_time body.total_time body.cur_login_time | 
| GetPlayerDetailByDisplayName | /player/get_player_detail_by_display_name | body.first_login_time body.last_login_time body.last_logout_time body.total_time body.cur_login_time | 
| BatchGetPlayerDetail | /player/batch_get_player_detail | body.data.first_login_time body.data.last_login_time body.data.last_logout_time body.data.total_time body.data.cur_login_time | 
| GetPlayerDetailListByDisplayName | /player/get_player_detail_list_by_display_name | body.player_detail_list.first_login_time body.player_detail_list.last_login_time body.player_detail_list.last_logout_time body.player_detail_list.total_time body.player_detail_list.cur_login_time | 
| BatchGetPlayerDetailListByDisplayNames | /player/batch_get_player_detail_list_by_display_names | body.player_detail_list.first_login_time body.player_detail_list.last_login_time body.player_detail_list.last_logout_time body.player_detail_list.total_time body.player_detail_list.cur_login_time | 
| BatchGetPlayerDetailsByDisplayNames | /player/batch_get_player_details_by_display_names | body.player_detail_infos.displayname.first_login_time body.player_detail_infos.displayname.last_login_time body.player_detail_infos.displayname.last_logout_time body.player_detail_infos.displayname.total_time body.player_detail_infos.displayname.cur_login_time | 
| GetPlayerBanInfo | /player/get_player_ban_info | body.created_time body.expired_time | 
| QueryPlayersPunishItems | /player/query_players_punish_items | body.punish_map.playerid.items.start_time body.punish_map.playerid.items.deadline | 
| GetTitleFileInfo | /title/get_title_file_info | body.data.updated_time body.data.file_size | 
| GetAllOverallBanInfo | /title/get_all_overall_ban_info | body.ban_info_list.ban_start_time body.ban_info_list.ban_expire_time body.ban_info_list.created_time body.ban_info_list.updated_time | 
| CreateECT | /ect/create_ect | body.created_time body.updated_time body.actions.updated_time | 
| GetPlayerUncompletedECTs | /ect/get_player_uncompleted_ects | body.ect_list.created_time body.ect_list.updated_time body.ect_list.actions.updated_time | 
| CancelECT | /ect/cancel_ect | body.created_time body.updated_time body.actions.updated_time | 
| UpdateECT | /ect/update_ect | body.created_time body.updated_time body.actions.updated_time | 
| UpdateECTActions | /ect/update_ect_actions | body.created_time body.updated_time body.actions.updated_time | 
| GetECTInfo | /ect/get_ect_info | body.created_time body.updated_time body.actions.updated_time | 
| GetPlayerCurrency | /inventory/get_player_currency | body.currencies.amount body.currencies.total_spend body.currencies.created_time | 
| GetPlayerMails | /mail/get_player_mails | body.mail_list.sent_time_stamp | 
| GetStatItems | /statistics/get_stat_items | body.round_start_time body.round_end_time body.items.updated_time | 
| GetPersistentStatItems | /statistics/get_persistent_stat_items | body.items.updated_time | 
| UpdateStatItems | /statistics/update_stat_items | body.items.latest_item.updated_time | 
| GetCycleCurrentRound | /statistics/get_cycle_current_round | body.round_info_map.round_start_time body.round_info_map.round_end_time | 
V0.26.3 (2024-08-15)
New Features
- Economy:- adapted to the Tenecent Midas payment system and added the Midas payment add-on.
- added BatchGrantCurrencyToPlayerandSubtractPlayerVirtualCurrenciesSDK APIs and backend HTTP APIs.
- added items mapping  in GetStoreCategoriesAPI.
 
- Party: added two backend  HTTP party APIs: GetPlayersCurrentPartyIdsandGetPartyInfo.
- Player Info: added two HTTP APIs:  GetPlayerDetailListByDisplayNameandBatchGetPlayerDetailListByDisplayNames.
PGOS Tools: Updated CLI APIs
Added New CLI APIs:
- Title File- list-title-file
- create-title-fil
- delete-title-file
- describe-title-file
- create-title-file-folder
- delete-title-file-folder
- refresh-title-file-cache
 
Updated Fields :
- Changed - RulesetNameto- AssociatedRulesetin Matchaking APIs:- update-match-config
- create-match-config
 
- Changed - GamePropertyreturn value from String to JSON object in Matchaking APIs:- describe-match-config
- list-match-config
 
Added New Parameters
- Added - CurrencyType,- ResourceIDin Economy APIs:- list-virtual-currency
- describe-virtual-currency
- create-virtual-currency
- update-virtual-currency
- export-virtual-currency
- check-virtual-currency
- import-virtual-currency
 
- Added - FailedItemsin Economy APIs:- import-ingame-item
- import-store
 
- Added - PayPlatformin Economy APIs:- export-store
- check-store
- import-store
- list-store-item
- describe-store-item
- create-store-item
- update-store-item
 
Deprecated APIs:
Mentioned in V0.25.1 (2024-05-31) Changelog and depracated the following APIs in V0.26.1:
- export-economy-currency-json-content
- import-economy-currency-json-content
- export-economy-ingame-item-json-content
- import-economy-ingame-item-json-content
- export-economy-platform-item-json-content
- import-economy-platform-item-json-content
- export-economy-store-json-content
- import-economy-store-json-content
:::
SDK Download Link:PGOS_SDK_V0.26.3
V0.26.0 (2024-07-02)
新功能
- 玩家鉴权: PGOS 适配多帐号绑定 
- Lobby: 
- World: 加入世界/战斗会话时支持加入邀请和确认机制,并且 - OnWorldBattleSessionTransfer事件已合并到- OnWorldBattleSessionUpdated事件中,不再单独支持。
- Title Config Data: 它是一组用于整个游戏的Key Value对。它通常用于存储适用于整个游戏的配置数据,例如游戏region信息列表、游戏客户端版本控制数据等等。如果您使用 HTTP API 访问title file,请参阅规范 以查看 HTTP API 的验证方法。 
- Title File: PGOS 提供了一个文件管理系统,用于管理整个游戏的文件。游戏客户端和游戏服务器可以访问游戏文件信息,游戏可以选择使用获取的 URL 下载文件。如果您使用 HTTP API 访问游戏文件,请参阅规范 以查看 HTTP API 的验证方法。 
- Player Data: - GetPlayerVersionedKVData API 将在传入空key array 时返回所有版本化key values。
- 新增 GetPlayerKVDataTemplates API,该 API 将返回在 PGOS 控制台上配置的Player KV 数据模板。[仅限Backend HTTP API]
 
- DS Hosting: 支持Fleet中的存储配置,允许游戏自定义Fleet中机器使用的存储大小。  
- Economy: 添加新的 API GetStoreCategories 来获取制定的store categories. 
- 崩溃改进:在崩溃详情中可以查看关联的战斗会话,在战斗会话详情中可以查看关联的崩溃。 
- Virtual Server: - 将 CI/CD 描述、状态和错误信息公开到 CLI,请参阅 CLI 命令部分。 
- 支持在门户上创建 VS 存储 
  
- Event: 增加 EventPlayerEventChannelAvailable 
修复问题
- 首次 CI 执行失败后,VS无法重启。
- 部分Budle显示的价格折扣不正确。
更新 SDK 注意事项
- PgosSDK不再支持- pgos_game_config.ini/- pgos_game_server_config.ini。如果游戏当前使用这些配置文件,您可以将配置传输到 PgosSDK UE 插件设置 或 代码。
PGOS Tools
Updated CLI tool version to V0.2.11
将 CLI 手册分为 Title CLI Command 和 Title Region CLI Command](../manual/cli_manual/command_reference.html)。
Added New CLI APIs:
- Title Config Data- list-title-config-data
- create-title-config-data
- update-title-config-data
- delete-title-config-data
- describe-title-config-data
 
Updated CLI APIs
- Added InvitationTimeoutSecondsfiled in world APIs:- create-world-config
- update-world-config
- describe-world-config
- list-world-config
 
- Added AdvancedMode,TeamsGroups,FlexiblePlacerMappingfields in Lobby APIs:- create-lobby-config
- update-lobby-config
 
- Added DeployStatus/DeployMessagefiled in VS APIs:- list-virtual-server
- describe-virtual-server
 
SDK Download Link:PGOS_SDK_V0.26.0
Updated backend API dominion, please pay attention to updating the domain in the game configuration. The old domain will be deprecated on December 31st.

V0.25.1(2024-05-31)
PGOS Services:
New Features
- Matchmaking post-processing: When PGOS completed matchmaking workflow, it supports using virtual server to inspect, adjust, and modify the matchmaking results, game side can determine the validity of the matchmaking results, change the matchmaking results, and re-queuing certain matchmaking tickets into the matchmaking queue to start re-matchmaking.
- Economy: Added player purchase limit of store item.
- Battle Service: Supported asynchronous invoke to the player battle session management APIs.
- Virtual Server:- Allowed to update virtual server image while VS stopped.
- Added consuming item idempotency token in virtual server’s request data.
- Added VS CI/CD tracing and optimized the status display of VS on the portal.
 
- PgosSDK : PgosSDK has adapted to Nintendo Switch SDK. Notes.
Fixed Bugs:
- The bucket-path is missing on LP DS.
- Failing idempotency test in subtract virtual currency in VS.
- Incorrect player battle session ID being reported for all additional players in party based matchmaking.
- Sometimes a battle session for a DS in an local placer goes into a "zombie" state after the DS terminates.
PGOS Tools: Updated CLI APIs
- export-virtual-currency
- check-virtual-currency
- import-virtual-currency
- export-ingame-item
- check-ingame-item
- import-ingame-item
- export-platform-item
- check-platform-item
- import-platform-item
- export-store
- check-store
- import-store
- list-battle-session
- describe-battle-session
- list-battle-session-log-file
- list-player-battle-session
 
- Added Parameters in APIs - API: create-match-config, update-match-config- Added parameters: PostProcessing,PostProcessingVirtualServer, it is used to support Virtual Server to inspect, adjust, and modify the matchmaking results
 
- Added parameters: 
- API: create-store-item, update-store-item- Added parameters: MaxPurchaseAmount, it is used to player purchase limit of store item
 
 提示- We plan to deprecate the following APIs in V0.26 and suggest to use new APIs added in V0.25.1. Please pay attention to adapt to the protocol when using new APIs. - export-economy-currency-json-content 
- import-economy-currency-json-content 
- export-economy-ingame-item-json-content 
- import-economy-ingame-item-json-content 
- export-economy-platform-item-json-content 
- import-economy-platform-item-json-content 
- export-economy-store-json-content 
- import-economy-store-json-content 
 
- API: create-match-config, update-match-config
SDK Download Link:PGOS_SDK_V0.25.1
V0.25.0(2024-04-30)
新功能
- PgosSDK UE Plugin - 多 PIE 实例优化:引入 客户端 SDK 实例模式,并使用统一的 - IPgosSDKCpp::Get()API 获取 SDK 实例,降低开发者管理 SDK 实例的复杂度(旧方式:- IPgosSDKCpp+- PgosClientSDKCppSubsystem)。新方式:在- IPgosSDKCpp::Get()API 中添加默认参数 (- ULocalPlayer*)。- 如果您的游戏未使用 - PgosSDK的多 PIE 实例功能,则无需进行任何修改。- static IPgosSDKCpp& Get(ULocalPlayer* LocalPlayer = nullptr);
- IPgosSDKCpp::CreatePGOS()API 已移除- bool AutoDestroy参数。如果您仍然需要该参数,可以使用- IPgosSDKCpp::GetPreCreateSettings().SetAutoDestroyPgosSDKForSingleton(bool AutoDestroy)替代。
 
- Player Auth - LoginPGOSAPI 参数- FClientLoginPGOSParams移除了- account id字段:账户 id 不再需要开发者传入,PGOS 后端会从相关账户提供商处获取。
- 在 Player Auth 中添加 Event Channel Status Changed Event,Event Channel作为 PGOS 后端向客户端发送事件通知(例如 chat_messages/friend_requests)的数据管道。在某些情况下,此事件可帮助游戏/玩家了解 PGOS/游戏服务降级的可能原因。
 
- Player Profile - 在门户控制台添加 玩家昵称设置: - 在 PGOS 后台添加配置,以支持昵称唯一性。如果游戏要求昵称不能重复,请联系我们启用该配置。
- 添加显昵称验证配置,包括字符长度验证、正则表达式验证等。
  
- Lobby - Lobby Config中添加 Start Battle Condition :  - Lobby所有者调用 - StartBattle接口时的操作取决于Lobby成员的- Ready标志:- All Ready Otherwise Waiting:全部就绪,否则等待。Lobby将进入 准备 阶段,等待未准备好的玩家准备就绪。当Lobby处于 准备 阶段时,切换队伍位置将导致Lobby回退到 等待 阶段。
- All Ready Otherwise Error:全部就绪,否则出错。如果并非所有玩家都已准备就绪,Lobby所有者将收到错误消息。
- Ignoring Ready Flag:忽略就绪标志。Lobby将直接进入 游戏 阶段,忽略 Ready标志。
 - The action when the lobby owner invokes the - StartBattleinterface depends on the- Readyflag of lobby members:- All Ready Otherwise Waiting: The lobby will enter the Preparing stage, waiting for unready players to get ready. When the lobby is in the Preparing stage, switching the team slot will cause the lobby to fall back to the Waiting stage.
- All Ready Otherwise Error: The lobby owner will receive an error if not all players are ready.
- Ignoring Ready Flag: The lobby will enter the Playing stage directly, ignoring the Readyflag.
 
- Economy - Schedule store category availability in advance: You can create multiple store categories, which are divided into simple categories and advanced categories.- For simple categories, you can publish all or part of the store items in the category at any time.
- For advanced categories, you can customize the published schedule of store items more flexibly.
 
- Support item instance tags: You can update the tags data of the specified item instance in the player's inventory by calling SetInstanceTags API, both the client and the server can invoke this API.
- Supported item instance mutable custom data: The mutable custom data(key-value pairs) of the item instance, which can be set or increased by the server. You can use these APIs to set or increase mutable custom data: GrantItemToPlayer, SetInstanceCustomData, and IncrInstanceCustomData
 
- Schedule store category availability in advance: You can create multiple store categories, which are divided into simple categories and advanced categories.
- Virtual Server - Add system preset Environment Variables. 提示- SUGGEST TO USE ENVIRONMENT VARIABLES TO GET STORAGE INFORMATION - We recommend using environment variables to obtain information on Virtual Server Storage, which can avoid hard coding and improve the maintainability of the code.
- In future versions, we will hide the Virtual Server Storage information on the portal and only allow to access it through environment variables.
 
- Others - UE DS log collection optimization.
 
Fixed Bugs:
- Virtual Server build finding the wrong Dockerfile.
- PgosSDKoccasionally crashes on shutdown in multiple PIE instances.
- Incorrect console warning log: "WARNING: GET SECRET_KEY FROM INI FILE SUCCESS! TO AVOID KEY LEAKS, SECRET_KEY SHOULD NOT BE CONFIGURED IN GAME RELEASE BUILDS IN PGOS_CONFIG.INI OR PGOS_SERVER_CONFIG.INI !!!", but the game did not do that.
Upgrade SDK Note
- The pay_platformfield has been added to the parameters of theGetStoreAPI. TheGetStoreWithPlatformAPI has been deprecated, and you can useGetStoreinstead.
- The deprecated PurchaseStoreItemAPI has been removed. You can useCreateStoreOrderandCommitStoreOrderinstead.
- This version of the Store has undergone significant changes. If you need to add or modify stores and store items on the portal, you will need to upgrade to the latest SDK [v0.25.0 and above]. If you don't need to make changes to the store on the portal for now, you can continue using the old version of the SDK. However, for a better experience, it is still recommended to upgrade to the new version.
PGOS Tools: Updated CLI APIs
- Lobby Config - Added new parameter  StartBattleConditionincreate-lobby-configAPI
- Added  new parameter  StartBattleConditioninupdate-lobby-configAPI
- Changed ConfigurationName to Name in below APIs- list-lobby-config
- describe-lobby-config
- delete-lobby-config
 
 
- Added new parameter  
- Store Item - Added new APIs: - list-store-item
- describe-store-item
- create-store-item
- update-store-item
- delete-store-item
- enable-store-item
- disable-store-item
 
- Store Item - Added new APIs: - list-store-category
- describe-store-category
- create-store-category
- update-store-category
- delete-store-category
- enable-store-category
- disable-store-category
- set-store-category-schedule
 
- Deprecated APIs - list-title-data
- create-title-data
- delete-title-data
- update-title-data
- export-title-data-json-content
- import-title-data-json-content
 
SDK Download Link:PGOS_SDK_V0.25.0
V0.24.0(2024-03-29)
PGOS Services:
New Features
- Added joining and invite strategy to Party service - Added two parameters - join_strategyand- invite_strategyin- create partyAPI:- join_strategycontrols how other players join the party- EClientPartyJoinStrategy - Description - Public - Any player can join the party, except for the player who is blocked by the leader. 
 It's the default policy.- OnlyFriendsOfLeader - Only friends of the leader are allowed to join the party. - OnlyFriendsOfMembers - Only friends of any member who are not blocked by the leader are allowed to join the party. - OnlyInvited - Only explicitly invited players who are not blocked by the leader are allowed to join the party. - invite_strategycontrols how the members of the party invite others.- EClientPartyInviteStrategy - Description - AllMembersCanInvite - All members of the party are allowed to invite other players to join the party. 
 A player who is blocked by the leader or the inviting player can't be invited.
 It's the default policy.- OnlyLeaderCanInvite - Only the leader is allowed to invite other players to join the party. 
 A player who is blocked by the leader can't be invited.
- The store ID can be set by game, instead of automatically assigned by PGOS 
- Build name and fleet name are not allowed to be modified after the creation 
- Added comments for the secret key on the title setting page  
- Added Events history on the Virtual server page to facilitate debugging  
- Added Singapore zone on Tencent Cloud 
- Matchmaking performance improvements and stability optimization 
Upgrade SDK Note
- TitleKVDatais renamed to- TitleRegionConfigKVData, such as:- Old Name - New Name - FPgosTitleAPI::GetTitleKVData - FPgosTitleRegionConfigDataAPI::GetTitleRegionConfigKVData - FPgosTitleAPI::GetAllTitleKVData - FPgosTitleRegionConfigDataAPI::GetAllTitleRegionConfigKVData - FTitleKVDataQueryResult - FTitleRegionConfigKVDataQueryResult - ❗❗❗ Note: When upgrading the PGOS plugin, Please delete the old \Plugins\PgosSDK\ directory first instead of directly overwriting it with the new PgosSDK directory. Otherwise, the remaining PgosClientTitleAPI.cpp & PgosServerTitleAPI.cpp files may cause compilation errors. 
- The - IPgosSDKCpp::CreatePGOSAPI has been added with a default parameter:- void CreatePGOS(bool AutoDestroy = true)- If the AutoDestroyparameter is set to true (default value), the plugin will automatically attempt toDestroyPGOSduringEndPIEandShutdownModule, maintaining the previous behavior. That is, if the game wants to maintain its previous behavior, it does not need to change any code.
- If the AutoDestroyparameter is set to false, the lifetime of PgosSDK will be completely controlled by the game. In this case, the plugin will never attempt to activelyDestroyPGOSunder any circumstances.
 
- If the 
PGOS Tools
- Title Region Config Data (Title Data Changed to Title Region Config Data) - Added new APIs: - list-title-region-config-data
- create-title-region-config-data
- delete-title-region-config-data
- update-title-region-config-data
- export-title-region-config-data-json-content
- import-title-region-config-data-json-content
 - Deprecated APIs(Keep in V0.24,remove from V0.25) - list-title-data
- create-title-data
- delete-title-data
- update-title-data
- export-title-data-json-content
- import-title-data-json-content
 
- Player KV Data Group (Player Group changed to Player KV Data Group) - Added new APIs: - add-player-kv-data-group
- update-player-kv-data-group
- remove-player-kv-data-group
 - Deprecated APIs(Keep in V0.24,remove from V0.25) - add-player-group
- update-player-group
- remove-player-group
 
- DS Hosting CVM Instance - Added New APIs: - list-fleet-cvm-instance
- list-fleet-cvm-instance-file
- collect-fleet-cvm-instance-file
- cancel-fleet-cvm-instance-file-collection
- describe-fleet-cvm-instance-file-collection
 
- Economy Virtual Currency - Added New APIs - list-virtual-currency
- describe-virtual-currency
- create-virtual-currency
- update-virtual-currency
- delete-virtual-currency
 
- Economy Ingame Item - Added New APIs - list-ingame-item
- describe-ingame-item
- create-ingame-item
- update-ingame-item
- delete-ingame-item
 
- Economy Platform Item(Item Mapping Changed to Platform Item) - Added New APIs - export-economy-platform-item-json-content
- import-economy-platform-item-json-content
 - Deprecated APIs(Keep in V0.24,remove from V0.25) - export-economy-item-mapping-json-content
- import-economy-item-mapping-json-content
 
- Economy Store - Added New APIs - list-store
- describe-store
- create-store
- update-store
- delete-store
 
Advance Notice: there are significant changes to the fields and protocols for the following APIs in V0.25, we will deprecate them in V0.25 and provide new APIs
- export-economy-store-item-json-content
- import-economy-store-item-json-content
- export-economy-store-category-json-content
- import-economy-store-category-json-content
SDK Download Link:PGOS_SDK_V0.24
V0.23.2(2024-03-05)
Fixed Bugs:
- Fixed an occasional crash in the client SDK lobby module.
- Added friend‘s presence to player friend information
- Optimized notification events of world service
- The IOS library was not being found during the APP launch
SDK Download Link:PGOS_SDK_V0.23.2
V0.23.0(2024-02-02)
PGOS Service
New Features
- Matchmaking: Supported selecting multiple maps and multi-game modes at the same time when initiating matchmaking. 
- Xbox Store Reconciliation: it allows games to synchronize items purchased by players from the Xbox store to PGOS and allows games to build an economy by selling PGOS-managed items using Xbox as the "payment processor" 
- Lobby: Added configuration to control lobby joining, which can be modified by the lobby owner: - Free to join the lobby
- Apply to join the lobby. A join request will be sent to the lobby owner, who can approve or reject the request.
- Simplified lobby event data structure, no longer returns full lobby details in team updated and global/player data updated events.
 
- World: Added - Equivalent Valuesfiled in filter rules, which allows multiple sets of equivalent values for the attribute. The game can use this configuration to merge attribute values for which it does not wish to divert players into different buckets.
- Statistics: Added - BatchGetStatCycleRoundInfoAPI to query the cycle end time.
- Only recommend online players
- Supported developers to set the game's default upper limit of the player‘s friends on the portal
- Provided BatchSetPlayerFriendsLimitAPI to set the upper limit of the individual player's friends
 
- Added a new API - FPgosBattleAPI::GetDSHostingLatenciesto get the latency mapping from the client to the data centers of DS hosting.
- Added a new API - FPgosPlayerAuthAPI::MyAuthTicketto facilitate player verification on the game server.
- Added multiplayer support for Unreal SDK: The PGOS SDK supports both multiple PIE instances in UE Editor and multiple local players in the game. 
- Supports Virtual Server v2.0 in AWS Title Region. 
- PGOS Prometheus Exporter: PGOS provides the PrometheusExporter to help the game import data metrics into Prometheus, then you can use Grafana to customize the alert rules and show a custom dashboard on the game side to monitor the API request or specific metrics. 
- Added Roadmap on the portal. 
Upgrade SDK Note
- To support the multiplayer support feature, each PGOS Client SDK instance appears as a Unreal LocalPlayerSubsystem. Therefore, PGOS related services can only work after theUnreal LocalPlayerSubsystemis ready. If the old PGOS-related code in game is not working, you may need to adjust the position of theCreatePGOS-relatedcode.
- The FPgosFriendAPI::GetRecommendedPlayersandFPgosFriendAPI::GetPotentialPlayersAPIs now include a parameter to specify the number of players to be returned.
SDK Download Link:PGOS_SDK_V0.23
PGOS Tools
New Features
Updated the CLI APIs
- Added the - MultiRulesetEnabled、- MultiRulesetsfields in below Matchmaking APIs- list-match-config
- describe-match-config
- create-match-config
- update-match-config
 
- Added - EquivalentValuesfield in below World APIs:- create-world-filter
- list-world-filter
- update-world-filter
- describe-world-filter
 
- Added - ResourceFileMD5、- MaxInstanceStrategyin the below Virtual Server APIs- create-virtual-server
- list-virtual-server
- update-virtual-server
- describe-virtual-server
 
Added new CLI API
- Virtual Server - describe-virtual-server-env-vars
- update-virtual-server-env-vars
 
- Task - list-task 
- create-task 
- update-task 
- delete-task 
- describe-task 
- execute-task 
 
- Event - list-event
- list-event-handler
- describe-event-handler
- create-event-handler
- update-event-handler
- delete-event-handler
 
- Player custom info - export-player-custom-info-definition
- import-player-custom-info-definition
 
PGOS Tools Download Link:CLI V0.2.10
V0.22.1(2023-12-08)
New Features:
- Added JoinWorldBattleSessionAPI in World service, which allows players to join a specified world battle session.
- Optimize Economy's API to support idempotency.- Client SDK: ConsumeInstance
- Server SDK: GrantItemToPlayer,GrantCurrencyToPlayer
- HTTP API: GrantItemToPlayer,GrantCurrencyToPlayer,SubtractPlayerCurrency
 
- Client SDK: 
- Added event_custom_dataparameter in Economy's API, which supports passing a game-defined value to PGOS virtual server event.- Client SDK: CreateStoreOrder,ConsumeInstance,OpenContainerInstance,RevokeInstance,SyncPlayerPlatformInventory,SyncSteamPurchase
- Server SDK: GrantItemToPlayer,GrantCurrencyToPlayer
- HTTP API: GrantItemToPlayer,GrantCurrencyToPlayer,SubtractPlayerCurrency,RevokeItemInstance
 
- Client SDK: 
PGOS Tools:CLI V0.2.9
- Provided CLI HTTP API and developers can use any programming language to implement automated resource management.
- Adapted to Mac
PGOS SDK: PGOS_SDK_V0.22.1
V0.22.0(2023-11-28)
New Service:
- World: World is an entity that players can join and leave freely and smoothly. It can be used to implement a variety of online gaming features. Typical application scenarios include:- A persistent and freely accessible gaming scene, such as a game lobby or game hub.
- A large game that does not require complex matchmaking rules.
 
New Features:
- Steam Store Reconciliation: it allows games to synchronize items purchased by players from the Steam store to PGOS and allows games to build an economy by selling PGOS-managed items using Steam as the "payment processor"
- Supported Player Data Versioned attribute, and new SDK APIs:- Client SDK: GetMyVersionedKVData,SetMyVersionedKVData
- Server SDK: GetPlayerVersionedKVData,BatchGetPlayerVersionedKVData,SetPlayerVersionedKVData,BatchSetPlayerVersionedKVData.
 
- Client SDK: 
- Supported importing and exporting the configuration of Virtual server, Leaderboard, Statisitc, and Goals to other regions.
- Supported integrating Matchmaking without using PGOS DS hosting, games only get the matchmaking result and manage the battle session by themselves.
- Optimize the process of purchasing items in the store to support idempotency.
- Added a parameter round_end_timein theGetStatCycleInfoandBatchGetStatCycleInfoAPIs.
- Added backend HTTP API to get battle sessions:- QueryBattleSessions
 
- Added backend HTTP API for group custom data:- SetGroupTags
- SetGroupGlobalCustomData
- DelGroupGlobalCustomData
- ClearGroupGlobalCustomData
- BatchSetGroupPlayerCustomData
 
- Added  FClientLogoutPGOSParamsparameter in LogoutPGOS API, which supports a game-defined custom value pass to PGOS backend event:event_player_logout_pgos.
Upgrade Note
- PGOS SDK Adapted to UE 5.3 
- Removed GME SDK (Voice feature) from PGOS SDK. 
- Virtual Server V1 is not available anymore, please use Virtual Server V2. 
- The parameter structure of the Player Profile API has changed due to the addition of the 'versioned' attribute, supplementary of error messages, and the optimization of the 'set' player data rule ( [Explanation]). PGOS V0.22 SDK adjusted the data structure related to player data. - 4.1 Input parameter structures: - API Name - Input Old - Input New - BatchIncrPlayerKVData - TArray<FServerPlayerKVDataIncrements> - TArray<FPlayerKVDataGroup> - 4.2 Callback data parameter structures: - API Name - Callback Data Old - Callback Data New - GetOneOfMyKVData - FKVDataValue - FOnePlayerKVData - GetMyKVData - FGetPlayerKVDataRsp - FPlayerKVDataGroupWithFails - SetMyKVData - FClientSetMyKVDataRsp - no callback data [Explanation] - IncrOneOfMyKVData - FClientIncrOneOfMyKVDataRsp - FOnePlayerKVData - IncrMyKVData - FClientIncrMyKVDataRsp - FKVDataGroup - GetOneOfPlayerKVData - FKVDataValue - FOnePlayerKVData - GetPlayerKVData - FGetPlayerKVDataRsp - FPlayerKVDataGroupWithFails - BatchGetPlayerKVData - FBatchGetPlayerKVDataRsp - FBatchPlayerKVDataGroupWithFails - BatchGetPlayerPublicKVData - FBatchGetPlayerGroupKVDataRsp - FBatchPlayerKVDataGroup - BatchGetPlayerGroupKVData - FBatchGetPlayerGroupKVDataRsp - FBatchPlayerKVDataGroup - SetPlayerKVData - FServerSetPlayerKVDataRsp - no callback data [Explanation] - BatchSetPlayerKVData - FServerBatchSetPlayerKVDataRsp - FBatchPlayerOperationResult - IncrOneOfPlayerKVData - FServerIncrOneOfPlayerKVDataRsp - FOnePlayerKVData - IncrPlayerKVData - FServerIncrPlayerKVDataRsp - FPlayerKVDataGroup - BatchIncrPlayerKVData - FServerBatchIncrPlayerKVDataRsp - FBatchPlayerKVDataGroup - Explanation: A player's - KVDataupdate operation either succeeds or fails in its entirety, so there will no longer be a- failed_keysfield in the callback data for the update operation. However, retrieving- KVDataoperations is still allowed to be partially successful, which means that the callback data will still contain the- failed_keysfield.
PGOS Tools:CLI V0.2.8:
Renamed existing APIs:
- Ruleset - find-match-rule-set-list -> list-match-ruleset
- find-match-rule-set-by-name -> describe-match-ruleset
- create-match-rule-set -> create-match-ruleset
- delete-match-rule-set-by-name -> delete-match-ruleset
- update-match-rule-set-by-name -> update-match-ruleset
- publish-draft-match-rule-set -> publish-match-ruleset-draft
 
- Match Configuration 
- find-match-config-list -> list-match-config 
- find-match-config-by-name -> describe-match-config 
- create-match-config -> create-match-config 
- delete-match-config-by-name -> delete-match-config 
- update-match-config-by-name -> update-match-config 
- update-match-config-status-by-name -> update-match-config-status 
Added new APIs:
- Lobby Configuration - create-lobby-config
- list-lobby-config
- update-lobby-config
- describe-lobby-config
- delete-lobby-config
- update-lobby-config-status
 
- World Filter - create-world-filter 
- list-world-filter 
- update-world-filter 
- describe-world-filter 
- delete-world-filter 
 
- World Configuration - create-world-config 
- list-world-config 
- update-world-config 
- describe-world-config 
- delete-world-config 
 
- Ingame Item Mapping - export-economy-item-mapping-json-content 
- import-economy-item-mapping-json-content 
 
- Goal - list-goal 
- describe-goal 
- create-goal 
- update-goal 
- delete-goal 
- list-pass-by-goal 
- update-passes-by-goal 
- list-tier-by-goal 
- describe-tier-by-goal 
- update-tiers-by-goal 
- update-tier 
- delete-tiers 
- create-tier 
 
- Schedule - list-schedule 
- update-schedule 
- publish-schedule 
- retire-schedule 
- create-schedule 
- describe-schedule 
- delete-schedules 
 
- Cycle - list-cycle 
- describe-cycle-by-name 
- describe-cycle-stat-items 
- describe-binded-cycles 
- bind-stat-to-cycle 
- unbind-stat-from-cycle 
- create-cycle 
- update-cycle 
- delete-cycle 
 
- Stat - list-stat 
- describe-stat 
- describe-persistent-stat-item 
- update-stat-key 
- delete-stat-key 
- describe-recent-stat-items 
- delete-stat 
- create-stat 
- update-stat 
 
- Leaderboard - describe-leaderboard 
- describe-leaderboard-by-name 
- list-ranking 
- list-ranking-by-key 
- create-leaderboard 
- update-leaderboard 
- delete-leaderboard 
 
PGOS SDK:PGOS_SDK_V0.22.0