feat: pipeline filter wildcard support

This commit is contained in:
Timothy J. Baek 2024-05-27 20:26:24 -07:00
parent 966f10e715
commit ec36493d61

View File

@ -249,21 +249,23 @@ class PipelineMiddleware(BaseHTTPMiddleware):
data = json.loads(body_str) if body_str else {}
model_id = data["model"]
valves = [
filters = [
model
for model in app.state.MODELS.values()
if "pipeline" in model
and model["pipeline"]["type"] == "filter"
and model_id
in [
target_model["id"]
for target_model in model["pipeline"]["pipelines"]
]
and (
model["pipeline"]["pipelines"] == ["*"]
or any(
model_id == target_model["id"]
for target_model in model["pipeline"]["pipelines"]
)
)
]
sorted_valves = sorted(valves, key=lambda x: x["pipeline"]["priority"])
sorted_filters = sorted(filters, key=lambda x: x["pipeline"]["priority"])
user = None
if len(sorted_valves) > 0:
if len(sorted_filters) > 0:
try:
user = get_current_user(
get_http_authorization_cred(
@ -274,10 +276,12 @@ class PipelineMiddleware(BaseHTTPMiddleware):
except:
pass
for valve in sorted_valves:
print(sorted_filters)
for filter in sorted_filters:
try:
urlIdx = valve["urlIdx"]
urlIdx = filter["urlIdx"]
url = openai_app.state.config.OPENAI_API_BASE_URLS[urlIdx]
key = openai_app.state.config.OPENAI_API_KEYS[urlIdx]
@ -289,7 +293,7 @@ class PipelineMiddleware(BaseHTTPMiddleware):
headers=headers,
json={
"user": user,
"model": valve["id"],
"model": filter["id"],
"body": data,
},
)
@ -298,7 +302,7 @@ class PipelineMiddleware(BaseHTTPMiddleware):
data = r.json()
except Exception as e:
# Handle connection error here
log.error(f"Connection error: {e}")
print(f"Connection error: {e}")
pass
modified_body_bytes = json.dumps(data).encode("utf-8")