2023-08-14 14:07:15 +00:00
|
|
|
import time
|
|
|
|
|
|
|
|
start_time = time.time()
|
|
|
|
|
2023-10-25 09:14:33 +00:00
|
|
|
import setuptools # avoid warnings
|
2023-05-06 12:17:39 +00:00
|
|
|
import os
|
2023-05-17 03:39:00 +00:00
|
|
|
import sys
|
2023-08-14 14:07:15 +00:00
|
|
|
import argparse
|
|
|
|
from typing import Sequence
|
2023-10-25 09:07:40 +00:00
|
|
|
from contextlib import asynccontextmanager
|
2023-05-06 12:17:39 +00:00
|
|
|
|
2023-05-20 15:34:33 +00:00
|
|
|
sys.path.append(os.path.dirname(os.path.realpath(__file__)))
|
|
|
|
|
|
|
|
import psutil
|
2023-06-03 09:12:59 +00:00
|
|
|
from fastapi import Depends, FastAPI
|
2023-05-06 12:17:39 +00:00
|
|
|
from fastapi.middleware.cors import CORSMiddleware
|
|
|
|
import uvicorn
|
|
|
|
|
2023-05-07 09:27:54 +00:00
|
|
|
from utils.rwkv import *
|
|
|
|
from utils.torch import *
|
|
|
|
from utils.ngrok import *
|
2023-06-03 09:12:59 +00:00
|
|
|
from utils.log import log_middleware
|
2023-10-25 09:14:33 +00:00
|
|
|
from routes import completion, config, state_cache, midi, misc, file_process
|
2023-05-07 09:27:54 +00:00
|
|
|
import global_var
|
2023-05-06 12:17:39 +00:00
|
|
|
|
2023-10-25 09:07:40 +00:00
|
|
|
|
|
|
|
@asynccontextmanager
|
|
|
|
async def lifespan(app: FastAPI):
|
|
|
|
init()
|
|
|
|
yield
|
|
|
|
|
|
|
|
|
|
|
|
app = FastAPI(lifespan=lifespan, dependencies=[Depends(log_middleware)])
|
2023-05-06 12:17:39 +00:00
|
|
|
|
|
|
|
app.add_middleware(
|
|
|
|
CORSMiddleware,
|
|
|
|
allow_origins=["*"],
|
|
|
|
allow_credentials=True,
|
|
|
|
allow_methods=["*"],
|
|
|
|
allow_headers=["*"],
|
|
|
|
)
|
|
|
|
|
2023-05-07 09:27:54 +00:00
|
|
|
app.include_router(completion.router)
|
|
|
|
app.include_router(config.router)
|
2023-07-25 08:11:17 +00:00
|
|
|
app.include_router(midi.router)
|
2023-10-25 09:14:33 +00:00
|
|
|
app.include_router(file_process.router)
|
2023-08-14 15:37:55 +00:00
|
|
|
app.include_router(misc.router)
|
2023-05-28 15:52:38 +00:00
|
|
|
app.include_router(state_cache.router)
|
2023-05-07 09:27:54 +00:00
|
|
|
|
2023-05-06 12:17:39 +00:00
|
|
|
|
|
|
|
def init():
|
2023-05-07 09:27:54 +00:00
|
|
|
global_var.init()
|
2023-08-14 14:07:15 +00:00
|
|
|
cmd_params = os.environ["RWKV_RUNNER_PARAMS"]
|
|
|
|
global_var.set(
|
|
|
|
global_var.Args, get_args(cmd_params.split(" ") if cmd_params else None)
|
|
|
|
)
|
|
|
|
|
2023-05-28 15:52:38 +00:00
|
|
|
state_cache.init()
|
2023-05-06 12:17:39 +00:00
|
|
|
|
|
|
|
set_torch()
|
|
|
|
|
|
|
|
if os.environ.get("ngrok_token") is not None:
|
|
|
|
ngrok_connect()
|
|
|
|
|
|
|
|
|
2023-07-26 14:24:26 +00:00
|
|
|
@app.get("/", tags=["Root"])
|
2023-05-06 12:17:39 +00:00
|
|
|
def read_root():
|
2023-06-03 09:12:59 +00:00
|
|
|
return {"Hello": "World!"}
|
2023-05-06 12:17:39 +00:00
|
|
|
|
2023-05-07 09:27:54 +00:00
|
|
|
|
2023-07-26 14:24:26 +00:00
|
|
|
@app.post("/exit", tags=["Root"])
|
2023-05-07 14:48:52 +00:00
|
|
|
def exit():
|
2023-05-07 09:27:54 +00:00
|
|
|
parent_pid = os.getpid()
|
|
|
|
parent = psutil.Process(parent_pid)
|
|
|
|
for child in parent.children(recursive=True):
|
|
|
|
child.kill()
|
|
|
|
parent.kill()
|
2023-05-06 12:17:39 +00:00
|
|
|
|
|
|
|
|
2023-08-14 14:07:15 +00:00
|
|
|
def get_args(args: Union[Sequence[str], None] = None):
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
group = parser.add_argument_group(title="server arguments")
|
|
|
|
group.add_argument(
|
|
|
|
"--port",
|
|
|
|
type=int,
|
|
|
|
default=8000,
|
|
|
|
help="port to run the server on (default: 8000)",
|
|
|
|
)
|
|
|
|
group.add_argument(
|
|
|
|
"--host",
|
|
|
|
type=str,
|
|
|
|
default="127.0.0.1",
|
|
|
|
help="host to run the server on (default: 127.0.0.1)",
|
2023-05-24 14:03:30 +00:00
|
|
|
)
|
2023-08-14 14:07:15 +00:00
|
|
|
group = parser.add_argument_group(title="mode arguments")
|
|
|
|
group.add_argument(
|
|
|
|
"--rwkv-beta",
|
|
|
|
action="store_true",
|
|
|
|
help="whether to use rwkv-beta (default: False)",
|
|
|
|
)
|
|
|
|
args = parser.parse_args(args)
|
|
|
|
|
|
|
|
return args
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
args = get_args()
|
|
|
|
os.environ["RWKV_RUNNER_PARAMS"] = " ".join(sys.argv[1:])
|
|
|
|
print("--- %s seconds ---" % (time.time() - start_time))
|
|
|
|
uvicorn.run("main:app", port=args.port, host=args.host, workers=1)
|