Boilerplate Laravel 9x application to scrape API data from https://nhl.com.
This tool is currently able to scrape:
- Game Schedules
- Player Information
- Game Play By Play
- Game Team Stats
- Game Skater / Goalie Stats
Season / All Time stats are summarized based off game information scraped, missing game data will lead to incorrect totals.
- copy .env.example to .env
- bash setup.sh
- sail up -d
- sail artisan key:generate
- sail composer install
- sail artisan migrate:fresh --seed
- sail artisan horizon
Commands used to scrape data from NHL API.
Note:
- Before scraping game data the schedules must be scraped for all seasons or the season you are looking to scrape.
- By default commands will not overwrite previously imported schedules. You may use the --overwriteoption to override.
Fetch all games:
sail artisan nhl:games
Fetch all games for a season:
sail artisan nhl:games 20192020
Fetch all games for a range of seasons:
sail artisan nhl:games 20192020-20202021
Fetch one game:
sail artisan nhl:games 2019020001
Fetch a range of games:
sail artisan nhl:games 2019020001-2019020500
Fetch schedule for all seasons:
sail artisan nhl:schedule
Fetch schedule for specified season:
sail artisan nhl:schedule 20192020
Fetch schedule for range of seasons:
sail artisan nhl:schedule 20192020-20202021
Commands use calculate season/alltime stats from fetched game data.
Calculate all-time stats skater/goalie/team:
sail artisan nhl:alltime {skaters|goalies|teams?}
Calculate season stats skater/goalie/team:
sail artisan nhl:season {skaters|goalies|teams?}
- https://statsapi.web.nhl.com/api/v1/schedule?season={seasonId}
- Game Schedules
 
- https://statsapi.web.nhl.com/api/v1/game/{gameId}/feed/live?site=en_nhl
- Player information
- Play By Play
- Team Stats
- Skater / Goalie Stats
 
- https://statsapi.web.nhl.com/api/v1/people/{playerId}/stats?stats=gameLog&season={seasonId}
- Backup endpoint used if missing game data from live feed.
- Player Information
 
All scraping / calculation tasks are defered to a queue (games, schedule, calculate).
More info on Laravel Horizon can be found here
Game ID is a unique identifier assigned to each game. 10 characters in length the first 4 characters describe the year. The next 2 characters describe the type of game (pre season = 01, regular season = 02, playoffs = 03), the remaining digits are used to describe the game.
Examples:
- Game 100 of regular season: 2020020100
- Game 15 of playoffs: 2020030015
PHP Unit
sail artisan test
PHP Stan (Level 8)
./vendor/bin/phpstan analyse app
- HTML game logs (?)
- Advanced stats calculations
- Find alternative to Player Info
- change alltime/season to fetches.
- verify removing statsNotFound is ok?