A comprehensive Laravel package for interacting with the Sleeper Fantasy Sports API. This package provides easy access to all Sleeper API endpoints including users, leagues, drafts, players, and more.
Official Sleeper Resources:
You can install the package via composer:
composer require hotsaucejake/laravel-sleeperThe Sleeper API is read-only and requires no authentication. All methods return JSON objects/arrays containing the requested data. Rate limit: stay under 1000 calls per minute.
use HOTSAUCEJAKE\LaravelSleeper\Facades\LaravelSleeper;Retrieves user information by username.
$user = LaravelSleeper::getUserByName('sleeperuser');
// Returns: { "username": "sleeperuser", "user_id": "12345678", "display_name": "SleeperUser", "avatar": "..." }Retrieves user information by user ID. Recommended over username since usernames can change.
$user = LaravelSleeper::getUserById('12345678');
// Returns: Same format as getUserByName()Returns the full-size avatar URL for a given avatar ID.
$avatarUrl = LaravelSleeper::showAvatar('cc12ec49965eb7856f84d71cf85306af');
// Returns: "https://sleepercdn.com/avatars/cc12ec49965eb7856f84d71cf85306af"Returns the thumbnail avatar URL for a given avatar ID.
$thumbnailUrl = LaravelSleeper::showAvatarThumbnail('cc12ec49965eb7856f84d71cf85306af');
// Returns: "https://sleepercdn.com/avatars/thumbs/cc12ec49965eb7856f84d71cf85306af"Retrieves all leagues for a specific user in a given season.
$leagues = LaravelSleeper::getAllLeaguesForUser('12345678', 2024);
// Returns: Array of league objects with settings, roster info, scoring settings, etc.Retrieves detailed information about a specific league.
$league = LaravelSleeper::getLeague('289646328504385536');
// Returns: Single league object with full configuration detailsRetrieves all rosters in a league with current players, starters, and team records.
$rosters = LaravelSleeper::getLeagueRosters('289646328504385536');
// Returns: Array of roster objects with starters[], players[], settings{wins, losses, points}, etc.Retrieves all users/managers in a league with their team information.
$users = LaravelSleeper::getLeagueUsers('289646328504385536');
// Returns: Array of user objects with metadata{team_name}, is_owner (commissioner status), etc.Retrieves all matchups for a specific week. Teams with the same matchup_id play each other.
$matchups = LaravelSleeper::getLeagueMatchups('289646328504385536', 1);
// Returns: Array with starters[], players[], matchup_id, points, custom_pointsRetrieves the winners bracket for league playoffs.
$bracket = LaravelSleeper::getLeaguePlayoffWinnersBracket('289646328504385536');
// Returns: Array of bracket rounds with team progressions and resultsRetrieves the losers bracket for league playoffs (consolation bracket).
$bracket = LaravelSleeper::getLeaguePlayoffLosersBracket('289646328504385536');
// Returns: Array of bracket rounds for consolation gamesRetrieves all transactions (trades, waivers, free agents) for a specific week/round.
$transactions = LaravelSleeper::getLeagueTransactions('289646328504385536', 1);
// Returns: Array of transactions with type, adds{}, drops{}, draft_picks[], waiver_budget[]Retrieves all traded draft picks in a league, including future picks.
$tradedPicks = LaravelSleeper::getLeagueTradedPicks('289646328504385536');
// Returns: Array with season, round, roster_id (original), owner_id (current)Retrieves current state information for the sport (current week, season, etc.).
$state = LaravelSleeper::getSportState('nfl');
// Returns: { week, season_type, season, previous_season, league_season, display_week }Retrieves all drafts for a specific user in a given season.
$drafts = LaravelSleeper::getDraftsForUser('12345678', 2024);
// Returns: Array of draft objects with type, status, settings, metadataRetrieves all drafts for a specific league (dynasty leagues may have multiple drafts).
$drafts = LaravelSleeper::getLeagueDrafts('289646328504385536');
// Returns: Array of draft objects sorted by most recentRetrieves detailed information about a specific draft.
$draft = LaravelSleeper::getSpecificDraft('289646328508579840');
// Returns: Draft object with draft_order{}, slot_to_roster_id{}, settings{}Retrieves all picks made in a specific draft with player details.
$picks = LaravelSleeper::getDraftPicks('289646328508579840');
// Returns: Array of picks with player_id, picked_by, roster_id, round, metadata{player info}Retrieves all traded picks within a specific draft.
$tradedPicks = LaravelSleeper::getDraftTradedPicks('289646328508579840');
// Returns: Array similar to league traded picks but specific to this draftRetrieves all players in the database. Important: This is a large response (~5MB) - cache locally and call max once per day.
$players = LaravelSleeper::getAllPlayers('nfl');
// Returns: Object with player_id as keys, player objects with name, position, team, stats, etc.getTrendingPlayers(string $type = 'add', string $sport = 'nfl', int $lookback_hours = 24, int $limit = 25)
Retrieves trending players based on add/drop activity.
// Most added players in last 24 hours
$trending = LaravelSleeper::getTrendingPlayers('add');
// Most dropped players in last 48 hours, limit 10
$dropped = LaravelSleeper::getTrendingPlayers('drop', 'nfl', 48, 10);
// Returns: Array of { player_id, count } objectsPlayer IDs can be numeric strings ("1042") or team abbreviations ("CAR" for team defenses).
// Get all players to create a lookup map
$players = LaravelSleeper::getAllPlayers();
$playerName = $players['1042']['first_name'] . ' ' . $players['1042']['last_name'];
$teamDefense = $players['CAR']['position']; // "DEF"Teams with the same matchup_id play against each other:
$matchups = LaravelSleeper::getLeagueMatchups('league_id', 1);
foreach ($matchups as $team) {
// Find opponent by matching matchup_id
$opponent = collect($matchups)->where('matchup_id', $team['matchup_id'])
->where('roster_id', '!=', $team['roster_id'])
->first();
}Bench players = All players - Starting players:
$roster = LaravelSleeper::getLeagueRosters('league_id')[0];
$bench = array_diff($roster['players'], $roster['starters']);In order to run the package tests you must create an .env file from the .env.example file. Tests will use the live endpoints. Since it's under the API rate limit, it's ok for now. I don't think this package will get any bigger than it already is so no need for mocks, etc...
composer testPlease see CHANGELOG for more information on what has changed recently.
The MIT License (MIT). Please see License File for more information.