Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Query Linz public transport stops for IDs and fetch live upcoming departures using Linz Linien EFA endpoints.
Query Linz public transport stops for IDs and fetch live upcoming departures using Linz Linien EFA endpoints.
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
Use this skill to interact with Linz Linien EFA endpoints: GET /efa/XML_STOPFINDER_REQUEST GET /efa/XML_DM_REQUEST Read endpoint details in {baseDir}/references/endpoints.md before implementation. Use {baseDir}/scripts/linz_transport.py as the default execution path.
Resolve the API base URL. Run the script subcommand that matches the task. Return a compact, user-facing summary.
Script path: {baseDir}/scripts/linz_transport.py Runtime: Python 3, standard library only. Base URL input: --base-url <url> argument, or LINZ_TRANSPORT_API_BASE_URL environment variable, or default http://www.linzag.at/linz2. Preferred commands: Search stops: python {baseDir}/scripts/linz_transport.py stops "taubenmarkt" Fetch departures by stop ID: python {baseDir}/scripts/linz_transport.py departures --stop-id 60501160 --limit 10 Resolve stop and fetch departures in one call: python {baseDir}/scripts/linz_transport.py next "taubenmarkt" --limit 10 --pick-first
Use user-provided base URL first. Otherwise use LINZ_TRANSPORT_API_BASE_URL if available. If neither exists, use http://www.linzag.at/linz2.
Sort by countdownInMinutes ascending if needed. Show the next 5-10 departures unless user asks for more. Include both relative (countdownInMinutes) and absolute (time) times. Keep field names stable when returning JSON.
If stop search returns empty list, suggest nearby spellings and retry with a shorter query token. If multiple stop matches are returned, rerun with explicit --stop-id or use next ... --pick-first only when ambiguity is acceptable. If departures response is empty, state that no upcoming departures are currently available. If HTTP request fails, report status code, endpoint, and retry guidance. If EFA response includes a message code, include that code in diagnostics.
python {baseDir}/scripts/linz_transport.py stops "taubenmarkt" python {baseDir}/scripts/linz_transport.py departures --stop-id 60501160 --limit 10 python {baseDir}/scripts/linz_transport.py next "taubenmarkt" --limit 10 --pick-first python "{baseDir}/scripts/linz_transport.py" stops "taubenmarkt" python "{baseDir}/scripts/linz_transport.py" departures --stop-id 60501160 --limit 10 python "{baseDir}/scripts/linz_transport.py" next "taubenmarkt" --limit 10 --pick-first
Data access, storage, extraction, analysis, reporting, and insight generation.
Largest current source with strong distribution and engagement signals.