Random Operator with Large Latency
This shield 👇 indicates if API is working today:
Last 30 days:
Did you ever want to get a random number? But like, really random
Roll-API is here to help! When you ask it for random number, it shakes the real, physical dice 🎲 inside a special box, then takes a picture of it 📷, analyzes how many dots it has 👁️, and gives you the result!
For normies, there is a nice web-app 📱 written in Flutter HTML+Dart - https://the.lastgimbus.com/rollplay/ -
you can use it on your phone, for example, when playing board games when you can't find a dice 👍
For terminal people there is a CLI ⌨️ written in Dart - https://github.com/TheLastGimbus/rollapi_dart#cli
Whole API lives under https://roll.lastgimbus.com/api/
(NOTE: All uuid's below are purely example - use your own, that you will get from roll/
)
-
Make a request to
roll/
:$ curl https://roll.lastgimbus.com/api/roll/ 7a1da923-0622-4848-b224-973f1b6c74f0
It gives you a UUID of your request - you will use that to check if your roll is ready and what number was drawn
-
Make request to
info/<uuid>/
orresult/<uuid>/
:-
result/
gives you purely the result - this is useful when making some bash scripts 📜$ curl https://roll.lastgimbus.com/api/result/7a1da923-0622-4848-b224-973f1b6c74f0/ 6
Response text, code:
- <number>, 200 - here is your random number 🎉
- "QUEUED", 202 - your request is waiting in the queue with other requests - it may take some time ⌛
- "RUNNING", 201 - your request is being rolled right now - wait 5 seconds, and it will be ready 🔥
- "EXPIRED", 410 - your request has been sitting too long, and it's results don't exist anymore 😕 - make a new one 👍
- "FAILED", 500 - something failed inside the RollER - maybe dice was moving, idk 🤷 - make a new request, and it should work 👍
-
info/
gives you a JSON with more info:$ curl https://roll.lastgimbus.com/api/info/7a1da923-0622-4848-b224-973f1b6c74f0/ { # Estimated-time-arrival - estimated timestamp when result will be available "eta": 1618160853.0, # How many requests are before yours in queue "queue": 0, # Your result - is null when not finished yet or expired "result": 6, # Same statuses as with "result/", except it's "FINISHED" instead of a number "status": "FINISHED", # Timestamp when results expire - "-1.0" when waiting in queue, "0.0" when expired or failed "ttl": 1618160343.0 }
(
info/
always returns a 200 status code 👀)
-
-
If you are curious how your dice looks - you can request the original image with
image/<uuid>/
📷$ curl https://roll.lastgimbus.com/api/image/7a1da923-0622-4848-b224-973f1b6c74f0/ > full-image.jpg $ ls full-image.jpg
You can also get image from CV analysis (in grayscale, cropped, and with marked detected dots) - at
anal-image/<uuid>/
:$ curl https://roll.lastgimbus.com/api/anal-image/7a1da923-0622-4848-b224-973f1b6c74f0/ > anal-image.jpg $ ls anal-image.jpg
If the request is not finished, it will return same responses as
result/
Your results will be available for 5 minutes when finished. After that, you fill get "EXPIRED" messages, and you need to make a new request.
If you want details about how I built it - and how you can do it too - look at DIY.md
- My friend @amMooncake made this sweet purple-ish icon - you can check his other graphics out: Instagram, Dribble
- The RollER machine was heavily inspired by @markfickett's D20 Roll Fairness project