-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.py
More file actions
103 lines (81 loc) · 3.19 KB
/
app.py
File metadata and controls
103 lines (81 loc) · 3.19 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import os
import sys
from pathlib import Path
from typing import Annotated
from urllib.parse import quote_plus
import certifi
import pandas as pd
from dotenv import load_dotenv
from fastapi import FastAPI, File, Request, UploadFile
from fastapi.middleware.cors import CORSMiddleware
from fastapi.responses import Response
from fastapi.templating import Jinja2Templates
from pymongo.mongo_client import MongoClient
from pymongo.server_api import ServerApi
from starlette.responses import RedirectResponse
from starlette.templating import _TemplateResponse
from uvicorn import run as app_run
from network_security.constant.training_pipeline import (
DATA_INGESTION_COLLECTION_NAME,
DATA_INGESTION_DATABASE_NAME,
)
from network_security.exception.exception import NetworkSecurityException
from network_security.logging.logger import logging
from network_security.pipeline.training_pipeline import TrainingPipeline
from network_security.utils.main_utils.utils import load_object
from network_security.utils.ml_utils.model.estimator import NetworkModel
ca = certifi.where()
load_dotenv()
username = quote_plus(os.getenv("MONGO_DB_USERNAME"))
password = quote_plus(os.getenv("MONGO_DB_PASSWORD"))
mongo_db_url: str = f"mongodb+srv://{username}:{password}@cluster0.l5ee6dv.mongodb.net/?retryWrites=true&w=majority&appName=Cluster0"
client = MongoClient(mongo_db_url, server_api=ServerApi("1"), tlsCAFile=ca)
database = client[DATA_INGESTION_DATABASE_NAME]
collection = database[DATA_INGESTION_COLLECTION_NAME]
app = FastAPI()
origins = ["*"]
app.add_middleware(
CORSMiddleware,
allow_origins=origins,
allow_credentials=True,
allow_methods=["*"],
allow_headers=["*"],
)
templates = Jinja2Templates(directory="./templates")
@app.get("/", tags=["authentication"])
async def index() -> RedirectResponse:
return RedirectResponse(url="/docs")
@app.get("/train")
async def train_route() -> Response:
try:
train_pipeline = TrainingPipeline()
train_pipeline.run_pipeline()
return Response("Training is successful")
except Exception as e:
raise NetworkSecurityException(e, sys)
@app.post("/predict")
async def predict_route(request: Request, file: Annotated[UploadFile, File()] = ...) -> _TemplateResponse:
try:
df = pd.read_csv(file.file)
# print(df)
preprocesor = load_object("final_model/preprocessor.pkl")
final_model = load_object("final_model/model.pkl")
network_model = NetworkModel(preprocessor=preprocesor, model=final_model)
print(df.iloc[0])
y_pred = network_model.predict(df)
print(y_pred)
df["predicted_column"] = y_pred
print(df["predicted_column"])
# df['predicted_column'].replace(-1, 0)
# return df.to_json()
Path("prediction_output").mkdir(exist_ok=True)
df.to_csv("prediction_output/output.csv")
table_html = df.to_html(classes="table table-striped")
# print(table_html)
return templates.TemplateResponse(
"table.html", {"request": request, "table": table_html},
)
except Exception as e:
raise NetworkSecurityException(e, sys)
if __name__ == "__main__":
app_run(app, host="0.0.0.0", port=8080)