Splunk Power Client (SPC) is a Python module that provides spc command line to simplify the day-to-day tasks of Splunk users and administrators.
Project description
Splunk Power Client
A modern, scriptable command-line client for Splunk power users and administrators.
spc is a Python CLI that streamlines day-to-day Splunk operations — uploading lookups, managing saved searches, dispatching jobs, editing configurations — through a fast, scriptable, multi-instance command line.
📚 Documentation · 📝 Changelog · 🤝 Contributing
[!WARNING] 🚧 Work in progress —
spcis still under active development. Expect breaking changes, rough edges, and bugs. Use it with caution in production environments — and please open an issue if you hit one.
Features
- Lookups — Upload from CSV, JSON, or Excel into Lookup CSV or KVStore. Synchronise a lookup from one Splunk instance to another in a single command.
- Saved searches — Reschedule in bulk, dispatch in the past with trigger actions (replay), or backfill over an arbitrary time window.
- Jobs — List, inspect, and manage search jobs.
- Configurations — Update Splunk configuration files quickly.
- Users — Create multiple local users from a definition file.
- Secrets — Manage Splunk secrets safely.
- Ingest — Stream events into Splunk programmatically.
- Multi-instance — Switch seamlessly between Splunk environments (dev / staging / prod) from a single profile-aware configuration.
Installation
# As a standalone tool
uv tool install splunk-power-client
# Or with pip
pip install splunk-power-client
Requires Python 3.13+.
Quickstart
# Discover commands
spc --help
# Manage instances (add / list / update / remove)
spc instances --help
# Show the active Splunk instance and its details
spc info
For the full command reference, examples, and recipes, see the documentation.
Commands
| Command | Status | What it does |
|---|---|---|
instances |
✅ | Add, list, and switch between Splunk instances |
info |
✅ | Show details of the active Splunk instance |
lookups |
✅ | Upload, synchronise, list, delete CSV / KVStore lookups |
secrets |
✅ | Manage Splunk secrets |
jobs |
✅ | List and inspect search jobs |
debug/refresh |
✅ | Refresh Splunk configuration without restart |
searches |
🚧 | Reschedule, dispatch, replay saved searches |
configs |
🚧 | Bulk-update Splunk configuration files |
users |
🚧 | Create multiple local users |
ingest |
🚧 | Stream events into Splunk |
Legend: ✅ available · 🚧 work in progress
Development
This project uses uv for everything — dependency management, building, publishing.
git clone https://github.com/nicolas-rdgs/Splunk-Power-Client.git
cd Splunk-Power-Client
uv sync --all-extras --dev
uv run pre-commit install
uv run pre-commit install --hook-type commit-msg
Common commands:
uv run ruff check . # lint
uv run ruff format --check . # format check
uv run pytest # tests
uv run mkdocs serve # preview docs locally
uv build # build wheel + sdist
The full contribution flow — Conventional Commits, PR conventions, and the automated release pipeline — is documented in CONTRIBUTING.md.
Development methodology
The core architecture, feature design, and the bulk of spc are written by hand. AI assistance (Claude, by Anthropic) is used deliberately and under human review to accelerate well-defined, lower-creativity work and to drastically improve quality and reduce development time. Concretely, AI helps with:
- Refactoring and naming consistency
- Scaffolding repetitive code (model definitions, command boilerplate)
- Improving test coverage and edge-case handling
- Writing and polishing documentation
- Setting up and maintaining the CI/CD pipeline
Every change goes through a Pull Request and a human review before reaching main. Nothing is committed unreviewed.
Release process
Releases are fully automated. Merging a Pull Request with a Conventional Commits-formatted title to main triggers:
- Test —
ruff check,ruff format --check,pytest --cov - Version — python-semantic-release decides the next SemVer, updates
pyproject.tomlandCHANGELOG.md, tagsvX.Y.Z - Build & publish —
uv build, thenuv publish --trusted-publishing always(OIDC, no long-lived tokens) - GitHub Release — with the changelog section and a Contributors list
See CONTRIBUTING.md for the human side of this flow.
Acknowledgements
Built on Splunk Enterprise SDK for Python, Typer, Pydantic, Rich, and uv.
License
Released under the MIT License — © 2025 Nicolas Rodrigues.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file splunk_power_client-0.1.2.tar.gz.
File metadata
- Download URL: splunk_power_client-0.1.2.tar.gz
- Upload date:
- Size: 9.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e7ba6ed4b2212bbdfb6797060b18a1a53cd7196d210001bb8c5f6d24f330b84c
|
|
| MD5 |
28469008991d894de7eacd5d8fef4d85
|
|
| BLAKE2b-256 |
3d7e9bf773f66ed891cdb8e70688dccec1813430d2ea74e666210eacc247d456
|
File details
Details for the file splunk_power_client-0.1.2-py3-none-any.whl.
File metadata
- Download URL: splunk_power_client-0.1.2-py3-none-any.whl
- Upload date:
- Size: 55.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
352792fcfc880a68e84d6086a246dedb4377a7fe5c56e7ad41278274c3045b3d
|
|
| MD5 |
e5de995bbe64bba066934333ca8195c0
|
|
| BLAKE2b-256 |
1e12ef536060cf6d58c95a9f0133cc83c530e25d4a95a5dbe633902ccb036bed
|