Spaces:
Sleeping
Sleeping
metadata
title: PhishWatch Proxy
emoji: 🛡️
sdk: docker
Hugging Face Space - Phishing Text Classifier (Docker + FastAPI)
This Space exposes two endpoints so the Flutter app can call them reliably:
/predictfor text/email/SMS classification via Transformers/predict-urlfor URL classification via your scikit-learn Random Forest model
Files
- Dockerfile - builds a small FastAPI server image
- app.py - FastAPI app that loads the model and returns
{ label, score }. - requirements.txt - Python dependencies.
How to deploy
- Create a new Space on Hugging Face (type: Docker).
- Upload the contents of this
hf_space/folder to the Space root (including Dockerfile). - In Space Settings → Variables, add:
- MODEL_ID = Perth0603/phishing-email-mobilebert
- URL_REPO = Perth0603/Random-Forest-Model-for-PhishingDetection
- URL_FILENAME = url_rf_model.joblib (set to your artifact filename)
- Wait for the Space to build and become green. Test:
- GET
/should return{ status: ok, model: ... } - POST
/predictwith{ "inputs": "Win an iPhone! Click here" } - POST
/predict-urlwith{ "url": "https://example.com/login" }
- GET
Flutter app config
Set the Space URL in your env file so the app targets the Space instead of the Hosted Inference API:
{"HF_SPACE_URL":"https://<your-space>.hf.space"}
Run the app:
flutter run --dart-define-from-file=hf.env.json