Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vedant343/sitegenie.
SiteGenie: Your AI-powered website companion. Enhance interactions effortlessly with our innovative chatbot. Trained on your content, it seamlessly integrates, delivering instant responses to boost engagement.
https://github.com/vedant343/sitegenie.
Last synced: 20 days ago
JSON representation
SiteGenie: Your AI-powered website companion. Enhance interactions effortlessly with our innovative chatbot. Trained on your content, it seamlessly integrates, delivering instant responses to boost engagement.
- Host: GitHub
- URL: https://github.com/vedant343/sitegenie.
- Owner: vedant343
- License: mit
- Created: 2024-03-19T07:42:43.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-06-08T05:59:57.000Z (7 months ago)
- Last Synced: 2024-10-28T16:58:06.012Z (2 months ago)
- Language: JavaScript
- Homepage: https://site-frontend-sitegenie.vercel.app
- Size: 4.8 MB
- Stars: 1
- Watchers: 0
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![Next JS](https://img.shields.io/badge/Next-black?style=plastic&logo=next.js&logoColor=white)
![NodeJS](https://img.shields.io/badge/node.js-6DA55F?style=plastic&logo=node.js&logoColor=white)
![Express.js](https://img.shields.io/badge/express.js-%23404d59.svg?style=plastic&logo=express&logoColor=%2361DAFB)
![Javascript](https://img.shields.io/badge/JavaScript-323330?style=plastic&logo=javascript&logoColor=F7DF1E)
![TailwindCSS](https://img.shields.io/badge/Tailwind_CSS-38B2AC?style=plastic&logo=tailwind-css&logoColor=white)
![Postgres](https://img.shields.io/badge/postgres-%23316192.svg?style=plastic&logo=postgresql&logoColor=white)
![Supabase](https://img.shields.io/badge/Supabase-3ECF8E?style=plastic&logo=supabase&logoColor=white)
![OpenAI](https://img.shields.io/badge/OpenAI-412991.svg?style=plastic&logo=OpenAI&logoColor=white)
![LangChain](https://img.shields.io/badge/Langchain-green)
![AWS](https://img.shields.io/badge/AWS-%23FF9900.svg?style=plastic&logo=amazon-aws&logoColor=white)
![Serverless](https://img.shields.io/badge/Serverless-red)
![GitHub Actions](https://img.shields.io/badge/github%20actions-%232671E5.svg?style=plastic&logo=githubactions&logoColor=white)
![Postman](https://img.shields.io/badge/Postman-FF6C37?style=plastic&logo=postman&logoColor=white)
## About SiteGenie
**SiteGenie** is an innovative AI chatbot meticulously designed to enhance website interactions. Trained on user-provided links, this advanced chatbot seamlessly integrates with websites, delivering instant responses and boosting user engagement. It expedites interactions by eliminating time-consuming searches, significantly improving operational efficiency.
## Features
- **Tailored Data Training:** Our chatbot receives specialized training from carefully selected web pages, nurturing a vast knowledge base for GPT model proficiency.
- **Enhanced Knowledge Base:** Ingest website content into a searchable knowledge base to ensure a robust reference source for chatbot training, enabling accurate and contextually relevant responses.
- **Instantaneous Responses:** The chatbot promptly addresses user queries regarding website content, eliminating the need for human intervention and significantly reducing user wait time.
- **Effortless Integration:** Easily embed the chatbot directly onto any website using HTML iframe embedding, with advanced customization options and theming to enrich user satisfaction and engagement.
- **Responsive and Efficient Design:** Implemented as an end-to-end solution that works on multiple screen sizes with the help of Tailwind CSS, enabling users to efficiently accomplish tasks without navigating multiple pages.
_SiteGenie aims to deliver an intuitive and effective solution for crafting, personalizing, and launching AI-driven chatbots, ultimately elevating user engagement and satisfaction across various domains and industries._
Try SiteGenie`Link to install`
Screenshot of landing page## 💡 How SiteGenie works ?
```mermaid
sequenceDiagram
participant User
participant System
participant Langchain
participant OpenAI
participant Supabase
participant AWS LambdaUser ->> System: Request website URL
System ->> Langchain: Perform recursive data scraping
Langchain ->> System: Return scraped content
System ->> System: Clean content (Stemming, Lemmatization)
System ->> System: Split content into documents
System ->> OpenAI: Create vector embeddings
OpenAI ->> System: Return vector embeddings
System ->> Supabase: Add vector embeddings to vector store
Supabase ->> System: Confirm addition
System ->> User: System ready to process promptsUser ->> System: Send prompt with context
System ->> OpenAI: Generate response using vector store context
OpenAI ->> System: Return generated response
System ->> User: Return responseNote over System, AWS Lambda: Deployment
System ->> AWS Lambda: Deploy backend on AWS Lambda
AWS Lambda ->> System: Serverless deployment allows on-demand executionNote over System: Environments
System ->> AWS Lambda: Deploy code to staging
System ->> AWS Lambda: Deploy tested code to productionNote over System: Integration Testing
System ->> System: Run integration tests for API
System ->> System: Automate deployment script
System ->> System: Clone repo, run tests locally, deploy to staging, run tests againNote over System: GitHub Actions
System ->> GitHub Actions: Run integration tests on every commit
GitHub Actions ->> System: Ensure code quality and functionalityNote over System: Repositories
System ->> System: Maintain frontend and backend repositories
System ->> System: Secure main branch with branch protection rules
System ->> System: Require pull request and code review for merges to main branch```
>This sequence diagram depicts the interaction flow within a system handling website data processing and AI-driven response generation. Initially, the system scrapes data recursively from the requested URL, cleans it, and generates vector embeddings using OpenAI. These embeddings are stored in Supabase. Upon receiving prompts from users, the system leverages these stored embeddings to generate contextually relevant responses via OpenAI. Deployment on AWS Lambda allows for scalable serverless execution, with staging and production environments ensuring smooth integration through automated testing and GitHub Actions, maintaining code quality and security with stringent repository management practices like branch protection and code reviews for merges.
## Contributing
### Built Over ![NextJS Version](https://img.shields.io/badge/Next.js-v14.0.3-blue?style=plastic)
- Clone the repository
```sh
git clone https://github.com/your_username_/Project-Name.git
```- Install dependencies
```sh
npm install
```### Setting-up `.env` file
Your `.env` file should include
```sh
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=
CLERK_SECRET_KEY=
NEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in
NEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up
NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL=/user-dashboard
NEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL=/user-dashboard
```## 🤝 Contributing to Library
> [!NOTE]
> Contributing GuidelinesCreate a pull request
Fork this repository by clicking on the fork button on the top of this page. This will create a copy of this repository in your account.
Clone the repository
Now clone the forked repository to your machine. Go to your GitHub account, open the forked repository, click on the code button and then click the _copy to clipboard_ icon, this is the COPIED_URL.
> _Open a terminal and run the following git command:_
```git
git clone "COPIED_URL"
```e.g : `git clone https://github.com/vedanti-u/db.ai.git`
Install dependencies
```bash
npm install
```Create a branch
Branch naming conviction
Change to the repository directory on your computer (if you are not already there):```bash
cd sitegenie
```Now create a branch using the `git checkout` command:
```bash
git checkout -b new-branch-name
```e.g : `git checkout -b llm-prompt-support`
**Name your branch according to the feature you are working on :**
e.g : you want to work on creating more llm prompt support, name your branch like `llm-prompt-support`
_(follow this naming convention i.e using "-" in between)_
Setting up the .env
Create a `.env` File with format
```bash
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=
CLERK_SECRET_KEY=
NEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in
NEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up
NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL=/user-dashboard
NEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL=/user-dashboard
```Make contribution to Code
Creating pull requests
Once you have modified an existing file or added a new file to the project of your choice, you can stage it to your local repository, which we can do with the `git add` command. In our example, `filename.md`, we will type the following command.
$ git add filename.md
where filename is the file you have modified or created
If you are looking to add all the files you have modified in a particular directory, you can stage them all with the following command:
`git add .`Or, alternatively, you can type `git add -all` for all new files to be staged.
Commiting the changes
git commit -m "Added a new prompt in prompts.json file"
To PUSH your branch to your remote main
$ git push --set-upstream origin your-branch-name
e.g : `$ git push --set-upstream origin optimise-binding`
Open Github
click on compare & pull request
write a description for your pull request specifing the changes you have made, title it and then, Click on create pull request_your branch will be merged on code review_
:people: Collaborators
Vedanti Udapure
Vedant Bhalerao
Vojas Gonnade
-------
https://github.com/vedanti-u/SiteGenie
### :octocat: Statistics[![Open Source Love svg2](https://badges.frapsoft.com/os/v2/open-source.svg?v=103)](https://github.com/ellerbrock/open-source-badges/)
![stars](https://img.shields.io/github/stars/vedanti-u/SiteGenie.svg)
![forks](https://img.shields.io/github/forks/vedanti-u/SiteGenie.svg)
![watchers](https://img.shields.io/github/watchers/vedanti-u/SiteGenie.svg)
[![Open Source? Yes!](https://badgen.net/badge/Open%20Source%20%3F/Yes%21/blue?icon=github)](https://github.com/Naereen/badges/)
[![GitHub contributors](https://badgen.net/github/contributors/vedanti-u/SiteGenie)](https://GitHub.com/vedanti-u/SiteGenie/graphs/contributors/)
[![GitHub commits](https://badgen.net/github/commits/vedanti-u/SiteGenie)](https://GitHub.com/Naereen/StrapDown.js/commit/)
[![GitHub issues](https://img.shields.io/github/issues/vedanti-u/SiteGenie.svg)](https://GitHub.com/vedanti-u/SiteGenie/issues/)
[![GitHub issues-closed](https://img.shields.io/github/issues-closed/vedanti-u/SiteGenie.svg)](https://GitHub.com/vedanti-u/SiteGenie/issues?q=is%3Aissue+is%3Aclosed)
[![GitHub pull-requests closed](https://img.shields.io/github/issues-pr-closed/vedanti-u/SiteGenie.svg)](https://GitHub.com/vedanti-u/SiteGenie/pulls?q=is%3Aclosed)
[![GitHub pull-requests closed](https://badgen.net/github/closed-prs/vedanti-u/SiteGenie)](https://GitHub.com/vedanti-u/SiteGenie/pulls?q=is%3Aclosed)
[![GitHub pull-requests merged](https://badgen.net/github/merged-prs/vedanti-u/SiteGenie)](https://GitHub.com/vedanti-u/SiteGenie/pulls?q=is%3Amerged)
[![GitHub license](https://img.shields.io/github/license/vedanti-u/SiteGenie.svg)](https://github.com/vedanti-u/SiteGenie/blob/master/LICENSE)![Love](https://img.shields.io/badge/Made_with_Love-pink?style=flat-square&logo=)