The official framework for developing and testing Splunk SOAR Apps
Project description
Splunk SOAR SDK - the official tool for Splunk SOAR app development
Documentation
Detailed documentation can be found here
Installation
The Splunk SOAR SDK is available as a package on PyPI.
The recommended installation method is via uv.
Find us at .conf25
To learn more about the SDK, check out our (presentation slides)[https://conf.splunk.com/files/2025/slides/DEV1495.pdf] from .conf25!
Installing the SDK as a tool
This package defines the soarapps command line interface. To use it, install as a uv tool:
uv tool install splunk-soar-sdk
soarapps --help
Quick Start
Create a new, empty app: Run soarapps init.
Migrate an existing app to the SDK: Run soarapps convert myapp, where myapp is your app written using BaseConnector. This will convert asset configuration, action declarations, and inputs and outputs. You'll still need to re-implement your action code, as well as any custom views and webhooks.
Getting Help
If you need help, please file a GitHub issue at https://github.com/phantomcyber/splunk-soar-sdk/issues.
Installing the SDK as an app dependency
When developing a new Splunk SOAR app using the SDK, you should use uv as your project management tool:
uv add splunk-soar-sdk
Running the above command will add splunk-soar-sdk as a dependency of your Splunk SOAR app, in your pyproject.toml file.
Usage
In order to start using SDK and build your first Splunk SOAR App, follow the Getting Started guide.
A Splunk SOAR app developed with the SDK will look something like this:
Project structure:
string_reverser/
├─ src/
│ ├─ __init__.py
│ ├─ app.py
├─ tests/
│ ├─ __init__.py
│ ├─ test_app.py
├─ .pre-commit-config.yaml
├─ logo.svg
├─ logo_dark.svg
├─ pyproject.toml
With app.py containing:
from soar_sdk.abstract import SOARClient
from soar_sdk.app import App
from soar_sdk.asset import AssetField, BaseAsset
from soar_sdk.params import Params
from soar_sdk.action_results import ActionOutput
class Asset(BaseAsset):
base_url: str
api_key: str = AssetField(sensitive=True, description="API key for authentication")
app = App(name="test_app", asset_cls=Asset, appid="1e1618e7-2f70-4fc0-916a-f96facc2d2e4", app_type="sandbox", logo="logo.svg", logo_dark="logo_dark.svg", product_vendor="Splunk", product_name="Example App", publisher="Splunk")
@app.test_connectivity()
def test_connectivity(soar: SOARClient, asset: Asset) -> None:
soar.debug(f"testing connectivity against {asset.base_url}")
class ReverseStringParams(Params):
input_string: str
class ReverseStringOutput(ActionOutput):
reversed_string: str
@app.action(action_type="test", verbose="Reverses a string.")
def reverse_string(
param: ReverseStringParams, soar: SOARClient
) -> ReverseStringOutput:
reversed_string = param.input_string[::-1]
return ReverseStringOutput(reversed_string=reversed_string)
if __name__ == "__main__":
app.cli()
Requirements
- uv
- Python >=3.9
- Python may be installed locally with uv
- Splunk SOAR >=6.4.0
- You can get Splunk SOAR Community Edition from the Splunk website
Copyright 2025 Splunk Inc.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
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_soar_sdk-3.22.0.tar.gz.
File metadata
- Download URL: splunk_soar_sdk-3.22.0.tar.gz
- Upload date:
- Size: 668.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.11 {"installer":{"name":"uv","version":"0.11.11","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 |
043766171cccd1575401a91b8f21692a8bee0941b70524ec03d3f5a66cf42ec7
|
|
| MD5 |
2123ad822a9948e9cec52bd62bbcbaa9
|
|
| BLAKE2b-256 |
e9615e98faf1b5afb4c9b160614dad43d97d783fe04e2965e8469cf72481997c
|
File details
Details for the file splunk_soar_sdk-3.22.0-py3-none-any.whl.
File metadata
- Download URL: splunk_soar_sdk-3.22.0-py3-none-any.whl
- Upload date:
- Size: 209.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.11 {"installer":{"name":"uv","version":"0.11.11","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 |
e47772265c4d16d6eaf1ae1720fcd938f1a8d53f7abacf939a64d30e9b7939f4
|
|
| MD5 |
d6aa913d612c6e5dc5ee3e2a17cca30c
|
|
| BLAKE2b-256 |
2d23d4a5c25bd1fc698a6ff5a5048d9a91c2bd357120abd2a6520985ff96404f
|