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.1.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.1-py3-none-any.whl (19.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: sarban-2.0.1.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.1.tar.gz
Algorithm Hash digest
SHA256 5ab562bb623500bee1dfbdde145b3318bb36425fc90dabcdb4f7b67c94ae5737
MD5 2d247c0bbca6483f4f67b7c429cab724
BLAKE2b-256 49ada15a657090b7df9413cc2dba9f18a86391e2b8f6aaf427241c1772bf0b94

See more details on using hashes here.

File details

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

File metadata

  • Download URL: sarban-2.0.1-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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d895191c261af56f560f0b64dcb4a56a26724934376eedacca9a1a9b89d6af35
MD5 9d0713db21c6d6a137a6a4ea950ea47a
BLAKE2b-256 792ca7b653e1876d9b628dacb4b262cc2897ec29f52602a96cc1395406ec49b6

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