Respond with error code
This commit is contained in:
21
main.py
21
main.py
@ -1,9 +1,12 @@
|
|||||||
"""Website for uploading files and creating .HTMLs and thumbnails so we can embed files in Discord.
|
"""Website for uploading files, creating .HTMLs, and thumbnails.
|
||||||
|
|
||||||
|
This was created for Discord. You can use this to embed videos in Discord.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
from typing import Dict
|
||||||
|
|
||||||
import ffmpeg
|
import ffmpeg
|
||||||
from fastapi import FastAPI, File, UploadFile
|
from fastapi import FastAPI, File, UploadFile
|
||||||
@ -28,17 +31,17 @@ app = FastAPI(
|
|||||||
|
|
||||||
|
|
||||||
@app.post("/uploadfiles/")
|
@app.post("/uploadfiles/")
|
||||||
async def upload_file(file: UploadFile = File(...)):
|
async def upload_file(file: UploadFile = File(...)) -> Dict[str, str]:
|
||||||
"""Page for uploading files.
|
"""Page for uploading files.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
file (UploadFile): Our uploaded file. Defaults to File(...).
|
file (UploadFile): Our uploaded file. Defaults to File(...).
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
HTMLResponse: Returns HTML for site.
|
Dict[str, str]: Returns a dict with the filename or a link to the .html if it was a video.
|
||||||
"""
|
"""
|
||||||
# TODO: Add syntax highlighting for text.
|
# TODO: Add syntax highlighting for text.
|
||||||
|
try:
|
||||||
# Make custom html for video files.
|
# Make custom html for video files.
|
||||||
if file.content_type.startswith("video/"):
|
if file.content_type.startswith("video/"):
|
||||||
# Create folder if it doesn't exist.
|
# Create folder if it doesn't exist.
|
||||||
@ -62,6 +65,10 @@ async def upload_file(file: UploadFile = File(...)):
|
|||||||
file_object.write(file.file.read())
|
file_object.write(file.file.read())
|
||||||
|
|
||||||
return {"html_url": f"{Settings.domain}/{file.filename}"}
|
return {"html_url": f"{Settings.domain}/{file.filename}"}
|
||||||
|
except Exception as e:
|
||||||
|
# TODO: Change response code to 400.
|
||||||
|
print(e)
|
||||||
|
return {"error": f"Something went wrong: {e}"}
|
||||||
|
|
||||||
|
|
||||||
@app.get("/", response_class=HTMLResponse)
|
@app.get("/", response_class=HTMLResponse)
|
||||||
@ -104,9 +111,9 @@ def generate_html(url: str, width: int, height: int, screenshot: str, filename:
|
|||||||
|
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
url (str): URL for video.
|
url (str): URL for the video. This is accessible from the browser.
|
||||||
width (int): Video width.
|
width (int): This is the width of the video.
|
||||||
height (int): Video height.
|
height (int): This is the height of the video.
|
||||||
screenshot (str): URL for screenshot. This is what you will see in Discord.
|
screenshot (str): URL for screenshot. This is what you will see in Discord.
|
||||||
filename (str): Original video filename. We will append .html to the filename.
|
filename (str): Original video filename. We will append .html to the filename.
|
||||||
|
|
||||||
|
@ -6,8 +6,8 @@ from dotenv import load_dotenv
|
|||||||
|
|
||||||
class Settings:
|
class Settings:
|
||||||
description = (
|
description = (
|
||||||
"Discord will only create embeds for videos and images if they are smaller than 8mb. We can 'abuse' this"
|
"Discord will only create embeds for videos and images if they are smaller than 8 mb. We can 'abuse' this"
|
||||||
" by using the 'twitter:image' HTML meta tag."
|
" by creating a .html that contains the 'twitter:player' HTML meta tag linking to the video."
|
||||||
)
|
)
|
||||||
# Load environment variables
|
# Load environment variables
|
||||||
load_dotenv()
|
load_dotenv()
|
||||||
|
Reference in New Issue
Block a user