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

Uploaded Python 3

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

Hashes for splunk_power_client-0.1.2.tar.gz
Algorithm Hash digest
SHA256 e7ba6ed4b2212bbdfb6797060b18a1a53cd7196d210001bb8c5f6d24f330b84c
MD5 28469008991d894de7eacd5d8fef4d85
BLAKE2b-256 3d7e9bf773f66ed891cdb8e70688dccec1813430d2ea74e666210eacc247d456

See more details on using hashes here.

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

Hashes for splunk_power_client-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 352792fcfc880a68e84d6086a246dedb4377a7fe5c56e7ad41278274c3045b3d
MD5 e5de995bbe64bba066934333ca8195c0
BLAKE2b-256 1e12ef536060cf6d58c95a9f0133cc83c530e25d4a95a5dbe633902ccb036bed

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