본문으로 건너뛰기
버전: 5.16.1

GetLeaderboardByScore

BackendUserLeaderboardByScoreReturnObject GetLeaderboardByScore(string leaderboardUuid, int score);
BackendUserLeaderboardByScoreReturnObject GetLeaderboardByScore(string leaderboardUuid, long score);

파라미터

ValueTypeDescription
leaderboardUuidstring조회할 랭킹의 uuid
scoreint/long조회할 점수

leaderboardUuid 값은 아래 방법을 통해 확인할 수 있습니다.

설명

uuid 값을 이용하여 해당 랭킹에 등록된 랭커들 중 score 값을 가지고 있는 랭커와 해당 점수 위, 아래 점수의 랭커를 조회합니다.

  • 조회한 score의 유저가 여러 명 존재할 경우 모든 유저가 조회됩니다.
  • 해당 score의 위, 아래 점수의 유저가 여러 명 존재하더라도 각각 단 한 명의 유저만 조회됩니다.
  • 해당 함수는 SendQueue로 호출할 수 없습니다.

BackendUserLeaderboardByScoreReturnObject

namespace BackEnd.Leaderboard
{
public class UserLeaderboardItem
{
public string gamerInDate;
public string nickname = string.Empty;
public string score;
public string index;
public string rank;
public string extraData = string.Empty;
public string extraName = string.Empty;
}

public class BackendUserLeaderboardByScoreReturnObject : BackendUserLeaderboardReturnObject
{
public long GetTotalCount();
public List<UserLeaderboardItem> GetUserLeaderboardList();
public List<UserLeaderboardItem> GetPreviousUserLeaderboardList();
public List<UserLeaderboardItem> GetNextUserLeaderboardList();
}
}

Example

동기

var score = 0; //조회할 점수
BackEnd.Leaderboard.BackendUserLeaderboardByScoreReturnObject bro = Backend.Leaderboard.User.GetLeaderboardByScore("01920445-a435-759e-bc3b-048a1e7a87aa", 5);

Debug.Log(bro.GetTotalCount());

// 검색한 스코어보다 더 높은 순위의 유저
foreach(BackEnd.Leaderboard.UserLeaderboardItem item in bro.GetNextUserLeaderboardList())
{
Debug.Log($"{item.rank}위 : {item.nickname}");
Debug.Log(item.ToString());
}

foreach(BackEnd.Leaderboard.UserLeaderboardItem item in bro.GetUserLeaderboardList())
{
Debug.Log($"{item.rank}위 : {item.nickname}");
Debug.Log(item.ToString());
}

// 검색한 스코어보다 더 낮은 순위의 유저
foreach(BackEnd.Leaderboard.UserLeaderboardItem item in bro.GetPreviousUserLeaderboardList())
{
Debug.Log($"{item.rank}위 : {item.nickname}");
Debug.Log(item.ToString());
}

비동기

var score = 0; //조회할 점수
BackEnd.Leaderboard.User.GetLeaderboardByScore("leaderboardUuid", score, bro=> {
Debug.Log(bro.GetTotalCount());

// 검색한 스코어보다 더 높은 순위의 유저
foreach(BackEnd.Leaderboard.UserLeaderboardItem item in bro.GetNextUserLeaderboardList())
{
Debug.Log($"{item.rank}위 : {item.nickname}");
Debug.Log(item.ToString());
}

foreach(BackEnd.Leaderboard.UserLeaderboardItem item in bro.GetUserLeaderboardList())
{
Debug.Log($"{item.rank}위 : {item.nickname}");
Debug.Log(item.ToString());
}

// 검색한 스코어보다 더 낮은 순위의 유저
foreach(BackEnd.Leaderboard.UserLeaderboardItem item in bro.GetPreviousUserLeaderboardList())
{
Debug.Log($"{item.rank}위 : {item.nickname}");
Debug.Log(item.ToString());
}
});

ReturnCase

Success cases

조회에 성공한 경우
statusCode : 200
message : Success
returnValue : GetReturnValuetoJSON 참조

조회에 성공하였으나 랭킹의 유저가 등록되지 않은 경우
statusCode : 200
message : Success
returnValue : {"rows":[],"previousRank":{"NULL":true},"nextRank":{"NULL":true},"totalCount":0}

조회에 성공하였으나 해당 점수의 유저가 존재하지 않는 경우
statusCode : 200
message : Success
returnValue : GetReturnValuetoJSON 참조

Error cases

uuid가 null 혹은 string.Empty인 경우
statusCode : 400
errorCode : ValidationException
message : leaderboardUuid is null or empty

존재하지 않는 uuid로 조회를 시도한 경우
StatusCode : 404
ErrorCode : NotFoundException
Message : leaderboard not found, leaderboard을(를) 찾을 수 없습니다

GetReturnValuetoJSON

해당 점수의 유저와 위, 아래 점수를 가진 유저가 모두 존재하는 경우

{
"rows": [
{
"gamerInDate": "2024-05-08T07:17:20.455Z",
"nickname": "match5",
"rank": 5,
"index": 4,
"score": "5"
}
],
"previousRank": [
{
"gamerInDate": "2024-05-08T07:17:20.928Z",
"nickname": "match6",
"rank": 4,
"index": 3,
"score": "6"
}
],
"nextRank": [
{
"gamerInDate": "2024-05-08T07:17:19.951Z",
"nickname": "match4",
"rank": 6,
"index": 5,
"score": "4"
}
],
"totalCount": 10
}

해당 점수를 가진 유저는 없지만, 해당 점수보다 높은 점수를 가진 유저는 존재하는 경우

{
"rows": [],
"previousRank": [
{
"gamerInDate": "2024-05-08T07:17:17.625Z",
"nickname": "match0",
"rank": 10,
"index": 9,
"score": "0"
}
],
"nextRank": {
"NULL": true
},
"totalCount": 10
}

해당 점수를 가진 유저는 없지만, 해당 점수보다 낮은 점수를 가진 유저는 존재하는 경우

{
"rows": [],
"previousRank": {
"NULL": true
},
"nextRank": [
{
"gamerInDate": "2024-05-08T07:17:22.518Z",
"nickname": "match9",
"rank": 1,
"index": 0,
"score": "9"
}
],
"totalCount": 10
}