Perth0603's picture
Upload 4 files
e2e3793 verified
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:

  • /predict for text/email/SMS classification via Transformers. Returns { label, score } where score is the confidence for the predicted label.
  • /predict-url for URL classification via your URL model. Returns { label, score, phishing_probability, backend, threshold } where:
    • phishing_probability is always the raw probability of phishing (0..1)
    • label is PHISH when phishing_probability >= threshold, else LEGIT
    • score is the confidence for the predicted label (for LEGIT, score = 1 - phishing_probability), which lets the app show "Safe Confidence" for legitimate URLs

Files

  • Dockerfile - builds a small FastAPI server image
  • app.py - FastAPI app that loads the model and returns normalized responses as above.
  • requirements.txt - Python dependencies.

How to deploy

  1. Create a new Space on Hugging Face (type: Docker).
  2. Upload the contents of this hf_space/ folder to the Space root (including Dockerfile).
  3. 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)
  4. Wait for the Space to build and become green. Test:
    • GET / should return { status: ok, model: ... }
    • POST /predict with { "inputs": "Win an iPhone! Click here" }
    • POST /predict-url with { "url": "https://example.com/login" }

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