Initial Commit
commit
d3f22505ec
|
@ -0,0 +1,8 @@
|
|||
# Default ignored files
|
||||
/shelf/
|
||||
/workspace.xml
|
||||
# Editor-based HTTP Client requests
|
||||
/httpRequests/
|
||||
# Datasource local storage ignored files
|
||||
/dataSources/
|
||||
/dataSources.local.xml
|
|
@ -0,0 +1,10 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="PYTHON_MODULE" version="4">
|
||||
<component name="NewModuleRootManager">
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<excludeFolder url="file://$MODULE_DIR$/.venv" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
|
@ -0,0 +1,15 @@
|
|||
<component name="InspectionProjectProfileManager">
|
||||
<profile version="1.0">
|
||||
<option name="myName" value="Project Default" />
|
||||
<inspection_tool class="PyPackageRequirementsInspection" enabled="true" level="WARNING" enabled_by_default="true">
|
||||
<option name="ignoredPackages">
|
||||
<value>
|
||||
<list size="2">
|
||||
<item index="0" class="java.lang.String" itemvalue="pydantic_core" />
|
||||
<item index="1" class="java.lang.String" itemvalue="typing_extensions" />
|
||||
</list>
|
||||
</value>
|
||||
</option>
|
||||
</inspection_tool>
|
||||
</profile>
|
||||
</component>
|
|
@ -0,0 +1,6 @@
|
|||
<component name="InspectionProjectProfileManager">
|
||||
<settings>
|
||||
<option name="USE_PROJECT_PROFILE" value="false" />
|
||||
<version value="1.0" />
|
||||
</settings>
|
||||
</component>
|
|
@ -0,0 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Black">
|
||||
<option name="sdkName" value="Python 3.11 (OpenAIProxy)" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.11 (OpenAIProxy)" project-jdk-type="Python SDK" />
|
||||
</project>
|
|
@ -0,0 +1,8 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/OpenAIProxy.iml" filepath="$PROJECT_DIR$/.idea/OpenAIProxy.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
|
@ -0,0 +1,6 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
|
@ -0,0 +1,59 @@
|
|||
import json
|
||||
|
||||
from flask import Flask, request, Response
|
||||
import requests
|
||||
|
||||
app = Flask(__name__)
|
||||
|
||||
# Die Backend-Server-Adresse
|
||||
BACKEND_SERVER = "https://api.mistral.ai"
|
||||
|
||||
@app.route("/", defaults={"path": ""}, methods=["GET", "POST", "PUT", "DELETE"])
|
||||
@app.route("/<path:path>", methods=["GET", "POST", "PUT", "DELETE"])
|
||||
def proxy(path):
|
||||
# Die Anfrage an den Backend-Server weiterleiten
|
||||
backend_url = f"{BACKEND_SERVER}/{path}"
|
||||
print(f"Request to backend: {backend_url}")
|
||||
|
||||
# Anfragemethode und -header an den Backend-Server weiterleiten
|
||||
backend_request_method = request.method
|
||||
backend_request_headers = {}
|
||||
|
||||
for header in request.headers:
|
||||
if header[0] in [ "Authorization", "Accept", "Content-Type"]:
|
||||
backend_request_headers[header[0]] = header[1]
|
||||
|
||||
# Den Request-Body filtern, bevor er an den Backend-Server gesendet wird
|
||||
if (request.get_data()):
|
||||
backend_request_data = filter_request_body(request.get_data())
|
||||
else:
|
||||
backend_request_data = None
|
||||
|
||||
# Die Anfrage an den Backend-Server senden
|
||||
backend_response = requests.request(
|
||||
backend_request_method,
|
||||
backend_url,
|
||||
headers=backend_request_headers,
|
||||
data=backend_request_data,
|
||||
)
|
||||
|
||||
# Die Antwort des Backend-Servers an den Client weiterleiten
|
||||
response_headers = {
|
||||
"Content-Type": backend_request_headers["Content-Type"],
|
||||
}
|
||||
response = Response(backend_response.content, backend_response.status_code, response_headers)
|
||||
print(f"Response headers: {response_headers}")
|
||||
print(f"Response body: {backend_response.content}")
|
||||
return response
|
||||
|
||||
def filter_request_body(request_body):
|
||||
j = json.loads(request_body)
|
||||
if "user" in j:
|
||||
del j["user"]
|
||||
if "n" in j:
|
||||
del j["n"]
|
||||
|
||||
return json.dumps(j)
|
||||
|
||||
if __name__ == "__main__":
|
||||
app.run(host="0.0.0.0", port=8080, debug=True)
|
|
@ -0,0 +1,6 @@
|
|||
certifi==2024.2.2
|
||||
charset-normalizer==3.3.2
|
||||
idna==3.7
|
||||
requests==2.31.0
|
||||
urllib3==2.2.1
|
||||
flask==3.0.3
|
Loading…
Reference in New Issue