Compare commits
	
		
			1 Commits
		
	
	
		
			master
			...
			4eca30edc1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4eca30edc1 | 
| @@ -15,7 +15,7 @@ jobs: | ||||
|     container: catthehacker/ubuntu:act-latest | ||||
|     strategy: | ||||
|       matrix: | ||||
|         python-version: ["3.9", "3.10", "3.11", "3.12"] | ||||
|         python-version: ["3.8", "3.9", "3.10", "3.11", "3.12"] | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v3 | ||||
|   | ||||
| @@ -3,15 +3,6 @@ | ||||
|     "extends": [ | ||||
|         "config:base" | ||||
|     ], | ||||
|     "baseBranches": [ | ||||
|         "dev" | ||||
|     ], | ||||
|     "pip_requirements": { | ||||
|         "fileMatch": [ | ||||
|             "requirements/.*\\.txt$" | ||||
|         ], | ||||
|         "enabled": true | ||||
|     }, | ||||
|     "packageRules": [ | ||||
|         { | ||||
|             "matchUpdateTypes": [ | ||||
|   | ||||
| @@ -10,7 +10,7 @@ Small module that makes your journey with RMV REST API somehow easier. Based ful | ||||
| ## Requirements | ||||
|  | ||||
| * RMV API key (Get it [here](https://opendata.rmv.de/site/start.html)) | ||||
| * Python 3.9+ | ||||
| * Python 3.8+ | ||||
| * git (Only for installation from source) | ||||
|  | ||||
| ## Installation | ||||
|   | ||||
| @@ -9,7 +9,7 @@ authors = [{ name = "Profitroll", email = "profitroll@end-play.xyz" }] | ||||
| maintainers = [{ name = "Profitroll", email = "profitroll@end-play.xyz" }] | ||||
| description = "Small module that makes your journey with RMV REST API somehow easier." | ||||
| readme = "README.md" | ||||
| requires-python = ">=3.9" | ||||
| requires-python = ">=3.8" | ||||
| license = { text = "MIT" } | ||||
| classifiers = [ | ||||
|     "Development Status :: 3 - Alpha", | ||||
| @@ -17,6 +17,7 @@ classifiers = [ | ||||
|     "License :: OSI Approved :: MIT License", | ||||
|     "Operating System :: OS Independent", | ||||
|     "Programming Language :: Python :: 3", | ||||
|     "Programming Language :: Python :: 3.8", | ||||
|     "Programming Language :: Python :: 3.9", | ||||
|     "Programming Language :: Python :: 3.10", | ||||
|     "Programming Language :: Python :: 3.11", | ||||
| @@ -45,7 +46,7 @@ speed = { file = "requirements/speed.txt" } | ||||
| where = ["src"] | ||||
|  | ||||
| [tool.black] | ||||
| target-version = ['py39', 'py310', 'py311', 'py312'] | ||||
| target-version = ['py38', 'py39', 'py310', 'py311', 'py312'] | ||||
| line-length = 94 | ||||
|  | ||||
| [tool.isort] | ||||
| @@ -65,7 +66,7 @@ show_error_codes = true | ||||
|  | ||||
| [tool.pylint.main] | ||||
| extension-pkg-whitelist = ["ujson"] | ||||
| py-version = 3.9 | ||||
| py-version = 3.8 | ||||
|  | ||||
| [tool.coverage.run] | ||||
| source = ["pyrmv"] | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| requests~=2.32.3 | ||||
| xmltodict~=0.14.0 | ||||
| isodate~=0.7.0 | ||||
| xmltodict~=0.13.0 | ||||
| isodate~=0.6.1 | ||||
| @@ -1,10 +1,10 @@ | ||||
| black~=25.1.0 | ||||
| black~=24.8.0 | ||||
| isort==5.13.2 | ||||
| mypy~=1.15.0 | ||||
| pylint==3.3.7,<3.4.0 | ||||
| pytest-cov~=6.1.0 | ||||
| mypy~=1.11.2 | ||||
| pylint==3.2.7 | ||||
| pytest-cov~=5.0.0 | ||||
| pytest~=8.3.2 | ||||
| tox==4.25.0 | ||||
| tox==4.19.0 | ||||
| types-ujson~=5.10.0.20240515 | ||||
|  | ||||
| # Disabled async libraries for now | ||||
|   | ||||
| @@ -1,2 +1,2 @@ | ||||
| build==1.2.2.post1 | ||||
| twine~=6.1.0 | ||||
| build==1.2.2 | ||||
| twine~=5.1.1 | ||||
|   | ||||
| @@ -21,7 +21,7 @@ trip = client.trip_find(origin_id=origin.id, dest_id=destination.id) | ||||
| """ | ||||
|  | ||||
| __name__ = "pyrmv" | ||||
| __version__ = "0.5.0" | ||||
| __version__ = "0.4.0" | ||||
| __license__ = "MIT License" | ||||
| __author__ = "Profitroll" | ||||
|  | ||||
|   | ||||
| @@ -150,7 +150,7 @@ class Client: | ||||
|             boardType=board_type.code, | ||||
|         ) | ||||
|  | ||||
|         find_exception(board_raw.copy()) | ||||
|         find_exception(board_raw) | ||||
|  | ||||
|         return BoardArrival( | ||||
|             board_raw, | ||||
| @@ -219,7 +219,7 @@ class Client: | ||||
|             boardType=board_type.code, | ||||
|         ) | ||||
|  | ||||
|         find_exception(board_raw.copy()) | ||||
|         find_exception(board_raw) | ||||
|  | ||||
|         return BoardDeparture( | ||||
|             board_raw, | ||||
| @@ -343,7 +343,7 @@ class Client: | ||||
|             minprio=priority_min, | ||||
|         ) | ||||
|  | ||||
|         find_exception(messages_raw.copy()) | ||||
|         find_exception(messages_raw) | ||||
|  | ||||
|         if "Message" in messages_raw: | ||||
|             messages.extend(Message(message) for message in messages_raw["Message"]) | ||||
| @@ -402,7 +402,7 @@ class Client: | ||||
|             toIdx=to_index, | ||||
|         ) | ||||
|  | ||||
|         find_exception(journey_raw.copy()) | ||||
|         find_exception(journey_raw) | ||||
|  | ||||
|         return Journey(journey_raw) | ||||
|  | ||||
| @@ -481,7 +481,7 @@ class Client: | ||||
|             locationSelectionMode=selection_mode,  # type: ignore | ||||
|         ) | ||||
|  | ||||
|         find_exception(stops_raw.copy()) | ||||
|         find_exception(stops_raw) | ||||
|  | ||||
|         if "stopLocationOrCoordLocation" in stops_raw: | ||||
|             for stop in stops_raw["stopLocationOrCoordLocation"]: | ||||
| @@ -536,7 +536,7 @@ class Client: | ||||
|             accessId=self.access_id, inputString=query, lang=lang.code, maxNo=1 | ||||
|         ) | ||||
|  | ||||
|         find_exception(stops_raw.copy()) | ||||
|         find_exception(stops_raw) | ||||
|  | ||||
|         if len(stops_raw["stopLocationOrCoordLocation"]) <= 0: | ||||
|             return None | ||||
| @@ -642,7 +642,7 @@ class Client: | ||||
|             filterMode=filter_mode.code, | ||||
|         ) | ||||
|  | ||||
|         find_exception(stops_raw.copy()) | ||||
|         find_exception(stops_raw) | ||||
|  | ||||
|         if "stopLocationOrCoordLocation" in stops_raw: | ||||
|             for stop in stops_raw["stopLocationOrCoordLocation"]: | ||||
| @@ -833,7 +833,7 @@ class Client: | ||||
|             withFreq=frequency, | ||||
|         ) | ||||
|  | ||||
|         find_exception(trips_raw.copy()) | ||||
|         find_exception(trips_raw) | ||||
|  | ||||
|         if "Trip" in trips_raw: | ||||
|             trips.extend(Trip(trip) for trip in trips_raw["Trip"]) | ||||
| @@ -913,7 +913,7 @@ class Client: | ||||
|             trafficMessages=messages, | ||||
|         ) | ||||
|  | ||||
|         find_exception(trips_raw.copy()) | ||||
|         find_exception(trips_raw) | ||||
|  | ||||
|         if "Trip" in trips_raw: | ||||
|             trips.extend(Trip(trip) for trip in trips_raw["Trip"]) | ||||
|   | ||||
| @@ -59,9 +59,9 @@ class Message: | ||||
|         self.channels.extend(Channel(channel) for channel in data["channel"]) | ||||
|         self.id: str = data["id"] | ||||
|         self.active: bool = data["act"] | ||||
|         self.head: str = "" if "head" not in data else data["head"] | ||||
|         self.lead: str = "" if "lead" not in data else data["lead"] | ||||
|         self.text: str = "" if "text" not in data else data["text"] | ||||
|         self.head: str = data["head"] | ||||
|         self.lead: str = data["lead"] | ||||
|         self.text: str = data["text"] | ||||
|         self.company: Union[str, None] = data.get("company") | ||||
|         self.category: Union[str, None] = data.get("category") | ||||
|         self.priority: Union[int, None] = data.get("priority") | ||||
| @@ -81,10 +81,8 @@ class Message: | ||||
|                 f"{data['validToDate']} {data['validToTime']}", "%Y-%m-%d %H:%M:%S" | ||||
|             ) | ||||
|         ) | ||||
|         self.date_start_alt: Union[str, None] = ( | ||||
|             None if "altStart" not in data else data["altStart"] | ||||
|         ) | ||||
|         self.date_end_alt: Union[str, None] = None if "altEnd" not in data else data["altEnd"] | ||||
|         self.date_start_alt: str = data["altStart"] | ||||
|         self.date_end_alt: str = data["altEnd"] | ||||
|         self.time_modified: Union[datetime, None] = ( | ||||
|             None | ||||
|             if "modDate" not in data or "modTime" not in data | ||||
|   | ||||
| @@ -19,10 +19,8 @@ class Trip: | ||||
|         self.index: int = data["idx"] | ||||
|         self.id: str = data["tripId"] | ||||
|         self.ctx_recon: str = data["ctxRecon"] | ||||
|         self.duration: Union[Duration, timedelta, None] = ( | ||||
|             None if "duration" not in data else parse_duration(data["duration"]) | ||||
|         ) | ||||
|         self.real_time_duration: Union[Duration, timedelta, None] = ( | ||||
|         self.duration: Union[Duration, timedelta] = parse_duration(data["duration"]) | ||||
|         self.real_time_duration: Union[Duration, timedelta] = ( | ||||
|             None if "rtDuration" not in data else parse_duration(data["rtDuration"]) | ||||
|         ) | ||||
|         self.checksum: str = data["checksum"] | ||||
|   | ||||
| @@ -64,7 +64,7 @@ def board_arrival( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "date": | ||||
|             if val != None: | ||||
|                 if isinstance(val, datetime): | ||||
|   | ||||
| @@ -65,7 +65,7 @@ def board_departure( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "date": | ||||
|             if val != None: | ||||
|                 if isinstance(val, datetime): | ||||
|   | ||||
| @@ -97,7 +97,7 @@ def him_search( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) in {"dateB", "dateE"}: | ||||
|             if val != None: | ||||
|                 if isinstance(val, datetime): | ||||
|   | ||||
| @@ -55,7 +55,7 @@ def journey_detail( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "rtMode": | ||||
|             if val != None: | ||||
|                 payload["rtMode"] = val.upper() | ||||
|   | ||||
| @@ -54,7 +54,7 @@ def stop_by_coords( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "stopType": | ||||
|             if val != None: | ||||
|                 payload["type"] = val.upper() | ||||
|   | ||||
| @@ -65,7 +65,7 @@ def stop_by_name( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "inputString": | ||||
|             if val != None: | ||||
|                 payload["input"] = val | ||||
|   | ||||
| @@ -201,7 +201,7 @@ def trip_find( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "date": | ||||
|             if val != None: | ||||
|                 if isinstance(val, datetime): | ||||
|   | ||||
| @@ -87,7 +87,7 @@ def trip_recon( | ||||
|     payload = {} | ||||
|     headers = {"Accept": "application/json"} if json else {"Accept": "application/xml"} | ||||
|  | ||||
|     for var, val in locals().copy().items(): | ||||
|     for var, val in locals().items(): | ||||
|         if str(var) == "date": | ||||
|             if val != None: | ||||
|                 if isinstance(val, datetime): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user