Skip to content
@gitset-dev

Gitset.dev

A comprehensive suite of AI-driven tools that enhances your GitHub development experience.


GitSet.dev is a comprehensive suite of AI-driven tools that enhances your GitHub development experience. It provides solutions for streamlined repository management, precise versioning, and clear documentation. Built with Astro.js/React.js, and integrating 8 Python-based backends (FastAPI and Flask), it combines AI-powered suggestions with user-requested improvements, continuously refining results to deliver optimized outcomes. It offers both public utilities and authenticated services to streamline repository management, documentation, version control tasks and more.


GitSet.dev Preview

Core Features

Encompasses various features, including:

Public Tools (No Authentication Required):

  • Public AI-Readme Generator: Generates a README.md for any public repository from any Github user using AI. (Flask)
  • .gitignore Builder: Crafts customized .gitignore files by selecting multiple languages and frameworks and tools.

Authenticated Services::

  • Personal AI-Readme Generator: Generates a README.md for any public or private repository of the authenticated user.
  • Commit Messages Generator: Suggests semantic or custom commit messages for local staged Git files.- Gitset CLI required.
  • Tags & Releases Manager: Streamline version control management with AI-driven release note suggestions and user-requested improvements.
  • Code Decommenter: Removes specific types of comments from code while preserving functionality, supporting most major programming languages.
  • Repository Assessment Tool: Provides detailed evaluations and effort breakdowns for established repositories.

Technical Architecture

Based on a modular, service-oriented architecture, it employs distinct service layers to manage client requests, authentication, AI-driven processing, content aggregation, and improvement handling. The design follows best practices for scalability, performance, and security, ensuring a clear separation of concerns between public and protected services.

graph TD
    %% Entry Points
    client[Client Request] --> frontend[Frontend Service - Astro SSR]
    frontend --> authGateway{Authentication Gateway}

    %% Authentication Flow
    subgraph authService[Authentication Service]
        direction TB
        drizzleDB[(Drizzle ORM)]
        githubOAuth[GitHub OAuth Provider]
        sessionMgr[Session Manager]
    end
    
    authGateway -->|Requires Auth| drizzleDB
    drizzleDB --> githubOAuth
    githubOAuth --> sessionMgr
    
    %% Protected Services
    subgraph protectedServices[Protected Services Layer]
        direction LR
        readmeGen[AI-Readme Generator React Component]
        commitGen[Commit Message Generator React Component]
        releaseMgr[Tags & Release Manager React Component]
        repoAnalytics[Repository Assessment React Component]
        decommenterService[Code Decommenter React Component]
    end
    
    sessionMgr -->|Authenticated Session| protectedServices
    
    %% CLI Layer for Tags & Releases
    subgraph cliLayer[CLI Processing Layer]
        direction TB
        gitsetCLI[GitSet CLI Node.js Runtime]
    end

    %% AI Processing for Protected Services (Backend)
    subgraph aiProcessing[AI Processing Backend Layer]
        direction TB
        geminiAI1[Python and Gemini AI Service Backend]
        geminiAI2[Python and Gemini AI Service Backend]
        geminiAI3[Python and Gemini AI Service Backend]
        geminiAI4[Python and Gemini AI Service Backend]
        geminiAI5[Python and Gemini AI Service Backend]
    end
    
    readmeGen --> geminiAI1
    commitGen --> geminiAI2
    releaseMgr --> gitsetCLI
    gitsetCLI -->|Command Processing| geminiAI3
    repoAnalytics --> geminiAI4
    decommenterService --> geminiAI5
    
    %% Public Services Flow
    authGateway -->|Public Access| publicServices[Public Services Layer]
    
    subgraph publicLayer[Public Layer]
        direction TB
        githubAPI[GitHub API Service]
        publicReadme[Public Readme Generator React Component]
        gitignoreService[.gitignore Builder React Component]
        publicAI[Python and Gemini AI Service Backend]
        pythonService[Python Service Backend]
    end
    
    publicServices --> publicLayer
    publicReadme --> publicAI
    gitignoreService -->|Template Processing| pythonService
    
    %% Content Aggregation and Improvement Flow
    subgraph contentLayer[Content Aggregation Backend Layer]
        direction TB
        contentAggregator[Content Aggregator Service Backend]
        improvementHandler[Improvement Handler Service Backend]
    end
    
    aiProcessing --> contentAggregator
    publicAI --> contentAggregator
    pythonService --> contentAggregator
    contentAggregator --> frontend
    frontend -->|User Improvement Request| improvementHandler
    improvementHandler -->|Refined Content Request| contentAggregator
