|
from fastapi import FastAPI, File, UploadFile,Body |
|
from fastapi.staticfiles import StaticFiles |
|
from fastapi.responses import FileResponse |
|
from PIL import Image |
|
import numpy as np |
|
import urllib.request |
|
import io |
|
import os |
|
from moviepyTest import test |
|
from typing import * |
|
from fastapi.responses import PlainTextResponse |
|
import subprocess |
|
from fastapi import BackgroundTasks |
|
import time |
|
from bilibili_api import sync, video_uploader, Credential |
|
import asyncio |
|
|
|
|
|
sessdata = os.getenv('sessdata') |
|
bili_jct = os.getenv('bili_jct') |
|
buvid3 = os.getenv('buvid3') |
|
app = FastAPI() |
|
|
|
|
|
@app.get("/inference") |
|
def inference(): |
|
return "<p>Hello, World!</p>" |
|
|
|
@app.get("/infer_t5") |
|
def t5(input): |
|
|
|
return {"output": input} |
|
|
|
@app.get("/moviepyTest") |
|
def t5(): |
|
result = test() |
|
|
|
return {"output": result} |
|
|
|
|
|
|
|
|
|
@app.post("/getOriginalMangaList") |
|
def getOriginalMangaList(images: List[UploadFile] = File(...), save_path: str = "/manga"): |
|
saved_files = [] |
|
for idx, image in enumerate(images): |
|
img = image.file.read() |
|
image_data = Image.open(io.BytesIO(img)).convert("L").convert("RGB") |
|
path_to_image = os.path.join(save_path, f"{idx}.jpg") |
|
image_data.save(path_to_image) |
|
saved_files.append(path_to_image) |
|
return {"message": "Images saved successfully", "saved_files": saved_files} |
|
|
|
|
|
|
|
@app.delete("/deleteFiles") |
|
async def delete_files(directory: str): |
|
for filename in os.listdir(directory): |
|
file_path = os.path.join(directory, filename) |
|
if os.path.isfile(file_path): |
|
os.remove(file_path) |
|
return {"message": f"成功删除{directory}目录下的所有文件"} |
|
|
|
|
|
|
|
|
|
|
|
|
|
def file_executer(file_name:str)->"执行返回": |
|
try: |
|
print("开始执行py任务",file_name) |
|
|
|
|
|
|
|
output = [] |
|
process = subprocess.Popen(["python", f"{file_name}.py"], stdout=subprocess.PIPE, stderr=subprocess.STDOUT) |
|
|
|
for line in iter(process.stdout.readline, b''): |
|
line_text = line.decode('utf-8').strip() |
|
print(line_text) |
|
output.append(line_text) |
|
process.wait() |
|
result = '\n'.join(output) |
|
|
|
|
|
print("执行完成py任务:",file_name,"结果如下") |
|
print(result) |
|
return PlainTextResponse(result) |
|
except subprocess.CalledProcessError as e: |
|
print("执行py任务失败",file_name,"原因如下") |
|
print(f"Error executing {file_name}.py: {e}") |
|
return PlainTextResponse(f"Error executing {file_name}.py: {e}") |
|
|
|
@app.get("/execute_py_file/{file_name}") |
|
async def execute_py_file(file_name: str,background_tasks: BackgroundTasks): |
|
result = "接受到了请求{filename}任务".format(filename = file_name) |
|
background_tasks.add_task(file_executer,file_name) |
|
return result |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.get("/execute_all_task") |
|
async def execute_all_task(background_tasks: BackgroundTasks, file_list: list = ["1removeMask", "2magiDialogCut", "3mergeDialogToVideo"], |
|
bili_meta_data: dict = None, cover_image: UploadFile = File(...), mp4_out_file: str = 'mp4_out/output.mp4', |
|
allow_submit: bool = False, cover_path: str = '/cover' |
|
): |
|
tasks = [] |
|
for file_name in file_list: |
|
tasks.append(file_executer(file_name)) |
|
|
|
await asyncio.gather(*tasks) |
|
|
|
if allow_submit: |
|
cover_img = cover_image.file.read() |
|
cover_img_data = Image.open(io.BytesIO(cover_img)).convert("L").convert("RGB") |
|
cover_path_to_image = os.path.join(cover_path, f"cover.jpg") |
|
cover_img_data.save(cover_path_to_image) |
|
background_tasks.add_task(upload_video, bili_meta_data, cover_path_to_image) |
|
return {"message": "提交video任务已加入队列"} |
|
|
|
return {"message": "Tasks added to the queue"} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def someTask(): |
|
time.sleep(20) |
|
print("睡眠20s结束") |
|
|
|
@app.get("/backTaskTest") |
|
def returnRandomSubscribeUrl(background_tasks: BackgroundTasks)->str: |
|
|
|
result = "先返回" |
|
background_tasks.add_task(someTask) |
|
return result |
|
|
|
|
|
|
|
|
|
|
|
|
|
async def upload_video(meta:dict,cover_path_to_image:str): |
|
credential = Credential(sessdata=sessdata, |
|
bili_jct=bili_jct, |
|
buvid3=buvid3) |
|
|
|
|
|
page = video_uploader.VideoUploaderPage(path='mp4_out/output_video.mp4', title=meta['title'], description=meta['desc']) |
|
|
|
uploader = video_uploader.VideoUploader([page], meta, credential, cover=cover_path_to_image) |
|
|
|
@uploader.on("__ALL__") |
|
async def ev(data): |
|
print(data) |
|
|
|
await uploader.start() |
|
|
|
|