2020-06-05 01:51:25 -07:00
|
|
|
# Riven Example Proxy
|
|
|
|
|
2021-09-19 11:22:09 -07:00
|
|
|
This is a simple example implementation of a Riot API proxy server using
|
|
|
|
[`hyper`](https://github.com/hyperium/hyper). This adds the API key and
|
|
|
|
forwards requests to the Riot API, then returns and forwards responses back to
|
|
|
|
the requester.
|
|
|
|
|
|
|
|
This can handle not just GET endpoints but also POST and PUT (and any others)
|
|
|
|
with bodies, however it does not handle RSO endpoints which require an
|
|
|
|
`Authorization` header parameter. This handles errors but provides only minimal
|
|
|
|
failure information. Rate limits are enforced, so requests will wait to complete
|
|
|
|
when Riven is at the rate limit.
|
2020-06-05 01:51:25 -07:00
|
|
|
|
|
|
|
Set `RGAPI_KEY` env var then run:
|
|
|
|
```bash
|
|
|
|
export RGAPI_KEY=RGAPI-XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
|
2024-01-20 19:31:54 -08:00
|
|
|
cargo run --example proxy
|
2020-06-05 01:51:25 -07:00
|
|
|
```
|
|
|
|
|
|
|
|
Test in your browser or using `curl`. The first path segment specifies the region:
|
|
|
|
```json
|
|
|
|
$ curl http://localhost:3000/na1/lol/summoner/v4/summoners/by-name/LugnutsK
|
|
|
|
{"id":"...","accountId":"...","puuid":"...","name":"LugnutsK","profileIconId":4540,"revisionDate":1589704662000,"summonerLevel":111}
|
|
|
|
|
2021-09-09 14:31:39 -07:00
|
|
|
$ curl http://localhost:3000/eu/val/status/v1/platform-data
|
|
|
|
{"id": "EU", "name": "Europe", "locales": ["..."], "maintenances": [], "incidents": []}
|
|
|
|
|
2024-01-20 19:31:54 -08:00
|
|
|
$ curl http://localhost:3000/americas/lol/tournament-stub/v5/providers -H "Content-Type: application/json" -d '{"region":"JP","url":"https://github.com/MingweiSamuel/Riven"}'
|
|
|
|
1
|
2021-09-09 14:31:39 -07:00
|
|
|
|
|
|
|
$ curl http://localhost:3000/na1/unknown/endpoint
|
2020-06-05 01:51:25 -07:00
|
|
|
{"error":"Riot API endpoint method not found."}
|
|
|
|
```
|