This commit is contained in:
mdeboute 2022-04-28 12:03:51 +02:00
parent 0eedc2a638
commit b69be7c05e
14 changed files with 107 additions and 72 deletions

5
.gitignore vendored
View File

@ -4,4 +4,7 @@ __pycache__/
# Poetry venv directories and files
.venv/
poetry.lock
poetry.lock
# Keys and tokens of the Twitter API
credentials.py

View File

@ -1,11 +1 @@
# What's this?
This is a set of libraries to gather data from TBM.
## What's TBM?
TBM is a french compagny that operates Bordeaux's public transportation.
## Licence
These libraries are under GNU GPL v3. See [license](LICENSE) for more details.
# info_tbm

BIN
assets/pp.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

BIN
assets/tram.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

27
main.py
View File

@ -1,27 +0,0 @@
from src.stop import *
import sys
from datetime import datetime
from gmplot import gmplot
if __name__ == "__main__":
for word in sys.argv[1:]:
for area in search_stop_by_name(word):
for stop in show_stops_from_ref(area["ref"])["stop_points"]:
for route in stop["routes"]:
if "Tram" in route["line_human"]:
sr = StopRoute(stop["id"], route["line_id"])
line = sr.get_line()
v = line.get_vehicle(0)
if v.is_realtime:
print(
str(v.wait_time_text)
+ " ("
+ datetime.fromtimestamp(v.arrival).strftime("%H:%M")
+ ") → "
+ v.destination
+ " "
+ str(v.location)
)
gmap = gmplot.GoogleMapPlotter(v.location[0], v.location[1], 13)
gmap.marker(v.location[0], v.location[1], "cornflowerblue")
gmap.draw("map.html")

View File

@ -1,31 +0,0 @@
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<meta http-equiv="content-type" content="text/html; charset=UTF-8" />
<title>Google Maps - gmplot</title>
<script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?libraries=visualization"></script>
<script type="text/javascript">
function initialize() {
var map = new google.maps.Map(document.getElementById("map_canvas"), {
zoom: 13,
center: new google.maps.LatLng(44.828156, -0.574932)
});
var marker_icon_6495ED = {
url: "",
labelOrigin: new google.maps.Point(10, 11)
};
new google.maps.Marker({
position: new google.maps.LatLng(44.828156, -0.574932),
icon: marker_icon_6495ED,
map: map
});
}
</script>
</head>
<body style="margin:0px; padding:0px;" onload="initialize()">
<div id="map_canvas" style="width: 100%; height: 100%;" />
</body>
</html>

View File

@ -7,6 +7,7 @@ authors = ["mdeboute <martin.deboute@gmail.com>"]
[tool.poetry.dependencies]
python = "^3.9"
gmplot = "^1.4.1"
tweepy = "^4.8.0"
[tool.poetry.dev-dependencies]

37
src/autoreply.py Normal file
View File

@ -0,0 +1,37 @@
import tweepy
from config import *
import time
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger()
def check_mentions(api, keywords, since_id):
logger.info("Retrieving mentions")
new_since_id = since_id
for tweet in tweepy.Cursor(api.mentions_timeline, since_id=since_id).items():
new_since_id = max(tweet.id, new_since_id)
if tweet.in_reply_to_status_id is not None:
continue
if any(keyword in tweet.text.lower() for keyword in keywords):
logger.info(f"Answering to {tweet.user.name}")
api.update_status(
status="Please reach us via DM",
in_reply_to_status_id=tweet.id,
auto_populate_reply_metadata=True,
)
return new_since_id
def main():
api = create_api()
since_id = 1
while True:
since_id = check_mentions(api, ["help", "support"], since_id)
logger.info("Waiting...")
time.sleep(10)
if __name__ == "__main__":
main()

19
src/config.py Normal file
View File

@ -0,0 +1,19 @@
import tweepy
import logging
from credentials import *
logger = logging.getLogger()
def create_api():
auth = tweepy.OAuthHandler(CONSUMER_KEY, CONSUMER_SECRET)
auth.set_access_token(ACCESS_TOKEN, ACCESS_TOKEN_SECRET)
api = tweepy.API(auth, wait_on_rate_limit=True)
try:
api.verify_credentials()
except Exception as e:
logger.error("Error creating API", exc_info=True)
raise e
logger.info("API created")
return api

43
src/main.py Normal file
View File

@ -0,0 +1,43 @@
from tbm_api_lib.stop import *
import sys
from datetime import datetime
from gmplot import gmplot
if __name__ == "__main__":
for word in sys.argv[1:]:
for area in search_stop_by_name(word):
for stop in show_stops_from_ref(area["ref"])["stop_points"]:
for route in stop["routes"]:
if "Tram" in route["line_human"]:
sr = StopRoute(stop["id"], route["line_id"])
line = sr.get_line()
for vehicule in line.vehicles():
v = line.get_vehicle(vehicule)
if v.is_realtime:
print(
str(v.wait_time_text)
+ " ("
+ datetime.fromtimestamp(v.arrival).strftime(
"%H:%M"
)
+ ") → "
+ v.destination
+ " "
+ str(v.location)
)
else:
print(
"~"
+ str(v.wait_time_text)
+ " ("
+ datetime.fromtimestamp(v.arrival).strftime(
"%H:%M"
)
+ ") → "
+ v.destination
+ " "
+ str(v.location)
)
# gmap = gmplot.GoogleMapPlotter(v.location[0], v.location[1], 13)
# gmap.marker(v.location[0], v.location[1], "cornflowerblue")
# gmap.draw("map.html")

View File

@ -2,7 +2,7 @@
Provides stop information
"""
from src.libs import get_data_from_json, hms2seconds
from tbm_api_lib.libs import get_data_from_json, hms2seconds
from time import time
from urllib.parse import quote
from re import search

View File

@ -2,7 +2,7 @@
Provides all info about stations
"""
from src.libs import get_data_from_json
from tbm_api_lib.libs import get_data_from_json
from time import time
vcub_url = "https://ws.infotbm.com/ws/1.0/vcubs"

View File