Skip to main content

The official framework for developing and testing Splunk SOAR Apps

Project description

Splunk SOAR SDK - the official tool for Splunk SOAR app development

GitHub top language Python Version from PEP 621 TOML GitHub Actions Workflow Status Code Coverage GitHub Release PyPI - Version PyPI - Status PyPI - Types License

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

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

This version

3.3.2

Download files

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

Source Distribution

splunk_soar_sdk-3.3.2.tar.gz (535.0 kB view details)

Uploaded Source

Built Distribution

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

splunk_soar_sdk-3.3.2-py3-none-any.whl (169.5 kB view details)

Uploaded Python 3

File details

Details for the file splunk_soar_sdk-3.3.2.tar.gz.

File metadata

  • Download URL: splunk_soar_sdk-3.3.2.tar.gz
  • Upload date:
  • Size: 535.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.15 {"installer":{"name":"uv","version":"0.9.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_soar_sdk-3.3.2.tar.gz
Algorithm Hash digest
SHA256 94a0d85e71aeffcbdf01fe20ee37d98152eab5f970a54c5452f1ead13edb3a65
MD5 f0f6491013849b94389cb8013d5f6efa
BLAKE2b-256 e5be3ac6efe616bb7f58a4ed08e27aa9aad1db40392ec107c5fd66807089a06c

See more details on using hashes here.

File details

Details for the file splunk_soar_sdk-3.3.2-py3-none-any.whl.

File metadata

  • Download URL: splunk_soar_sdk-3.3.2-py3-none-any.whl
  • Upload date:
  • Size: 169.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.15 {"installer":{"name":"uv","version":"0.9.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_soar_sdk-3.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ab4db43dbabfd1288db709b374ce6592a96d4da585d66d6c70b164c6a2f00961
MD5 9930bb8b629233532e5bd2a336122395
BLAKE2b-256 cde1bd4f2265916fb03b897222d499f7a824817df8f317fb80bc5759c0c5cf24

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