Python SDK for Dilnaka file uploads
Project description
Dilnaka Python SDK
Python SDK for uploading files through the Dilnaka Upload API.
The SDK reads configuration from explicit arguments first, then environment variables. It requests a presigned S3 upload URL from your Dilnaka backend, uploads the file directly to S3, and calls the completion endpoint.
Install
pip install dilnaka
Configure
You can pass configuration directly to Dilnaka(...), or set environment variables for your application.
Configuration precedence is:
- Explicit constructor arguments such as
Dilnaka(base_url=...) - Existing process environment variables such as
DILNAKA_BASE_URL - Values loaded from
.env - Built-in defaults
If you use a .env file, create it in your application project:
DILNAKA_API_KEY=dlk_dev_your_api_key_here
DILNAKA_BASE_URL=https://dilnaka.tsnc.tech
DILNAKA_TIMEOUT=60
DILNAKA_BASE_URL defaults to https://dilnaka.tsnc.tech and DILNAKA_TIMEOUT defaults to 60.
Basic upload
from dilnaka import Dilnaka
client = Dilnaka()
uploaded = client.upload("./test-upload.txt")
print(uploaded.id)
print(uploaded.key)
print(uploaded.status)
Explicit configuration
from dilnaka import Dilnaka
client = Dilnaka(
api_key="dlk_dev_your_api_key_here",
base_url="https://dilnaka.tsnc.tech",
)
uploaded = client.upload("./avatar.png", folder="avatars")
print(uploaded)
Expected backend endpoints
The SDK expects your Caspian backend to expose:
POST /v1/uploads/presign
POST /v1/uploads/complete
GET /v1/files
GET /v1/files/{file_id}
DELETE /v1/files/{file_id}
Presign response shape
{
"fileId": "clx_file_id",
"fileKey": "uploads/2026/05/clx_file_id-test.txt",
"uploadUrl": "https://s3-presigned-url",
"expiresIn": 300,
"method": "PUT",
"headers": {
"Content-Type": "text/plain"
}
}
Complete response shape
{
"fileId": "clx_file_id",
"status": "uploaded",
"key": "uploads/2026/05/clx_file_id-test.txt",
"originalName": "test.txt",
"contentType": "text/plain",
"size": 94,
"publicUrl": null
}
Security model
The SDK never receives AWS credentials. It only receives a temporary presigned upload URL from your Dilnaka backend.
Your backend remains responsible for API key validation, scope checking, file validation, S3 key generation, metadata persistence, and upload completion verification.
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
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 dilnaka-0.0.6.tar.gz.
File metadata
- Download URL: dilnaka-0.0.6.tar.gz
- Upload date:
- Size: 22.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d15888b95a9539b195c142c736faaad51850d03faef7f2e4038240e8e6f975e4
|
|
| MD5 |
86a7baf71dc6d02818b2f71cb482e249
|
|
| BLAKE2b-256 |
d4341439a37da1d14a34815bf04d8701e5b86853f4a1560ee097d9391b1f4a55
|
File details
Details for the file dilnaka-0.0.6-py3-none-any.whl.
File metadata
- Download URL: dilnaka-0.0.6-py3-none-any.whl
- Upload date:
- Size: 6.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f4a5fe55a477f28001edfbfe80727f398baaf55943541aa9aaab3aa577f70668
|
|
| MD5 |
484ee25852b8eaf5f37cdf79406591ff
|
|
| BLAKE2b-256 |
a5f7bac6c98f89711e6720e294100f7b6c895f7824e94cf88c6dd243cb6b36f2
|