Skip to content

Instantly share code, notes, and snippets.

@hu553in
Created April 14, 2026 22:41
Show Gist options
  • Select an option

  • Save hu553in/bb8757d34c99237506768c56175c38f3 to your computer and use it in GitHub Desktop.

Select an option

Save hu553in/bb8757d34c99237506768c56175c38f3 to your computer and use it in GitHub Desktop.
Yandex Cloud Function to create Todoist tasks via Yandex Alice skill
import json
import logging
import os
from datetime import date
from urllib.request import Request, urlopen
from urllib.error import URLError
logger = logging.getLogger()
logger.setLevel(logging.INFO)
TODOIST_TOKEN = os.environ.get("TODOIST_TOKEN")
def handler(event, context):
body = event if "request" in event else json.loads(event.get("body", "{}"))
request = body.get("request", {})
session = body.get("session", {})
logger.info("Incoming request: %s", json.dumps(body, ensure_ascii=False))
if session.get("new"):
logger.info("New session started")
return respond("Привет! Скажи, какую задачу добавить в Todoist.")
utterance = request.get("original_utterance", "").strip()
if not utterance:
logger.warning("Empty utterance received")
return respond("Не расслышала. Повтори, какую задачу создать?")
logger.info("Creating task: %s", utterance)
success, error = create_todoist_task(utterance)
if success:
logger.info("Task created successfully: %s", utterance)
text = f"Готово! Задача «{utterance}» добавлена."
else:
logger.error("Failed to create task: %s", error)
text = f"Не удалось создать задачу: {error}"
return respond(text, end_session=True)
def create_todoist_task(content):
url = "https://api.todoist.com/rest/v2/tasks"
payload = {
"content": content,
"due_date": date.today().isoformat(),
}
data = json.dumps(payload).encode("utf-8")
req = Request(url, data=data, method="POST")
req.add_header("Authorization", f"Bearer {TODOIST_TOKEN}")
req.add_header("Content-Type", "application/json")
logger.info("Sending to Todoist API: %s", json.dumps(payload, ensure_ascii=False))
try:
with urlopen(req) as resp:
resp_body = resp.read().decode("utf-8")
if resp.status == 200:
logger.info("Todoist API response 200: %s", resp_body)
return True, None
logger.error("Todoist API unexpected status %d: %s", resp.status, resp_body)
return False, f"HTTP {resp.status}"
except URLError as e:
logger.error("Todoist API request failed: %s", e)
return False, str(e)
def respond(text, end_session=False):
result = {
"response": {
"text": text,
"tts": text,
"end_session": end_session,
},
"version": "1.0",
}
logger.info("Response: %s", json.dumps(result, ensure_ascii=False))
return result
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment