-
Notifications
You must be signed in to change notification settings - Fork 3
ptServer
PT server je http server implementující REST API. Jeho účel je
- umožnit vzdálenou správu hJOPserveru,
- poskytnout rozhraní k řízení kolejiště pro studenty MENDELU.
S PT serverem se komunikuje ve formátu JSON. Veškerá dokumentace, jména endpointů, atributů a osttaně všeho jsou v češtině.
PT server je zakompilovaný v základní verzi hJOPserveru, avšak automaticky se nespouští. PT server nevyžaduje žádnou autentizaci, což by mělo být, vzhledem k vypnutému serveru by default, únosně bezpečné.
PT server umožňuje toto:
- dotazovat server na data a stav,
- bloků,
- hnacích vozidel,
- přestavít výhybku,
- řídit hnací vozidlo na základě adresy.
- Se serverem se komunikuje výhradně v kódování UTF-8.
- Server na každý požadavek vrací 200 OK.
- Defaultní port serveru je 5823.
- Chyby při zpracování požadavků jsou zaneseny do odpovědi jako
errors
objekt. Viz specifikace
Následující stránky obsahují specifikace objektů posílaných v požadavcích a odpovědích.
Kdykoliv je v GET parametru předáván argument typu Boolean
, může
parametr nabývat hodnot:
-
true
/false
v jakékoliv velikosti písmen (napr.tRue
je také validní), nebo -
0
/1
.
- Endpoint vrací bloky.
- Parametry:
-
stanice=id
– vrací jen bloky v dané stanici, -
typ=typ
– vrací jen bloky daného typu, -
stav=[Boolean]
– jestli vrátit s bloky i jejich stav.
{
"bloky": [
{...}, {...}, ...
]
}
- Endpoint vrací blok
id
. - Parametry:
-
stav=[Boolean]
– jestli vrátit s bloky i jejich stav.
{
"blok": {
...
}
}
- Endpoint vrací stav bloku
id
. - Parametry: žádné.
{
"blokStav": {
...
}
}
- Endpoint umožňuje změnit stav bloku
id
. - Odpovědí je nový stav bloku.
- Stav bloku měníme posláním nového kýženého stavu v těle požadavku.
{
"blokStav": {
"poloha": "-"
}
}
TODO: dodělat popis konkrétních požadavků
- Endpoint vrací seznam stanic.
- Parametry: žádné.
{
"stanice": [
{...}, {...}, ...
]
}
- Endpoint vrací stanici s id
id
. - Parametry: žádné.
{
"stanic": {
...
}
}
- Endpoint vrací seznam lokomotiv.
- Parametry:
-
aktivni=[Boolean]
– jestli vrátit jen aktivní lokomotivy. Pokud není argument přítomný, vrátí všechny loko, pokud je přítomný, vrátí jen aktivní/neaktivní. -
stav=[Boolean]
– jestli vrátit s lokomotivami i jejich stavy.
{
"loks": [
{...}, {...}, ...
]
}
- Endpoint vrací lokomotivu s adresou
addr
. - Parametry:
-
stav=[Boolean]
– jestli vrátit s lokomotivou i její stav.
{
"lok": {
...
}
}
- Endpoint vrací stav lokomotivy s adresou
addr
. - Parametry: žádné.
{
"lokStav": {
...
}
}
- Endpoint umožňuje změnit stav lokomotivy s adresou
addr
. - Odpovědí je nový stav lokomotivy.
- Stav lokomotivy měníme posláním nového kýženého stavu v těle požadavku.
- Kýžený stav se od aktuálního stavu může lišit ve více parametrech, server se v takovém případě pokusí udělat nejlepší možnou akci.
{
"lokStav": {
"rychlostStupne": 15
}
}
Akceptované atributy:
rychlostStupne
rychlostKmph
smer
stavFunkci
Atributy lze kombinovat. Pokud je zadáno rychlostStupne
i rychlostKmph
,
vybere se rychlostStupne
. rychlostKmph
je v takovém případě ignorováno.