Basic Station Search
This commit is contained in:
parent
ea6b426c3c
commit
5068c7a302
3 changed files with 77 additions and 0 deletions
27
flake.lock
generated
Normal file
27
flake.lock
generated
Normal file
|
|
@ -0,0 +1,27 @@
|
|||
{
|
||||
"nodes": {
|
||||
"nixpkgs": {
|
||||
"locked": {
|
||||
"lastModified": 1778003029,
|
||||
"narHash": "sha256-q/nkKLDtHIyLjZpKhWk3cSK5IYsFqtMd6UtXF3ddjgA=",
|
||||
"owner": "nixos",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "0c88e1f2bdb93d5999019e99cb0e61e1fe2af4c5",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "nixos",
|
||||
"ref": "nixos-25.11",
|
||||
"repo": "nixpkgs",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"root": {
|
||||
"inputs": {
|
||||
"nixpkgs": "nixpkgs"
|
||||
}
|
||||
}
|
||||
},
|
||||
"root": "root",
|
||||
"version": 7
|
||||
}
|
||||
23
flake.nix
Normal file
23
flake.nix
Normal file
|
|
@ -0,0 +1,23 @@
|
|||
{
|
||||
description = "Python env for HaFaS-Terminal-App";
|
||||
|
||||
inputs.nixpkgs.url = github:nixos/nixpkgs/nixos-25.11;
|
||||
|
||||
outputs = { self, nixpkgs, ... }: let
|
||||
system = "x86_64-linux";
|
||||
pkgs = import nixpkgs { inherit system; };
|
||||
nixPackages = with pkgs; with python313Packages; [
|
||||
requests
|
||||
prompt-toolkit
|
||||
];
|
||||
in {
|
||||
devShells."${system}".default = pkgs.mkShell {
|
||||
buildInputs = with pkgs; [
|
||||
python313
|
||||
] ++ nixPackages;
|
||||
shellHook = ''
|
||||
exec zsh || exec bash || true
|
||||
'';
|
||||
};
|
||||
};
|
||||
}
|
||||
27
main.py
27
main.py
|
|
@ -9,5 +9,32 @@ The application will provide routing information and station departures/arrivals
|
|||
|
||||
import requests
|
||||
import json
|
||||
from datetime import datetime
|
||||
from prompt_toolkit import Application
|
||||
from prompt_toolkit.completion import WordCompleter
|
||||
|
||||
def stationRequest(station):
|
||||
res = session.post("https://fahrplan.ivb.at/bin/mgate.exe",
|
||||
data=json.dumps({"svcReqL": [{"req": {"input": {"field": "S", "loc": {"name": station, "type": "S"}}}, "meth": "LocMatch"}], "client": {"id": "VAO", "name": "webapp", "type": "WEB"}, "ver": "1.32", "lang": "de", "auth": {"type": "AID", "aid": "wf7mcf9bv3nv8g5f"}}),
|
||||
headers={'User-Agent': "IOS",'Content-Type': 'application/json'})
|
||||
return json.loads(res.text)
|
||||
|
||||
def departuresRequest(station):
|
||||
time = datetime.now()
|
||||
res = session.post("https://fahrplan.ivb.at/bin/mgate.exe",
|
||||
data=json.dumps({"svcReqL": [{"req": {"type": "DEP", "stbLoc": {"lid": f"A=1@L={station}@"}, "dirLoc": None, "maxJny": 1, "date": time.strftime("%Y%M%D"), "time": time.strftime("%H%M%S"), "dur": -1, "jnyFltrL": [{"type": "PROD", "mode": "INC", "value": "4087"}]}, "meth": "StationBoard"}], "client": {"id": "VAO", "name": "webapp", "type": "WEB"}, "ver": "1.32", "lang": "de", "auth": {"type": "AID", "aid": "wf7mcf9bv3nv8g5f"}}),
|
||||
headers={'User-Agent': "IOS",'Content-Type': 'application/json'})
|
||||
return json.loads(res.text)
|
||||
|
||||
def tripRequest(departure):
|
||||
res = session.post("https://fahrplan.ivb.at/bin/mgate.exe",
|
||||
data = json.dumps({"svcReqL": [{"req": {"jid": departure}, "meth": "JourneyDetails"}], "client": {"id": "VAO", "name": "webapp", "type": "WEB"}, "ver": "1.32", "lang": "de", "auth": {"type": "AID", "aid": "wf7mcf9bv3nv8g5f"}}),
|
||||
headers={'User-Agent': "IOS",'Content-Type': 'application/json'})
|
||||
return json.loads(res.text)
|
||||
|
||||
if __name__ == '__main__':
|
||||
session = requests.session()
|
||||
station = input("Enter Station Name: ")
|
||||
streq = stationRequest(station)
|
||||
bestFoundStation = streq["svcResL"][0]["res"]["match"]["locL"][0]
|
||||
print(bestFoundStation)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue