Tutorial: Search places
This tutorial shows how to search places with SearchPlacesAsync and handle paged responses.
Basic search
using LuduvoDotNet;
var client = new Luduvo();
var places = await client.SearchPlacesAsync("test");
Console.WriteLine($"Found {places.Length} places");
foreach (var place in places)
{
Console.WriteLine($"- {place.Title} by {place.OwnerUsername}");
}
Search with pagination
using LuduvoDotNet;
var client = new Luduvo();
try
{
var places = await client.SearchPlacesAsync("test", limit: 20, offset: 0);
foreach (var place in places)
{
Console.WriteLine($"{place.Id}: {place.Title} (players: {place.ActivePlayers}/{place.MaxPlayers})");
}
}
catch (ArgumentOutOfRangeException ex)
{
Console.WriteLine($"Invalid paging arguments: {ex.Message}");
}
catch (TooManyRequestsException)
{
Console.WriteLine("Rate limit reached. Try again later.");
}
catch (HttpRequestException ex)
{
Console.WriteLine($"API request failed: {ex.Message}");
}
Notes
SearchPlacesAsynccalls/places?q={query}.- The API may return either a direct array or an object with a
placesarray. limitmust be greater than0and less than100.offsetmust be0or greater.