The DASL client library used for interacting with the DASL workspace
Project description
DASL Client Library
The DASL (Databricks Antimatter Security Lakehouse) Client Library is a Python SDK for interacting with DASL services. This library provides an interface for interacting with DASL services, allowing you to manage datasources, rules, workspace configurations, and more from Databricks notebooks.
Features
- Simple Authentication: Automatic workspace detection in Databricks notebooks
- Datasource Management: Create, update, list, and delete datasources
- Rule Management: Define and manage security detection rules to identify threats
- Workspace Configuration: Update and retrieve DASL's workspace-level settings
Installation
Install from PyPI:
pip install dasl-client
Quick Start
Databricks Notebook Environment (Recommended)
The DASL client works best in Databricks notebooks with automatic authentication:
from dasl_client import Client
# Automatically detects Databricks context and authenticates
client = Client.for_workspace()
print("Connected to DASL!")
# List existing datasources
print("Existing datasources:")
for datasource in client.list_datasources():
print(f" - {datasource.metadata.name}")
# List detection rules
print("Existing detection rules:")
for rule in client.list_rules():
print(f" - {rule.metadata.name}")
Creating a Datasource
from dasl_client import DataSource, Schedule, BronzeSpec, SilverSpec
# Create a new datasource
datasource = Datasource(
source="aws",
source_type="cloudtrail",
autoloader=Autoloader(
enabled=True,
schedule=Schedule(
at_least_every="1h",
enabled=True
)
),
bronze=BronzeSpec(
bronze_table="security_logs_bronze",
skip_bronze_loading=False
),
silver=SilverSpec(
# Configure silver layer here, see the API reference for more details
),
gold=GoldSpec(
# Configure gold layer here, see the API reference for more details
)
)
# Create the datasource
created_datasource = client.create_datasource(datasource)
print(f"Created datasource: {created.metadata.name}")
Creating a Detection Rule
from dasl_client.types import Rule, Schedule
# Create a new detection rule to detect failed logins
rule = Rule(
schedule=Schedule(
at_least_every="2h",
enabled=True,
),
input=Rule.Input(
stream=Rule.Input.Stream(
tables=[
Rule.Input.Stream.Table(name="http_activity"),
],
filter="disposition = 'Blocked'",
starting_timestamp=datetime(2025, 7, 8, 16, 47, 30),
),
),
output=Rule.Output(
summary="record was blocked",
),
)
try:
created_rule = client.create_rule("Detect Blocked HTTP Activity", rule)
print(f"Successfully created rule: {created_rule.metadata.name}")
except Exception as e:
print(f"Error creating rule: {e}")
Requirements
- Python 3.8+
- Access to a Databricks workspace with DASL enabled
databricks-sdk>=0.41.0pydantic>=2
Documentation
For complete DASL Client documentation, examples, and API reference:
Support
- Email: support@antimatter.io
- Documentation: DASL Documentation
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 dasl_client-1.0.33.tar.gz.
File metadata
- Download URL: dasl_client-1.0.33.tar.gz
- Upload date:
- Size: 59.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3fc82c99876df35bbd200dab82a260cb741b2376b66883e2fbaf8b267f1fcf68
|
|
| MD5 |
a8e689e964d93c810fb6c356ccf8f811
|
|
| BLAKE2b-256 |
4a9ad3dc9613e76dcabd07a07d57f36ae45dbfa68a1d306abf37d317741c0197
|
File details
Details for the file dasl_client-1.0.33-py3-none-any.whl.
File metadata
- Download URL: dasl_client-1.0.33-py3-none-any.whl
- Upload date:
- Size: 67.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
64dc59ec2e8f472725fc61faccd0b004831c642c09cbbd3d2199c73c1cf53c66
|
|
| MD5 |
bb5f2126d1bf7b86355f68f5d4e3e0cf
|
|
| BLAKE2b-256 |
a6ab3961c4402645f60270b84306475d8b540b06b868b9040ff01a53678e520a
|