Loading

View this graph in an interactive editor with zoom capabilities here.


Frontend Layer

  • Primary Entry Point: The frontend service, built on Astro SSR with React.js integration, acts as the main entry point for client requests. It handles user interaction, manages content rendering, and coordinates with both public and protected service layers for data delivery.
  • Responsibilities:
    • State management and content rendering
    • User authentication and session handling
    • Interaction with public and protected services for data access

Authentication System

  • Authentication Gateway:

    • Functions as the security checkpoint, routing requests based on the authentication status of users.
    • Enforces access control policies and ensures secure request handling by interfacing with the authentication service.
  • Authentication Service:

    • Utilizes Drizzle ORM for database interaction, providing persistent storage for user data.
    • Integrates GitHub OAuth for user authentication, managing session tokens and ensuring secure user identification.
    • The session manager is responsible for managing the lifecycle of user sessions.

CLI Processing Layer

  • GitSet CLI:
    • Node.js-based command-line interface that acts as an intermediary processing layer
    • Handles command interpretation and execution for the Tags & Release Manager
    • Provides local environment integration for version control operations
    • Facilitates secure communication between the frontend interface and AI backend services
    • Processes Git commands and metadata before sending to the AI service for analysis

Protected Services Layer

This layer comprises five core services, which require authentication:

  1. AI-Readme Generator Service:

    • Utilizes Gemini AI to generate detailed, context-aware README files.
  2. Commit Message Generator Service:

    • Leverages contextual analysis via Gemini AI to automate commit message creation.
  3. Tags & Release Manager Service:

    • Manages version control, automatic release note generation, and tagging.
  4. Repository Assessment Service:

    • Provides repository health assessments, analyzing various metrics and insights, powered by Gemini AI.
  5. Code Decommenter Service:

    • Processes and removes specified types of comments from source code.
    • Supports multiple comment types: single-line, multi-line, documentation, and pragma comments.
    • Provides clean, formatted output for manual implementation.
    • Ensures code functionality remains intact while removing unnecessary documentation.

AI Processing Backend Layer

  • This layer implements parallelized AI processing through multiple instances of the Gemini AI backend, with each instance dedicated to specific tasks (e.g., README generation, commit message generation, release management, repository assessment, code comment removal).
  • The backend processes requests efficiently and in parallel, ensuring scalability and performance.
  • Each service maintains its own AI processing pipeline to prevent interference and optimize response times.

Public Services Layer

The public services layer is accessible without authentication, providing the following functionalities:

  1. GitHub API Service:

    • Handles GitHub integration, offering a public access endpoint for interacting with GitHub repositories.
  2. Public Readme Generator:

    • A simplified version of the README generation service, using the public AI backend to generate basic readme files.
  3. .gitignore Builder Service:

    • Generates .gitignore files based on predefined templates, with processing handled by the Python backend.
  4. Support Services:

    • Includes public-facing AI processing through the Gemini backend and Python services for template-based tasks.

Content Management Layer

  • Content Aggregator Service:

    • Collects content from various sources (AI processing, public services, and Python backend) and normalizes it into a unified format.
    • Facilitates content fusion, formatting, and preparation for frontend delivery.
  • Improvement Handler Service:

    • Manages user-generated improvement requests, coordinating with the content aggregator to refine and iterate on content.

Data Flow and Technical Considerations

The system is designed to efficiently handle user requests while maintaining security, performance, and scalability.

