Improve handling and allow for exclusion of hostname
This allows for the removal of "https://twitter.com/" This could be more convinent as you simply replace "twitter.com" with twtfix.me in the url, removing having to type http:// each time also added additional error handling just to avoid messy 500 errors.
This commit is contained in:
parent
80ed4bfa16
commit
5ac4879f02
1 changed files with 16 additions and 6 deletions
22
twitfix.py
22
twitfix.py
|
@ -1,20 +1,30 @@
|
|||
from flask import Flask, render_template, url_for, request, redirect
|
||||
from datetime import datetime
|
||||
import youtube_dl
|
||||
import requests
|
||||
import psutil
|
||||
import os
|
||||
import re
|
||||
|
||||
ydl = youtube_dl.YoutubeDL({'outtmpl': '%(id)s.%(ext)s'})
|
||||
app = Flask(__name__)
|
||||
pathregex = re.compile("\\w{1,15}\\/status\\/\\d{19}")
|
||||
|
||||
@app.route('/<path:subpath>')
|
||||
def twitfix(subpath):
|
||||
if subpath.startswith('https://twitter.com'):
|
||||
with ydl:
|
||||
result = ydl.extract_info(subpath, download=False)
|
||||
|
||||
return render_template('index.html', vidurl=result['url'], tweet=result['description'], pic=result['thumbnail'], user=result['uploader'], tweeturl=subpath)
|
||||
match = pathregex.search(subpath)
|
||||
if match is not None:
|
||||
twitter_url = subpath
|
||||
|
||||
if match.start() == 0:
|
||||
twitter_url = "https://twitter.com/" + subpath
|
||||
|
||||
with ydl:
|
||||
try:
|
||||
result = ydl.extract_info(twitter_url, download=False)
|
||||
except Exception: # Just to keep from 500s that are messy
|
||||
return "Bad twitter link, try again"
|
||||
|
||||
return render_template('index.html', vidurl=result['url'], tweet=result['description'], pic=result['thumbnail'], user=result['uploader'], tweeturl=twitter_url)
|
||||
else:
|
||||
return "Please use a twitter link"
|
||||
|
||||
|
|
Loading…
Reference in a new issue