Skip to main content

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.

PyPI Python License Tests Docs Code style: Ruff uv Conventional Commits semantic-release

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 progressspc is 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:

  1. Testruff check, ruff format --check, pytest --cov
  2. Versionpython-semantic-release decides the next SemVer, updates pyproject.toml and CHANGELOG.md, tags vX.Y.Z
  3. Build & publishuv build, then uv publish --trusted-publishing always (OIDC, no long-lived tokens)
  4. 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


Download files

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

Source Distribution

splunk_power_client-0.1.1.tar.gz (9.6 MB view details)

Uploaded Source

Built Distribution

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

splunk_power_client-0.1.1-py3-none-any.whl (55.2 kB view details)

Uploaded Python 3

File details

Details for the file splunk_power_client-0.1.1.tar.gz.

File metadata

  • Download URL: splunk_power_client-0.1.1.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

Hashes for splunk_power_client-0.1.1.tar.gz
Algorithm Hash digest
SHA256 9ea39915551f2551b344342a3cca50a078b89a428739722ef58ae0e12e387a7d
MD5 90a3e60d3b79b08203f4e3ef5b32dd04
BLAKE2b-256 4144ac784590de41bb1710c02f20179cc0bab2e8f02adbf60aa51598fc367722

See more details on using hashes here.

File details

Details for the file splunk_power_client-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: splunk_power_client-0.1.1-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

Hashes for splunk_power_client-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b5a052171d1f943b304a77cff8c6b5bb616c5074e74c44661aa2c903982ce145
MD5 7a078e377bce5777baa96724c7e549f8
BLAKE2b-256 924427725755de2de2579e8026e6ec31f7dc8b689640ad1bd52d8f6581c16ac6

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