A fast accurate API for detecting NSFW images. Ideal for content moderation on digital platforms.
This project uses Python, FastAPI framework, Transformers library, and TensorFlow.
TensorFlow will automatically detect and use the GPU if the underlying hardware supports it.
- Uses the Falconsai/nsfw-image-detection AI model
- Caches results based on SHA-256 hash of image data
docker run -p 8000:8000 steelcityamir/safe-content-ai:latest
Test using curl
curl -X POST "http://127.0.0.1:8000/v1/detect" \
-H "Content-Type: multipart/form-data" \
-F "file=@/path/to/your/image.jpeg"
Ensure you have Python 3.7+ installed on your system.
Clone the repository to your local machine:
git clone https://github.com/steelcityamir/safe-content-ai.git
Navigate to the cloned directory:
cd safe-content-ai
Create a virtual environment
python -m venv venv
source venv/bin/activate
Install the required libraries using pip:
pip install -r requirements.txt
Start the API server from your command line:
uvicorn main:app --reload
The API server runs on port 8000.
This endpoint allows users to upload an image file, which is then processed to determine if the content is NSFW (Not Safe For Work). The response includes whether the image is considered NSFW and the confidence level of the prediction.
- URL:
/v1/detect
- Method:
POST
- Content-Type:
multipart/form-data
- Body:
- file (required): The image file to be classified.
- Content-Type:
application/json
- Body:
{ "file_name": "string", "is_nsfw": "boolean", "confidence_percentage": "number" }
curl -X POST "http://127.0.0.1:8000/v1/detect" \
-H "Content-Type: multipart/form-data" \
-F "file=@/path/to/your/image.jpeg"
This endpoint allows users to provide image URLs, which are then processed to determine if the content is NSFW (Not Safe For Work). The response includes whether each image is considered NSFW and the confidence level of the prediction.
- URL:
/v1/detect/urls
- Method:
POST
- Content-Type:
application/json
- Body:
{ "urls": [ "https://example.com/image1.jpg", "https://example.com/image2.jpg", "https://example.com/image3.jpg", "https://example.com/image4.jpg", "https://example.com/image5.jpg" ] }
- Content-Type:
application/json
- Body:
[ { "url": "string", "is_nsfw": "boolean", "confidence_percentage": "number" } ]
curl -X POST "http://127.0.0.1:8000/v1/detect/urls" \
-H "Content-Type: application/json" \
-d '{
"urls": [
"https://example.com/image1.jpg",
"https://example.com/image2.jpg",
"https://example.com/image3.jpg",
"https://example.com/image4.jpg",
"https://example.com/image5.jpg"
]
}'
This project is licensed under the MIT License - see the LICENSE file for details.
For support, please open an issue in the GitHub issue tracker for this project.