pysisense is a Python SDK designed for seamless and structured interaction with the Sisense API.
It simplifies complex API operations and allows you to automate and manage users, groups, dashboards, data models, and more.
✅ Built for automation, debugging, and extensibility.
You can install pysisense from PyPI:
pip install pysisenseFor local development, install in editable mode:
pip install -e .Create one or more YAML files (use the templates in examples/ as reference only):
config.yaml– for single-environment operationssource.yamlandtarget.yaml– for migration scenarios
Each file should follow this structure:
domain: "your-domain.com"
is_ssl: true
token: "<your_api_token>"Some methods in this SDK require full administrative privileges to interact with Sisense resources (such as ownership changes, user migrations, or folder/dashboard access).
To avoid permission-related issues or incomplete operations:
It is recommended to use a new dedicated Sisense admin user's token when authenticating via your config.yaml.
Using restricted or scoped users may result in failures or inconsistent behavior, especially for:
- Folder and dashboard ownership changes
- Granting permissions across environments
- System-wide migrations
The examples/ folder contains Markdown guides. Each guide explains common workflows and includes copy-pasteable code snippets you can adapt in your own project:
-
access_management_example.md
Identity & Governance — manage users, groups, folder access, and governance tasks (e.g., unused assets). -
datamodel_example.md
Data Modeling — work with datasets, tables, columns, and schema within Sisense data models. -
dashboard_example.md
Dashboard Lifecycle — retrieve, update, reassign ownership, and manage shares of dashboards. -
migration_example.md
Environment Migration — migrate users, dashboards, and data models across environments (e.g., dev → prod). -
wellcheck_example.md
Data Health & Complexity — run structural checks on dashboards and data models (widget counts, pivot fields, island tables, RLS datatypes, import queries, many-to-many relationships, unused columns, and unused columns).
Note: These guides are not meant to be executed end-to-end. Copy the relevant snippets into your own Python files or notebooks, update configuration (YAML paths, IDs, etc.), and run them in your environment.
All logs are saved automatically to a local folder:
logs/pysisense.log
You don’t need to create this folder manually — it will be created at runtime in the same directory where you run your scripts.
- 👥 User & Group Management – Create, update, delete, and fetch users or groups
- 📊 Dashboard Management – Export, share, and migrate dashboards
- 📦 Data Models – Explore, describe, and update schemas and security
- 🔐 Permissions – Resolve and apply share rules (users & groups)
- 🔄 Cross-Environment Migrations – Move dashboards, models, and users
- ✅ WellCheck – Analyze dashboard and data model health (structure complexity, widget density, pivot fields, island tables, RLS datatypes, import queries, many-to-many relationships, and unused columns)
- 🧠 Smart Logging & Data Helpers – Auto log capture, CSV export, and DataFrame conversion
- ➕ And many more – Refer to the documentation for full details
- Pythonic SDK with class-based structure (
Dashboard,DataModel,AccessManagement,Migration) - Additional analysis module:
WellCheck– Run dashboard and data model health checks (structure, complexity, and best-practice validations) - Modular YAML-based authentication
- Built-in logging and exception handling
- Designed for end-to-end automation and real-world use
📚 Documentation
Comprehensive module-level documentation is available in the docs/ folder:
- Index – Overview of the SDK structure and modules
- Sisense Client – Base API wrapper for all HTTP operations
- Access Management – Manage users, groups, roles, and permissions
- Data Model – Handle datasets, tables, schemas, security, and deployment
- Dashboard – Retrieve, modify, and share Sisense dashboards
- Migration – Migrate users, dashboards, and models between environments
- Utils – Helper functions for export, formatting, and data operations
- WellCheck – Run health checks on dashboards and data models (structure, complexity, and best-practice validations)
You can also explore:
- Inline method docstrings using
help()in Python or directly within your IDE.
This project is licensed under the Sisense End User License Agreement (EULA). See the LICENSE file for the full text.
© 2025 Sisense Ltd. “Sisense” and related marks are trademarks of Sisense Ltd.