Class: TrophyApiClient::LeaderboardsClient

Inherits:
Object
  • Object
show all
Defined in:
lib/trophy_api_client/leaderboards/client.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(request_client:) ⇒ TrophyApiClient::LeaderboardsClient

Parameters:



16
17
18
# File 'lib/trophy_api_client/leaderboards/client.rb', line 16

def initialize(request_client:)
  @request_client = request_client
end

Instance Attribute Details

#request_clientTrophyApiClient::RequestClient (readonly)



12
13
14
# File 'lib/trophy_api_client/leaderboards/client.rb', line 12

def request_client
  @request_client
end

Instance Method Details

#all(request_options: nil) ⇒ Array<TrophyApiClient::LeaderboardResponse>

Get all active leaderboards for your organization.

Examples:

api = TrophyApiClient::Client.new(
  base_url: "https://api.example.com",
  environment: TrophyApiClient::Environment::PRODUCTION,
  api_key: "YOUR_API_KEY"
)
api.leaderboards.all

Parameters:

Returns:



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/trophy_api_client/leaderboards/client.rb', line 31

def all(request_options: nil)
  response = @request_client.conn.get do |req|
    req.options.timeout = request_options.timeout_in_seconds unless request_options&.timeout_in_seconds.nil?
    req.headers["X-API-KEY"] = request_options.api_key unless request_options&.api_key.nil?
    req.headers = {
  **(req.headers || {}),
  **@request_client.get_headers,
  **(request_options&.additional_headers || {})
    }.compact
    unless request_options.nil? || request_options&.additional_query_parameters.nil?
      req.params = { **(request_options&.additional_query_parameters || {}) }.compact
    end
    unless request_options.nil? || request_options&.additional_body_parameters.nil?
      req.body = { **(request_options&.additional_body_parameters || {}) }.compact
    end
    req.url "#{@request_client.get_url(environment: api, request_options: request_options)}/leaderboards"
  end
  parsed_json = JSON.parse(response.body)
  parsed_json&.map do |item|
    item = item.to_json
    TrophyApiClient::LeaderboardResponse.from_json(json_object: item)
  end
end

#get(key:, offset: nil, limit: nil, run: nil, user_id: nil, request_options: nil) ⇒ TrophyApiClient::LeaderboardResponseWithRankings

Get a specific leaderboard by its key.

Examples:

api = TrophyApiClient::Client.new(
  base_url: "https://api.example.com",
  environment: TrophyApiClient::Environment::PRODUCTION,
  api_key: "YOUR_API_KEY"
)
api.leaderboards.get(
  key: "weekly-words",
  run: "2025-01-15",
  user_id: "user-123"
)

Parameters:

  • key (String)

    Unique key of the leaderboard as set when created.

  • offset (Integer) (defaults to: nil)

    Number of rankings to skip for pagination.

  • limit (Integer) (defaults to: nil)

    Maximum number of rankings to return.

  • run (String) (defaults to: nil)

    Specific run date in YYYY-MM-DD format. If not provided, returns the current run.

  • user_id (String) (defaults to: nil)

    When provided, offset is relative to this user’s position on the leaderboard. If the user is not found in the leaderboard, returns empty rankings array.

  • request_options (TrophyApiClient::RequestOptions) (defaults to: nil)

Returns:



77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# File 'lib/trophy_api_client/leaderboards/client.rb', line 77

def get(key:, offset: nil, limit: nil, run: nil, user_id: nil, request_options: nil)
  response = @request_client.conn.get do |req|
    req.options.timeout = request_options.timeout_in_seconds unless request_options&.timeout_in_seconds.nil?
    req.headers["X-API-KEY"] = request_options.api_key unless request_options&.api_key.nil?
    req.headers = {
  **(req.headers || {}),
  **@request_client.get_headers,
  **(request_options&.additional_headers || {})
    }.compact
    req.params = {
      **(request_options&.additional_query_parameters || {}),
      "offset": offset,
      "limit": limit,
      "run": run,
      "userId": user_id
    }.compact
    unless request_options.nil? || request_options&.additional_body_parameters.nil?
      req.body = { **(request_options&.additional_body_parameters || {}) }.compact
    end
    req.url "#{@request_client.get_url(environment: api, request_options: request_options)}/leaderboards/#{key}"
  end
  TrophyApiClient::LeaderboardResponseWithRankings.from_json(json_object: response.body)
end