Skip to main content

A professional Git-based Skill management library for LLM agents.

Project description

LLMRix Skill Plugin Library

llmrix-skill is a professional Git-based Skill and plugin management framework designed for LLM Agents. It encapsulates the complex logic of publishing, versioning, and syncing code, prompts, and tools into an out-of-the-box plugin library, allowing developers to focus on building core Agent logic.

Core Features

As the foundational plugin library for an Agent framework, it provides the following capabilities:

  • Git-Driven Plugin Market: Uses Git repositories as the Single Source of Truth (SSOT) to achieve skill persistence, version tracing, and change tracking.
  • Out-of-the-box Dual Mode Architecture:
    • Worker Mode (Execution): Pure lightweight synchronization, responsible for pulling skills from remote repositories to local storage for high-speed loading by Agent instances.
    • Management Mode (Admin): Integrates with databases to support multi-tenant authentication, skill publishing, metadata parsing, and version rollbacks.
  • Dynamic Metadata Parsing: Automatically parses and validates SKILL.md (YAML Frontmatter) in the skill package to extract the plugin name, description, and category.
  • Concurrency & Safety: Built-in distributed file lock mechanism to prevent file state race conditions during high-concurrency publishing and pulling.

Quick Usage Guide

Installation

You can integrate this plugin library into your Agent project via pip:

pip install llmrix-skill

Scene 1: Syncing Plugins on Agent Execution Node (Worker Mode)

In your Agent execution environment (such as background task nodes, or upon container startup), configure a specific branch to pull the latest skills for model invocation.

from llmrix.skill import GitSkillManager

def sync_skills_for_agent():
    # Initialize the Manager, configuring the remote repository and target branch
    manager = GitSkillManager(
        repo_url="https://github.com/your-org/skill-repo.git",
        branch="develop",                # Highly recommended: specify the branch to pull (e.g., main/develop/v1)
        workspace="/path/to/local/cache" # Local cache path
    )

    # Execute sync, returning the absolute filesystem path where the skills are located
    skills_path = manager.sync()
    print(f"✅ Skill plugins synced to: {skills_path}")
    
    # You can now dynamically load modules under skills_path in your Agent framework

Scene 2: Web Server Management & Publishing (Management Mode)

In your Web API service (such as FastAPI/Django plugin market backend), use GitSkillManager to handle user uploads, publishing, and version rollbacks. It encapsulates database persistence and concurrent file locking.

from llmrix.skill import GitSkillManager
from llmrix.skill import MySQLStorage

# 1. Configure the database adapter
def get_db_connection():
    # Return a pymysql/MySQLdb connection object
    pass

storage = MySQLStorage(connection_factory=get_db_connection)

# 2. Initialize the Manager, dedicated for the management end
manager = GitSkillManager(
    repo_url="git@github.com:your-org/skill-repo.git",
    storage=storage
)

# 3. Publish user-uploaded skills
def publish_user_skill(user_id, uploaded_dir):
    skill = manager.publish(
        code="python_interpreter",      # Unique skill code
        source_dir=uploaded_dir,        # Unzipped directory uploaded by the user
        user_id=user_id,                # Current operating user ID (for auth)
        message="Initial release"       
    )
    print(f"🚀 Publish successful: {skill.name} v{skill.version}")

# 4. Version Rollback
def rollback_skill(user_id):
    skill = manager.rollback(
        code="python_interpreter",
        target_version=1,
        user_id=user_id,
        message="Revert due to bugs"
    )

Skill Package Specification

A standard skill plugin package is a directory containing the following files:

my_awesome_skill/
├── SKILL.md      # Skill description and metadata (Required)
├── main.py       # Core logic (Recommended)
└── requirements.txt # Dependencies (Optional)

SKILL.md must contain a valid YAML Frontmatter header:

---
name: Web Scraper Pro
description: Powerful web scraping tool, supports dynamic rendering.
category: Web & Search
---

Detailed Markdown documentation about this skill goes here...

Module Architecture

You can directly import the required submodules for lower-level extensions:

  • llmrix.skill.services: Contains GitSkillManager, SkillPublisher, and SkillSyncer.
  • llmrix.skill.storage: Contains BaseStorage and MySQLStorage. Inherit BaseStorage to implement your own MongoDB or PostgreSQL adapters.
  • llmrix.skill.git: Low-level Git driver library GitRepository.
  • llmrix.skill.models: Data models Skill and SkillVersion.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

llmrix_skill-0.2.1.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

llmrix_skill-0.2.1-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file llmrix_skill-0.2.1.tar.gz.

File metadata

  • Download URL: llmrix_skill-0.2.1.tar.gz
  • Upload date:
  • Size: 18.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for llmrix_skill-0.2.1.tar.gz
Algorithm Hash digest
SHA256 f302c50ed9e4e3f7274ed5c59b09f750f7090616a25bf80f3db75d6e61672dd8
MD5 2e387edc618a5e319f5db7ef752c9321
BLAKE2b-256 db0ceb767835dd51d1e5cfa409fe35e6de6d028373eefe768e141827d0dff57a

See more details on using hashes here.

File details

Details for the file llmrix_skill-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: llmrix_skill-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 22.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for llmrix_skill-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bc0206f58c6e1ec9bc5f99cf6f134fd36672437c57308b0e3048bdfb70e125eb
MD5 5018b44f103388c1e8541664ffd8a5dc
BLAKE2b-256 7743ce4a275db10693f3d6895cb4d576caf95ab892875b88959b7c112ed16cba

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page