Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kiranbaby14/docu-watch
An intelligent system that revolutionizes contract management using AI, graph databases, and DocuSign integration. Transform dense legal documents into actionable insights with automated analysis, real-time tracking, and a smart chatbot interface. Built with OpenAI, Neo4j, and FastAPI.
https://github.com/kiranbaby14/docu-watch
docusign-api fastapi neo4j nextjs openai semantic-kernel webhooks
Last synced: 20 days ago
JSON representation
An intelligent system that revolutionizes contract management using AI, graph databases, and DocuSign integration. Transform dense legal documents into actionable insights with automated analysis, real-time tracking, and a smart chatbot interface. Built with OpenAI, Neo4j, and FastAPI.
- Host: GitHub
- URL: https://github.com/kiranbaby14/docu-watch
- Owner: kiranbaby14
- License: mit
- Created: 2024-12-15T14:41:56.000Z (2 months ago)
- Default Branch: master
- Last Pushed: 2025-01-28T12:15:38.000Z (22 days ago)
- Last Synced: 2025-01-28T12:35:07.164Z (22 days ago)
- Topics: docusign-api, fastapi, neo4j, nextjs, openai, semantic-kernel, webhooks
- Language: Python
- Homepage:
- Size: 581 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Docu Watch
An application that leverages DocuSign, OpenAI, Microsoft semantic-kernel and Neo4j to provide intelligent contract analysis and a context-aware chatbot interface.
## 🏗️ Architecture
data:image/s3,"s3://crabby-images/92a1d/92a1d82c4253036c450a5137f254115c595456e4" alt="System Architecture"
## 🎥 Demo Video
[data:image/s3,"s3://crabby-images/29ae6/29ae660bd8ffe444a56d91be1f16a45c41a644db" alt="DocuWatch Demo"](https://www.youtube.com/watch?v=5giTCyTuFqc)
[Watch the full demo on YouTube](https://www.youtube.com/watch?v=5giTCyTuFqc)
## 🌟 Key Features
- **DocuSign Integration**: Seamless OAuth2 authentication and document retrieval using Docusign eSignature REST API
- **Intelligent Processing**: Automated contract analysis using OpenAI's assistant api and Microsoft's Semantic Kernel
- **Real-time Updates**: Webhook-based progress tracking for background tasks
- **Graph-based Knowledge**: Neo4j-powered contract relationship mapping
- **Interactive Chat**: Context-aware contract query system## 🛠️ Tech Stack
### Frontend
- **Next.js**
- **ShadcN UI**
- **Tailwind**### Backend
- **Webhooks**: Real-time progress updates
- **FastAPI**
- **Microsoft Semantic Kernel**: Advanced LLM integration
- **OpenAI**
- **Neo4j**: Graph database for contract relationships
- **Docusign eSignature REST API**: Document handling and OAuth2## 📦 Project Structure
```
.
├── apps/
│ ├── frontend/ # Next.js frontend application
│ └── backend/ # FastAPI backend application
├── package.json # Root package.json for monorepo
└── pnpm-workspace.yaml # PNPM workspace configuration
```
## 📦 Backend Structure
```
.
├── api/ # API routes and endpoints
├── core/ # Core application logic and configurations
├── data/ # Database interactions (can be moved to a cloud storage)
├── schemas/ # Schemas and validators
├── services/ # Business logic services
│ ├── ai/ # AI-related services
│ │ ├── llm/ # Language model implementations
│ │ ├── neo4j/ # Neo4j database services
│ │ ├── orchestration/ # Service orchestration logic
│ │ └── prompts/ # LLM prompt templates
│ ├── document/ # Document processing services
│ │ ├── stream.py # Document streaming functionality
│ │ └── downloader.py # Document download handlers
│ ├── docusign/ # DocuSign integration services
│ │ ├── auth.py # Authentication handlers
│ │ └── envelope.py # Envelope management
│ ├── notification/ # Notification services
│ │ └── webhook.py # Webhook handlers
│ └── tracking/ # Progress tracking services
│ ├── batch_progress.py # Batch progress tracking
│ └── progress.py # General progress tracking
├── utils/ # Utility functions and helpers
```## 🔄 Process Flow
1. **Authentication**
- OAuth2-based DocuSign login
- Access token and account ID retrieval2. **Document Processing**
- Downloads completed agreements (past 3 days)
- Converts PDFs to structured JSON
- Builds graph relationships3. **Analysis Features**
- Contract parties identification
- Risk assessment
- Obligation tracking
- Governing law analysis
- Industry pattern recognition## 🤖 ChatBot Capabilities
The system includes a sophisticated chatbot that:
- Leverages graph database for contextual awareness
- Provides precise contract-specific answers
- Understands relationships between different agreements
- Offers insights based on historical patterns## 📋 API Documentation
### Authentication Endpoints
```python
GET /login # Initiate DocuSign OAuth flow
GET /callback # Handle OAuth callback
```### Chat Endpoints
```python
POST /chat/ # Send message and get AI response
DELETE /chat/history # Clear chat history for current user
```### Envelope/Document Endpoints
```python
GET /envelopes/ # Get completed envelopes and trigger processing
GET /envelopes/json_files # Get processed JSON files
GET /envelopes/{envelope_id}/documents # List envelope documents
GET /envelopes/{envelope_id}/documents/{document_id}/download # Download document
```## 💻 Development Setup
### Prerequisites
- PNPM package manager
- Poetry (Python dependency management)```bash
cd docusign-contract-analysis# Install dependencies (both frontend and backend)
pnpm run monorepo-setup# Set up environment variables
cp apps/backend/.env.example apps/backend/.env
cp apps/frontend/.env.example apps/frontend/.env# Start development servers
pnpm run dev # Starts both frontend and backend servers
```## 🔑 Environment Variables
see `.env.example` inside
- apps/frontend/
- apps/backend/## 📝 License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.