Skip to main content

Yandex Dialogs Developer API client — programmatic skill creation, draft management, OAuth Device Flow

Project description

ya-dialogs-api

Async Yandex Dialogs Developer API client — programmatic skill creation, draft management, OAuth Device Flow.

CI PyPI Python 3.12+ License: MIT

What this is

A framework-agnostic Python library that drives the Yandex Dialogs Developer API — the meta-API at dialogs.yandex.ru/developer-api/v2/ used to programmatically create and manage Alice skills (Smart Home and custom dialog skills). Where every other Yandex Alice library on PyPI handles the runtime side (incoming webhook requests from end users), this one handles the provisioning side: sign in via Yandex Passport Device Flow, create a skill, upload a logo, set the webhook backend URL, publish a draft.

It exists because Yandex doesn't publish a developer-API SDK and the only known Python implementation lived inside the Music Assistant ma-provider-yandex-smarthome plugin. This library is that code, extracted and made generic.

Features

  • Full skill auto-creation pipeline — CSRF/cookie session → POST /apps → upload logo → PATCH draft → optional OAuth app creation → POST deploy.
  • Two channel typeschannel="smartHome" for Yandex Smart Home skills (always requires OAuth account-linking), channel="aliceSkill" for Alice custom dialog skills (OAuth-free or OAuth-attached).
  • Optional OAuthaliceSkill skills can be created without account-linking by omitting oauth_* params entirely. smartHome always requires all four.
  • Incremental state machineSkillCreationArtifacts snapshots progress after every step. On transient failure, retry resumes from the last completed step instead of restarting.
  • Typed errorsDialogsAuthError, DialogsValidationError, DialogsSkillNotFoundError, DialogsDuplicateSkillError with structured field info where available.
  • Framework-agnostic — caller produces an authenticated aiohttp.ClientSession (typically via ya-passport-auth) and wraps it in an AuthenticatorCM factory. No opinion on Device Flow UX.
  • Strictly typedmypy --strict clean, PEP 561 py.typed marker.
  • Security-awareSecretStr redacts tokens in repr/str/format/tracebacks (re-exported from ya-passport-auth).

Installation

pip install ya-dialogs-api

Quick start

Smart Home skill (OAuth required)

import asyncio
from contextlib import asynccontextmanager
from typing import AsyncIterator
import aiohttp
from ya_dialogs_api import (
    AuthenticatorCM,
    SMART_HOME_CHANNEL,
    SkillCreationArtifacts,
    SkillCreationState,
    auto_create_skill,
)

# Wrap your authenticated session in an async context-manager factory.
@asynccontextmanager
async def my_authenticator() -> AsyncIterator[aiohttp.ClientSession]:
    # Typically: ya_passport_auth.PassportClient.login_device_code(...)
    async with aiohttp.ClientSession(cookies={"Session_id": "..."}) as session:
        yield session

async def main() -> None:
    artifacts = SkillCreationArtifacts(state=SkillCreationState.NONE)
    result = await auto_create_skill(
        authenticator=my_authenticator,
        channel=SMART_HOME_CHANNEL,       # "smartHome"
        skill_name="My Smart Home",
        artifacts=artifacts,
        backend_uri="https://my-backend.example.com/yandex",
        oauth_authorize_url="https://my-backend.example.com/oauth/authorize",
        oauth_token_url="https://my-backend.example.com/oauth/token",
        oauth_client_id="my-client-id",
        oauth_client_secret="my-client-secret",
    )
    if result.state == SkillCreationState.DONE:
        print(f"Skill created: skill_id={result.skill_id}")
    else:
        print(f"Failed at step {result.state}: {result.last_error}")

asyncio.run(main())

Alice dialog skill (OAuth-free)

from ya_dialogs_api import DIALOG_CHANNEL, auto_create_skill

result = await auto_create_skill(
    authenticator=my_authenticator,
    channel=DIALOG_CHANNEL,               # "aliceSkill"
    skill_name="My Dialog Skill",
    artifacts=artifacts,
    backend_uri="https://my-backend.example.com/alice",
    description="A skill that does something useful",
    # oauth_* params omitted → no account-linking
)

Alice dialog skill with OAuth

Pass all four oauth_* params with channel="aliceSkill" to attach an OAuth application (account-linking). Partial sets raise ValueError synchronously.

Public API

Symbol Description
auto_create_skill(...) Full pipeline orchestrator. Resumable via SkillCreationArtifacts.
auto_update_skill(...) Patch a skill draft and re-deploy. Works for both channels.
DialogsSkillCreator Low-level client (one method per pipeline step, including delete_skill).
Channel Literal["smartHome", "aliceSkill"] — Yandex wire values.
SMART_HOME_CHANNEL / DIALOG_CHANNEL Typed constants for the two channels.
SkillCreationArtifacts / SkillCreationState State machine; serialize with dump_artifacts / load_artifacts.
AuthenticatorCM Protocol: no-arg async context-manager factory yielding aiohttp.ClientSession.
DialogsApiError (base) All library exceptions derive from this.
DialogsAuthError HTTP 401/403, HTML auth-wall, or 30x redirect to Passport.
DialogsCsrfError CSRF token not found in developer console HTML.
DialogsValidationError Domain-level field validation or Spring 4xx rejection.
DialogsSkillNotFoundError Spring 404 "Skill not found"; skill_id attribute set.
DialogsDuplicateSkillError Skill with this name already exists.
SecretStr Re-exported from ya-passport-auth for token redaction.
load_default_logo_bytes() Bundled 1024×1024 fallback skill logo.

Status

Stable (2.0.0). The public API is stable. The underlying Yandex dev-console endpoints are unofficial (reverse-engineered from DevTools traces) and may break without notice. The library is actively maintained against the current production endpoint behavior.

See also

License

MIT

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

ya_dialogs_api-2.3.0.tar.gz (113.5 kB view details)

Uploaded Source

Built Distribution

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

ya_dialogs_api-2.3.0-py3-none-any.whl (84.3 kB view details)

Uploaded Python 3

File details

Details for the file ya_dialogs_api-2.3.0.tar.gz.

File metadata

  • Download URL: ya_dialogs_api-2.3.0.tar.gz
  • Upload date:
  • Size: 113.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for ya_dialogs_api-2.3.0.tar.gz
Algorithm Hash digest
SHA256 fdae217afb793927ceb92f61f89a5e1b9ef97bc25879325d9b1fc433078aa5cf
MD5 9f422bef52a1b21b9bc0cd21a7235c44
BLAKE2b-256 b9e1332873b65ed1096e2482032bfd0b153cbfea8598ceb82d3287861a82624a

See more details on using hashes here.

Provenance

The following attestation bundles were made for ya_dialogs_api-2.3.0.tar.gz:

Publisher: release.yml on trudenboy/ya-dialogs-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ya_dialogs_api-2.3.0-py3-none-any.whl.

File metadata

  • Download URL: ya_dialogs_api-2.3.0-py3-none-any.whl
  • Upload date:
  • Size: 84.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for ya_dialogs_api-2.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 478823e788cbecca4c0a688fe7778411c03cdde18c04d46dc0927e789c695307
MD5 5f86f848e068b077d4cfd25b88c728fc
BLAKE2b-256 3df78484f2591fbd1ab2fbd3f5f2c68b34df1020f8b556eef4435144545838bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for ya_dialogs_api-2.3.0-py3-none-any.whl:

Publisher: release.yml on trudenboy/ya-dialogs-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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