Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/compscidr/llegend
local legend tools
https://github.com/compscidr/llegend
golang locallegend strava
Last synced: about 2 months ago
JSON representation
local legend tools
- Host: GitHub
- URL: https://github.com/compscidr/llegend
- Owner: compscidr
- Created: 2022-07-27T23:03:11.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-09-26T17:47:27.000Z (over 1 year ago)
- Last Synced: 2024-06-21T01:59:15.689Z (7 months ago)
- Topics: golang, locallegend, strava
- Language: Go
- Homepage:
- Size: 85 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# llegend
WiP, but goal is:
- shows segments you are local legend of on a map
- color coding of the segment showing how close to being overtaken
- color red = someone is nearly passed efforts
- color green = many efforts before someone catches you
- color gray = lost LL
- later: show segments you are getting close to being LL for with similar color coding## building and running
There are three necessary environment variables to run. The first is the access
token for the strava API, the second is the athlete ID, the third is the google maps API key.
```
ACCESS_TOKEN=
ATHLETE=
GMAPS=
```You can get a strava API token by creating an app here: https://www.strava.com/settings/api
And you get the athlete id from your strave profile page (its at the end of the URL)These can be set via `.env` file for docker and docker-compose, otherwise
they can be passed in via the command to run the program:### locally
```
go build
ACCESS_TOKEN= ATHLETE= ./llegend
```### docker
```
docker build -f Dockerfile . -t llegend
docker run -p 8080:8080 --env-file .env llegend
```### docker-compose
`docker-compose up --build`Then browse to http://localhost:8080
## What works
- Can get starred segments for the user and determine whether or not local legend![screenshot of what works](screenshot.png)
## Todo
- Add map data for segment to data structure we return to template
- Integrate some type of map API
- Plot segments on map- For segments which we are LL for:
- Determine our current efforts in past 90 days from histogram
- Determine next nearest total from past 90 days from histogram
- Add difference score to data structure we return to template
- Plot map with colors corresponding to difference score- For segments which we are not LL for:
- Determine our current efforts in past 90 days from results
- Determine the current leaders 90 day effort
- Determine difference score
- Plot map with colors corresponding to difference score
- distinguish between those we are LL of and those we could become- Create periodic task to refresh data
- Notify via email or something if about to lose LL
- Tests
- Spruce up the UI## inspiration projects
http://www.raceleap.live/
https://stravanity.vercel.app/