Skip to main content

A comprehensive Python SDK for managing Marzban panel through its REST API

Project description

SARBAN

A comprehensive Python SDK for managing Marzban panel (Gozargah/Marzban) through its REST API.

📚 Documentation

Quick Reference

Complete Documentation

✨ Features

  • ✅ Complete API coverage for all Marzban endpoints
  • ✅ Admin management (create, modify, remove admins)
  • ✅ User management (CRUD operations, usage tracking)
  • ✅ Node management (add, modify, remove, reconnect nodes)
  • ✅ Core configuration and statistics
  • ✅ System statistics and monitoring
  • ✅ User template management
  • ✅ Subscription management
  • ✅ Comprehensive error handling
  • ✅ Type hints for better IDE support

🚀 Installation

pip install sarban

📦 Quick Start

from sarban import SARBAN
from sarban.errors import BadLogin

# Initialize the client
sb = SARBAN(
    full_address="https://your-marzban-panel.com:2087",
    https=True
)

# Login
try:
    sb.login("admin_username", "admin_password")
    print("Login successful!")
except BadLogin:
    print("Invalid credentials")

📖 API Categories

Authentication

  • login() - Authenticate and get access token

Admin Management

  • get_current_admin() - Get current authenticated admin
  • create_admin() - Create a new admin
  • get_admins() - Get list of admins
  • modify_admin() - Modify admin details
  • remove_admin() - Remove an admin
  • disable_all_active_users() - Disable all active users under admin
  • activate_all_disabled_users() - Activate all disabled users under admin
  • reset_admin_usage() - Reset admin usage
  • get_admin_usage() - Get admin usage statistics

User Management

  • get_client() - Get user by username
  • get_client_by_subLink() - Get user by subscription token
  • add_client() - Add a new user
  • edit_client() - Modify existing user
  • delete_client() - Remove a user
  • get_users() - Get list of users with filters
  • reset_user_data_usage() - Reset user data usage
  • revoke_user_subscription() - Revoke user subscription
  • get_user_usage() - Get user usage statistics
  • active_next_plan() - Activate next plan for user
  • set_owner() - Set owner (admin) for user
  • reset_users_data_usage() - Reset all users data usage
  • get_users_usage() - Get all users usage statistics
  • get_expired_users() - Get expired users
  • delete_expired_users() - Delete expired users

Node Management

  • get_node_settings() - Get node settings
  • add_node() - Add a new node
  • get_node() - Get node by ID
  • get_nodes() - Get all nodes
  • modify_node() - Modify node details
  • remove_node() - Remove a node
  • reconnect_node() - Reconnect a node
  • get_usage() - Get nodes usage statistics

Core Management

  • get_core_stats() - Get core statistics
  • restart_core() - Restart the core
  • get_core_config() - Get core configuration
  • modify_core_config() - Modify core configuration

System Management

  • get_system_stats() - Get system statistics
  • get_inbounds() - Get inbound configurations
  • get_hosts() - Get proxy hosts
  • modify_hosts() - Modify proxy hosts

User Template Management

  • add_user_template() - Add a new user template
  • get_user_templates() - Get list of user templates
  • get_user_template() - Get user template by ID
  • modify_user_template() - Modify user template
  • remove_user_template() - Remove user template

Subscription Management

  • user_subscription() - Get user subscription
  • user_subscription_info() - Get subscription info
  • user_get_usage() - Get subscription usage
  • user_subscription_with_client_type() - Get subscription by client type

🔧 Error Handling

The SDK provides comprehensive error handling:

from sarban.errors import (
    BadLogin,
    Unauthorized,
    Forbidden,
    NotFound,
    Conflict,
    BadRequest,
    ValidationError,
    HTTPException
)

try:
    user = sb.get_client(username="nonexistent")
except NotFound:
    print("User not found")
except Unauthorized:
    print("Not authenticated")
except Forbidden:
    print("Access denied")

🔗 Subscription Link Generator

from sarban.sub_gen import sub_generator

subscription_link = sub_generator(
    userToken="token",
    fullAddress="sub.example.com:2096",
    verify=True
)

📝 Example Usage

from sarban import SARBAN

sb = SARBAN(full_address="https://panel.example.com:2087", https=True)
sb.login("admin", "password")

# Get all users
users = sb.get_users(limit=10)

# Add a new user
new_user = sb.add_client(
    username="test_user",
    inboundTag=["VLESS_INBOUND"],
    total_gb=10,
    expire_time=1735689600
)

# Get system stats
stats = sb.get_system_stats()
print(f"Total users: {stats['total_user']}")
print(f"Online users: {stats['online_users']}")

📄 License

MIT License

👤 Author

liwyd

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

🔗 Links

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

sarban-2.0.0.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

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

sarban-2.0.0-py3-none-any.whl (19.0 kB view details)

Uploaded Python 3

File details

Details for the file sarban-2.0.0.tar.gz.

File metadata

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

File hashes

Hashes for sarban-2.0.0.tar.gz
Algorithm Hash digest
SHA256 66dc97ed7d14577866f86e04c40fe702712974805a3950675232a9bd429c9c7d
MD5 807c776b29a0c2efb1beb07cbaf9201b
BLAKE2b-256 8cd13346c11a96560173a946676b78bc69b1c05d2416e97f64eb047472f552db

See more details on using hashes here.

File details

Details for the file sarban-2.0.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for sarban-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a02d07bb653e8a7a54d46766dedd016482f5ac3bcee41c8e4512585506d773de
MD5 3b88c0b9e619b48460fdc8669c55c677
BLAKE2b-256 503a74644abf0451dfa223dc78d6eef8077e4c676a40c58ddc8cf8678f844f09

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