Authentication Flow

  1. The client makes an initial request, which is handled by the frontend service.
  2. The frontend routes the request through the authentication gateway to determine if the user is authenticated.
  3. Upon successful authentication, the user session is established, and the user is granted access to the protected services layer.

Service Flow (Protected and Public)

  • Protected Services: Once authenticated, users can access the protected services. These services interact with their dedicated Gemini AI backend for specific tasks (e.g., managing tags & releases, generating commit messages, removing code comments). The backend processes the requests and returns aggregated results to the frontend.

  • Public Services: These services, which do not require authentication, process user requests and send the output through the aggregation layer. The content is then delivered to the frontend.

Content Aggregation and Improvement Flow

  1. Content is generated through the AI processing units or public services and is aggregated by the content aggregator.
  2. User requests for improvements are routed to the improvement handler, which works with the content aggregator to refine and iterate the content based on user feedback.
  3. The refined content is then sent back to the frontend for presentation to the user.

Technical Considerations

  • Scalability: The system ensures horizontal scalability with independent scaling of AI processing units, as well as the distributed handling of public and protected service layers. Each layer can scale independently based on demand.

  • Security: The authentication gateway serves as the primary security checkpoint, ensuring that only authenticated requests can access protected services. OAuth-based authentication ensures secure user identification and session management.

  • Performance: The use of parallel AI processing, combined with a robust content aggregation system, ensures that the system can efficiently process and deliver content. The public and protected services are optimized for minimal latency.

  • Integration Points:

    • Integration with GitHub for authentication and API access.
    • Gemini AI services for advanced content generation and analysis.
    • Python backend for template-based processing.
    • SSR frontend ensures dynamic rendering of content based on user interaction.

Frontend Installation

  1. Clone the repository:

    git clone https://github.com/imprvhub/gitset.git
  2. Navigate to the project directory:

    cd gitset
  3. Install the required dependencies:

    npm install

Usage

  1. Run npm run dev to start the development server.
  2. Access the application in your browser at http://localhost:4321.

Frontend Dependencies

  • Astro: A static site generator with server-side rendering capabilities.
  • React: A JavaScript library for building user interfaces.
  • TypeScript: A superset of JavaScript that adds optional static typing.
  • lucide-react: A set of customizable SVG icons for React.
  • react-icons/fa: A set of Font Awesome icons for React.
  • diff: A library for generating unified diffs.

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

For more information regarding this topic please read the following Terms and Conditions Section.

Pinned Loading

  1. gitset gitset Public

    Forked from imprvhub/gitset

    Gitset.dev is a comprehensive suite of AI-driven tools that enhances your GitHub development experience. Built on Astro.js/React.js integrating 8 Python-based backends (FastAPI - Flask) with AI la…

    Astro

  2. gitset-cli gitset-cli Public

    gitset-cli is AI-powered CLI tool that generates semantic commit messages by analyzing your staged changes. Save time and maintain consistency in your Git workflow with intelligent, context-aware c…

    JavaScript 1

Repositories

Showing 3 of 3 repositories
  • gitset-cli Public

    gitset-cli is AI-powered CLI tool that generates semantic commit messages by analyzing your staged changes. Save time and maintain consistency in your Git workflow with intelligent, context-aware commit suggestions.

    gitset-dev/gitset-cli’s past year of commit activity
    JavaScript 0 MPL-2.0 1 0 0 Updated Jan 21, 2025
  • gitset Public Forked from imprvhub/gitset

    Gitset.dev is a comprehensive suite of AI-driven tools that enhances your GitHub development experience. Built on Astro.js/React.js integrating 8 Python-based backends (FastAPI - Flask) with AI layers, it blends AI-powered suggestions with user-requested improvements, continuously refining results to deliver optimized outcomes.

    gitset-dev/gitset’s past year of commit activity
    Astro 0 1 0 0 Updated Jan 15, 2025
  • .github Public
    gitset-dev/.github’s past year of commit activity
    0 0 0 0 Updated Jan 13, 2025

Top languages

Loading…

Most used topics

Loading…