Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update Packaging #65

Merged
merged 9 commits into from
Oct 26, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,5 @@ python-sdk/dist/
python-sdk/build/
.pytest_cache/
python-sdk/.pytest_cache/
.vscode
.vscode
server/.env.local
18 changes: 0 additions & 18 deletions Dockerfile

This file was deleted.

6 changes: 2 additions & 4 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,11 @@ format:
cd python-sdk; isort rebuff/ tests/
cd python-sdk; black rebuff/ tests/


init: init-python-sdk init-server
npm install

Comment on lines -16 to -19
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So this is called in our github workflow:
https://github.com/protectai/rebuff/blob/main/.github/workflows/python_tests.yaml#L27-L28
https://github.com/protectai/rebuff/blob/main/python-sdk/tests/conftest.py#L21-L58

Which stands up the server for python-sdk tests (and subsequently tests ingration with the server -- now pinned to a specific release). Ultimately we should replace this setup with unit testing individual TS functions but for the time being is there a need to remove this?

Copy link
Member Author

@cherbel cherbel Oct 25, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added it back, although I removed the npm install, because the init-server step runs the install in the server directory, and there is no longer a package.json in the root directory.

init-python-sdk:
cd python-sdk; pip install -e '.[dev]' -U

init: init-python-sdk init-server

init-server:
cd server; npm install

Expand Down
88 changes: 45 additions & 43 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,21 +9,22 @@

<div align="center">

## Rebuff.ai
## Rebuff.ai

<img width="250" src="https://imgur.com/ishzqSK.png" alt="Rebuff Logo">

### **Self-hardening prompt injection detector**
Rebuff is designed to protect AI applications from prompt injection (PI) attacks through a [multi-layered defense](#features).
### **Self-hardening prompt injection detector**

Rebuff is designed to protect AI applications from prompt injection (PI) attacks through a [multi-layered defense](#features).

[Playground](https://playground.rebuff.ai/) •
[Discord](https://discord.gg/R3U2XVNKeE) •
[Features](#features) •
[Installation](#installation) •
[Getting started](#getting-started) •
[Self-hosting](#self-hosting) •
[Contributing](#contributing) •
[Docs](https://docs.rebuff.ai)
[Playground](https://playground.rebuff.ai/) •
[Discord](https://discord.gg/R3U2XVNKeE) •
[Features](#features) •
[Installation](#installation) •
[Getting started](#getting-started) •
[Self-hosting](#self-hosting) •
[Contributing](#contributing) •
[Docs](https://docs.rebuff.ai)

</div>
<div align="center">
Expand All @@ -32,15 +33,14 @@

</div>


## Disclaimer

Rebuff is still a prototype and **cannot provide 100% protection** against prompt injection attacks!

## Features


Rebuff offers 4 layers of defense:

- Heuristics: Filter out potentially malicious input before it reaches the LLM.
- LLM-based detection: Use a dedicated LLM to analyze incoming prompts and identify potential attacks.
- VectorDB: Store embeddings of previous attacks in a vector database to recognize and prevent similar attacks in the future.
Expand All @@ -66,6 +66,7 @@ pip install rebuff
## Getting started

### Detect prompt injection on user input

```python
from rebuff import Rebuff

Expand Down Expand Up @@ -109,65 +110,66 @@ if is_leak_detected:

## Self-hosting

To self-host Rebuff, you need to set up the necessary providers like Pinecone,
To self-host Rebuff Playground, you need to set up the necessary providers like Pinecone,
Supabase, and OpenAI. Follow the links below to set up each provider:

- [Pinecone](https://www.pinecone.io/)
- [Supabase](https://supabase.io/)
- [OpenAI](https://beta.openai.com/signup/)

Once you have set up the providers, you'll need to stand up the relevant SQL and
vector databases on Supabase and Pinecone respectively. See the
Once you have set up the providers, you'll need to stand up the relevant SQL and
vector databases on Supabase and Pinecone respectively. See the
[server README](server/README.md) for more information.

Now you can start the Rebuff server using Docker. First, build the Docker image:
Now you can start the Rebuff server using npm.

```bash
docker build -t rebuff .
cd server
```

In the server directory create an `.env.local` file and add the following environment variables:

```
OPENAI_API_KEY=<your_openai_api_key>
MASTER_API_KEY=12345
BILLING_RATE_INT_10K=<your_billing_rate_int_10k>
MASTER_CREDIT_AMOUNT=<your_master_credit_amount>
NEXT_PUBLIC_SUPABASE_ANON_KEY=<your_next_public_supabase_anon_key>
NEXT_PUBLIC_SUPABASE_URL=<your_next_public_supabase_url>
PINECONE_API_KEY=<your_pinecone_api_key>
PINECONE_ENVIRONMENT=<your_pinecone_environment>
PINECONE_INDEX_NAME=<your_pinecone_index_name>
SUPABASE_SERVICE_KEY=<your_supabase_service_key>
REBUFF_API=http://localhost:3000
```

Then, start the Docker container with the below command,
replacing the placeholders with your actual API keys, environment variables, and
desired server configurations.
Install packages and run the server with the following:

```bash
docker run -d -p 3000:3000 \
-e OPENAI_API_KEY=<your_openai_api_key> \
-e MASTER_API_KEY=12345 \
-e BILLING_RATE_INT_10K=<your_billing_rate_int_10k> \
-e MASTER_CREDIT_AMOUNT=<your_master_credit_amount> \
-e NEXT_PUBLIC_SUPABASE_ANON_KEY=<your_next_public_supabase_anon_key> \
-e NEXT_PUBLIC_SUPABASE_URL=<your_next_public_supabase_url> \
-e PINECONE_API_KEY=<your_pinecone_api_key> \
-e PINECONE_ENVIRONMENT=<your_pinecone_environment> \
-e PINECONE_INDEX_NAME=<your_pinecone_index_name> \
-e SUPABASE_SERVICE_KEY=<your_supabase_service_key> \
-e REBUFF_API=http://localhost:3000 \
--name rebuff rebuff
npm install
npm run dev
```

Now, the Rebuff server should be running at `http://localhost:3000`.


### Server Configurations

* `BILLING_RATE_INT_10K`: The amount of credits that should be deducted for
every request. The value is an integer, and 10k refers to a single dollar amount.
So if you set the value to 10000 then it will deduct 1 dollar per request. If you set
it to 1 then it will deduct 0.1 cents per request.

- `BILLING_RATE_INT_10K`: The amount of credits that should be deducted for
every request. The value is an integer, and 10k refers to a single dollar amount.
So if you set the value to 10000 then it will deduct 1 dollar per request. If you set
it to 1 then it will deduct 0.1 cents per request.

## How it works
![Sequence Diagram](https://github.com/woop/rebuff/assets/6728866/3d90ebb3-d149-42e8-b991-a46c46d5a9e7)

![Sequence Diagram](https://github.com/woop/rebuff/assets/6728866/3d90ebb3-d149-42e8-b991-a46c46d5a9e7)

## Contributing

We'd love for you to join our community and help improve Rebuff! Here's how you can get involved:

1. Star the project to show your support!
2. Contribute to the open source project by submitting issues, improvements, or adding new features.
3. Join our [Discord server](https://discord.gg/R3U2XVNKeE).
3. Join our [Discord server](https://discord.gg/R3U2XVNKeE).

## Development

Expand Down
Empty file removed apps/.keep
Empty file.
24 changes: 0 additions & 24 deletions apps/prompt-hack/.eslintrc.json

This file was deleted.

Loading
Loading