safe-content-ai/README.md
Boroumand, Amir A 1552747d79 Update README.md
2024-04-22 14:23:15 -04:00

103 lines
2.2 KiB
Markdown

[![Python CI](https://github.com/steelcityamir/safe-content-ai/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/steelcityamir/safe-content-ai/actions/workflows/ci.yml) [![codecov](https://codecov.io/gh/steelcityamir/safe-content-ai/graph/badge.svg?token=RRZEJFKRG1)](https://codecov.io/gh/steelcityamir/safe-content-ai)
# Safe Content AI
A fast reliable API for detecting NSFW images.
## ⭐ Features
- Uses the [Falconsai/nsfw-image-detection](https://huggingface.co/Falconsai/nsfw_image_detection) AI model
- Caches results based on SHA-256 hash of image data
## 🐳 Quick Start using Docker
```bash
docker run -p 8000:8000 codebyamir/safecontentai:latest
```
## Getting Started
### Prerequisites
Ensure you have Python 3.7+ installed on your system.
### Installation
Clone the repository to your local machine:
```bash
git clone https://github.com/steelcityamir/safe-content-ai.git
```
Navigate to the cloned directory:
```bash
cd safe-content-ai
```
Create a virtual environment
```bash
python -m venv venv
source venv/bin/activate
```
Install the required libraries using pip:
```bash
pip install -r requirements.txt
```
### Running the API
Start the API server from your command line:
```bash
uvicorn main:app --reload
```
## API usage
### POST /api/v1/detect
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.
#### Request
- **URL**: `/api/v1/detect`
- **Method**: `POST`
- **Content-Type**: `multipart/form-data`
- **Body**:
- **file** (required): The image file to be classified.
#### Response
- **Content-Type**: `application/json`
- **Body**:
```json
{
"file_name": "string",
"is_nsfw": "boolean",
"confidence_percentage": "number"
}
#### Curl
```bash
curl -X POST "http://127.0.0.1:8000/api/v1/detect" \
-H "Content-Type: multipart/form-data" \
-F "file=@/path/to/your/image.jpeg"
```
## 📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
## Support
For support, please open an issue in the GitHub issue tracker for this project.