-
-
Notifications
You must be signed in to change notification settings - Fork 155
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' of https://github.com/OWASP-BLT/BLT
- Loading branch information
Showing
36 changed files
with
4,563 additions
and
544 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,177 @@ | ||
import tempfile | ||
from pathlib import Path | ||
|
||
import openai | ||
from django.core.files.base import ContentFile | ||
from django.core.files.storage import default_storage | ||
from dotenv import find_dotenv, load_dotenv | ||
from langchain.chains import ConversationalRetrievalChain | ||
from langchain.memory import ConversationSummaryMemory | ||
from langchain.text_splitter import RecursiveCharacterTextSplitter | ||
from langchain_community.document_loaders import ( | ||
DirectoryLoader, | ||
Docx2txtLoader, | ||
PyPDFLoader, | ||
TextLoader, | ||
UnstructuredMarkdownLoader, | ||
) | ||
from langchain_community.vectorstores import FAISS | ||
from langchain_core.prompts import ChatPromptTemplate | ||
from langchain_openai import ChatOpenAI, OpenAIEmbeddings | ||
from openai import OpenAI | ||
|
||
load_dotenv(find_dotenv(), override=True) | ||
|
||
|
||
def is_api_key_valid(api_key): | ||
client = OpenAI(api_key=api_key) | ||
try: | ||
client.completions.create(prompt="Hello", model="gpt-3.5-turbo-instruct", max_tokens=1) | ||
return True | ||
except openai.APIConnectionError as e: | ||
print(f"Failed to connect to OpenAI API: {e}") | ||
except openai.RateLimitError as e: | ||
print(f"OpenAI API rate limit exceeded: {e}") | ||
except openai.APIError as e: | ||
print(f"OpenAI API error: {e}") | ||
return False | ||
|
||
|
||
def load_document(file_path): | ||
loaders = { | ||
".pdf": PyPDFLoader, | ||
".docx": Docx2txtLoader, | ||
".txt": TextLoader, | ||
".md": UnstructuredMarkdownLoader, | ||
} | ||
|
||
file_path = Path(file_path) | ||
extension = file_path.suffix | ||
Loader = loaders.get(extension) | ||
|
||
if Loader is None: | ||
raise ValueError(f"Unsupported file format: {extension}") | ||
|
||
return Loader(file_path).load() | ||
|
||
|
||
def load_directory(dir_path): | ||
return DirectoryLoader(dir_path).load() | ||
|
||
|
||
def split_document(chunk_size, chunk_overlap, document): | ||
text_splitter = RecursiveCharacterTextSplitter( | ||
chunk_size=chunk_size, | ||
chunk_overlap=chunk_overlap, | ||
length_function=len, | ||
) | ||
return text_splitter.split_documents(document) | ||
|
||
|
||
def get_temp_db_path(db_folder_path): | ||
temp_dir = tempfile.TemporaryDirectory() | ||
db_folder_str = str(db_folder_path) | ||
temp_db_path = Path(temp_dir.name) / db_folder_path | ||
temp_db_path.mkdir(parents=True, exist_ok=True) | ||
return temp_dir, db_folder_str, temp_db_path | ||
|
||
|
||
def embed_documents_and_save(embed_docs): | ||
db_folder_path = Path("faiss_index") | ||
|
||
embeddings = OpenAIEmbeddings(model="text-embedding-3-small") | ||
|
||
# Temporary directory for local operations | ||
temp_dir, db_folder_str, temp_db_path = get_temp_db_path(db_folder_path) | ||
|
||
# Check if the folder exists in the storage system and download files | ||
if default_storage.exists(db_folder_str) and default_storage.listdir(db_folder_str): | ||
# Download all files from the storage folder to the temp directory | ||
for file_name in default_storage.listdir(db_folder_str)[1]: | ||
with default_storage.open(db_folder_path / file_name, "rb") as f: | ||
content = f.read() | ||
with open(temp_db_path / file_name, "wb") as temp_file: | ||
temp_file.write(content) | ||
|
||
# Load the FAISS index from the temp directory | ||
db = FAISS.load_local(temp_db_path, embeddings, allow_dangerous_deserialization=True) | ||
# Add new documents to the index | ||
db.add_documents(embed_docs) | ||
else: | ||
# Create a new FAISS index if it doesn't exist | ||
db = FAISS.from_documents(embed_docs, embeddings) | ||
|
||
# Save the updated FAISS index back to the temp directory | ||
db.save_local(temp_db_path) | ||
|
||
# Clean up the storage directory before uploading the new files | ||
if default_storage.exists(db_folder_str): | ||
for file_name in default_storage.listdir(db_folder_str)[1]: | ||
default_storage.delete(db_folder_path / file_name) | ||
|
||
# Upload the updated files back to Django's storage | ||
for file in temp_db_path.rglob("*"): | ||
if file.is_file(): | ||
with open(file, "rb") as f: | ||
content = f.read() | ||
default_storage.save( | ||
str(db_folder_path / file.relative_to(temp_db_path)), ContentFile(content) | ||
) | ||
temp_dir.cleanup() | ||
|
||
return db | ||
|
||
|
||
def load_vector_store(): | ||
embeddings = OpenAIEmbeddings(model="text-embedding-3-small") | ||
db_folder_path = Path("faiss_index") | ||
|
||
temp_dir, db_folder_str, temp_db_path = get_temp_db_path(db_folder_path) | ||
|
||
# check the file exists in the storage system and download files if not exist return None | ||
if not default_storage.exists(db_folder_str) or not default_storage.listdir(db_folder_str)[1]: | ||
temp_dir.cleanup() | ||
return None | ||
# Download all files from the storage folder to the temp directory | ||
for file_name in default_storage.listdir(db_folder_str)[1]: | ||
with default_storage.open(db_folder_path / file_name, "rb") as f: | ||
content = f.read() | ||
with open(temp_db_path / file_name, "wb") as temp_file: | ||
temp_file.write(content) | ||
|
||
# Load the FAISS index from the temp directory | ||
db = FAISS.load_local(temp_db_path, embeddings, allow_dangerous_deserialization=True) | ||
temp_dir.cleanup() | ||
|
||
return db | ||
|
||
|
||
def conversation_chain(vector_store): | ||
prompt = ChatPromptTemplate.from_messages( | ||
( | ||
"human", | ||
( | ||
"You are an assistant specifically designed for answering questions about " | ||
"the OWASP Bug Logging Tool (BLT) application. Use the following pieces of " | ||
"retrieved context to answer the question. If the user's question is not " | ||
"related to the BLT application or if the context does not provide enough " | ||
"information to answer the question, respond with 'Please ask a query related " | ||
"to the BLT Application.' Ensure your response is concise and does not exceed " | ||
"three sentences.\nQuestion: {question}\nContext: {context}\nAnswer:" | ||
), | ||
) | ||
) | ||
llm = ChatOpenAI(model_name="gpt-3.5-turbo-0125", temperature=0.5) | ||
retriever = vector_store.as_retriever(search_type="similarity", search_kwargs={"k": 3}) | ||
memory = ConversationSummaryMemory( | ||
llm=llm, return_messages=True, memory_key="chat_history", max_token_limit=1000 | ||
) | ||
|
||
crc = ConversationalRetrievalChain.from_llm( | ||
llm=llm, | ||
retriever=retriever, | ||
memory=memory, | ||
chain_type="stuff", | ||
combine_docs_chain_kwargs={"prompt": prompt}, | ||
) | ||
return crc, memory |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
### Detailed Description of the "About Us" UI Component and the url path is "https://blt.owasp.org/about/" for the OWASP Bug Logging Tool (BLT) Application | ||
|
||
#### 1. Component Overview | ||
The "About Us" UI component in the OWASP Bug Logging Tool (BLT) application provides users with comprehensive information about the BLT project, its purpose, functionalities, and how it benefits users. This section aims to inform users about the initiative's goals, how it operates, and the incentives for participating in bug reporting. | ||
|
||
#### 2. User Interaction | ||
Users interact with the About Us component through the following steps: | ||
1. **Accessing the Component**: Users navigate to the "About Us" section via the sidebar menu. | ||
2. **Reading Information**: Users read through the detailed information provided to understand the BLT initiative, its goals, and how they can participate. | ||
3. **Navigating Links**: Users may click on embedded links to access related pages or external resources for more detailed information. | ||
|
||
#### 3. Key Elements | ||
- **Navigation Sidebar**: Contains links to various sections of the BLT application, including Issues, Companies, Scoreboard, Users, Teams, Bug Bounties, and more. | ||
- **About BLT Section**: Provides a detailed description of the BLT project, emphasizing its open-source nature, non-commercial goals, and community-driven approach. | ||
- **User Benefits**: Describes the incentives for users, including points, money from sponsored bug hunts, leaderboard recognition, and tips for finding bugs. | ||
- **How It Works**: Provides step-by-step instructions for testers on how to participate, including creating a user account, describing bugs, attaching screenshots, and submitting information. | ||
- **Organization Benefits**: Explains the advantages for organizations in maintaining a bug-free website and how they can participate in the bug bounty program. | ||
- **Additional Information**: Includes links to terms and conditions, privacy policy, and other relevant documentation. | ||
|
||
#### 4. Visual Design | ||
- **Layout**: The layout features a left sidebar for navigation and a main content area displaying the detailed information. The text is organized into sections with clear headings for easy reading. | ||
- **Color Scheme**: The design uses a consistent color scheme with red, white, and grey tones, matching the overall BLT branding. Red is used for headings and links to draw attention. | ||
- **Typography**: Modern, readable fonts are used for headings, body text, and links, ensuring clarity and ease of reading. | ||
- **Visual Cues**: Headings and sections are clearly delineated, and links are highlighted to indicate interactivity. | ||
|
||
#### 5. Accessibility Features | ||
- **Keyboard Navigation**: All interactive elements can be accessed and operated via keyboard shortcuts, allowing users with mobility impairments to navigate and use the component. | ||
- **Screen Reader Compatibility**: The text and links are labeled clearly to be compatible with screen readers, aiding visually impaired users in understanding and interacting with the component. | ||
- **High Contrast**: Text and interactive elements have high contrast against the background, making it easier for users with visual impairments to read the content. | ||
- **Descriptive Labels**: All interactive elements have clear and descriptive labels to ensure users understand their purpose and functionality. | ||
|
||
#### 6. Error Handling | ||
The About Us component includes mechanisms to handle errors and provide feedback to users: | ||
- **Error Messages**: If an error occurs while loading the information or navigating links, clear and concise error messages are displayed to inform the user and provide steps to resolve the issue. | ||
- **Fallback Content**: If the main content fails to load, the page provides fallback messages or placeholders, ensuring that the user experience is not significantly disrupted. | ||
- **Input Validation**: Ensures that users enter valid input before submitting queries or interactions. | ||
|
||
#### 7. Performance | ||
The component is designed with several features to enhance performance and user experience: | ||
- **Optimized Loading**: The page is optimized to load quickly, allowing users to access the information without delay. | ||
- **Responsive Design**: The layout is fully responsive, adapting to different screen sizes and devices to ensure a consistent and accessible experience across desktops, tablets, and mobile devices. | ||
- **Efficient Data Retrieval**: Uses efficient data retrieval techniques to fetch and display information quickly, minimizing wait times and enhancing user satisfaction. | ||
- **Scalability**: The component is designed to handle a large amount of textual information, maintaining performance and user experience even with extensive content. | ||
|
||
|
||
|
||
About us Page content : | ||
About BLT | ||
BLT is 100% free to use, Open Source and a non-commercial, not for profit initiative. All prize money goes directly to the bug hunter. | ||
Software code allows us to buy a gift for Mom or Dad on amazon.com in 7 seconds, watch our favorite “House of Cards” episode on Netflix or read Yelp reviews about a new restaurant. | ||
|
||
When we can’t access the information we’re looking for on the internet within seconds, we are not happy. | ||
|
||
This is where you come into the picture. | ||
|
||
BLT wants you to identify the software (and hardware) bugs that delay downloads, freeze screens, create payloads that deliver malware to websites and generate other issues. | ||
|
||
What’s in it for you? | ||
Points. | ||
Money if you join a BLT Sponsored Bug Hunt. | ||
Jackpot money listed on the Leaderboard. | ||
Money if someone tips you for finding a bug through the tip button. | ||
Experience to add to your résumé or portfolio. | ||
How it Works | ||
Testers | ||
Create a User Account to log into BLT. | ||
Describe the software or hardware bug you found. | ||
Attach a screenshot of the bug. | ||
Submit the information. | ||
Win money through company-sponsored Bug Bounties, tips or the Grand Prize/Jackpot.We may also have "heists" where each bug is worth a specific amount based on what the company sets. | ||
If you participate in BLT’s sponsored Bug Bounties, you could win prize money known as tips. | ||
Organizations | ||
We want everyone to love your website. | ||
You want to keep your customers happy by giving them a consistent bug-free user experience. BLT offers monthly Bug Bounties through 4 different subscription plans to help you achieve this. | ||
|
||
BLT is 100% free to use, Open Source and a non-commercial, not for profit initiative. |
Oops, something went wrong.