feat: provider v0.1.10 — source_dir (zip внутри провайдера), убран archive провайдер из всех примеров

This commit is contained in:
“Naeel” 2026-03-09 17:45:45 +04:00
parent 0fd2993ee7
commit abd4612502
14 changed files with 32 additions and 161 deletions

View File

@ -34,7 +34,7 @@ terraform apply -auto-approve
terraform output job_result terraform output job_result
# Проверить функцию: # Проверить функцию:
curl -s $(terraform output -raw display_url) curl -s https://sless-api.kube5s.ru/fn/default/simple-py-time-display
``` ```
--- ---
@ -47,7 +47,7 @@ terraform init
terraform apply -auto-approve terraform apply -auto-approve
terraform output job_result terraform output job_result
curl -s $(terraform output -raw display_url) curl -s https://sless-api.kube5s.ru/fn/default/simple-node-time-display
``` ```
--- ---
@ -62,7 +62,7 @@ terraform init
terraform apply -auto-approve terraform apply -auto-approve
# Проверить HTTP-функцию: # Проверить HTTP-функцию:
curl -s -X POST $(terraform output -raw trigger_url) \ curl -s -X POST https://sless-api.kube5s.ru/fn/default/hello-http \
-H 'Content-Type: application/json' -d '{"name":"World"}' -H 'Content-Type: application/json' -d '{"name":"World"}'
# Посмотреть результат джоба: # Посмотреть результат джоба:
@ -99,16 +99,16 @@ terraform output notes_url # CRUD
terraform output notes_list_url # список всех записей terraform output notes_list_url # список всех записей
# Создать запись: # Создать запись:
curl -s -X POST "$(terraform output -raw notes_url)/add?title=Hello&body=World" curl -s -X POST "https://sless-api.kube5s.ru/fn/default/notes/add?title=Hello&body=World"
# Список записей: # Список записей:
curl -s $(terraform output -raw notes_list_url) curl -s https://sless-api.kube5s.ru/fn/default/notes-list
# Обновить (id из предыдущего ответа): # Обновить (id из предыдущего ответа):
curl -s -X POST "$(terraform output -raw notes_url)/update?id=1&title=Updated&body=New+body" curl -s -X POST "https://sless-api.kube5s.ru/fn/default/notes/update?id=1&title=Updated&body=New+body"
# Удалить: # Удалить:
curl -s -X POST "$(terraform output -raw notes_url)/delete?id=1" curl -s -X POST "https://sless-api.kube5s.ru/fn/default/notes/delete?id=1"
``` ```
--- ---

View File

@ -1,17 +1,6 @@
# 2026-03-08 # 2026-03-08 / Изменено: 2026-03-09
# http.tf HTTP-функция: принимает запросы, возвращает приветствие. # http.tf HTTP-функция: принимает запросы, возвращает приветствие.
# Код: code/handler-http.js # Код: code/handler-http.js
#
# Использование:
# terraform apply
# curl -s -X POST $(terraform output -raw trigger_url) \
# -H 'Content-Type: application/json' -d '{"name":"Naeel"}'
data "archive_file" "handler_http" {
type = "zip"
source_file = "${path.module}/code/handler-http.js"
output_path = "${path.module}/dist/handler-http.zip"
}
resource "sless_function" "hello_http" { resource "sless_function" "hello_http" {
name = "hello-http" name = "hello-http"
@ -20,17 +9,13 @@ resource "sless_function" "hello_http" {
memory_mb = 128 memory_mb = 128
timeout_sec = 30 timeout_sec = 30
code_path = data.archive_file.handler_http.output_path source_dir = "${path.module}/code"
# filesha256 исходного файла надёжнее чем output_md5 zip:
# MD5 zip зависит от метаданных архива и может совпасть при разном содержимом
code_hash = filesha256("${path.module}/code/handler-http.js")
} }
resource "sless_trigger" "hello_http" { resource "sless_trigger" "hello_http" {
name = "hello-http-trigger" name = "hello-http-trigger"
type = "http" type = "http"
function = sless_function.hello_http.name function = sless_function.hello_http.name
# enabled = false чтобы заморозить функцию (не удаляя ресурс), потом поставить зновь true
enabled = true enabled = true
} }

View File

@ -1,19 +1,6 @@
# 2026-03-08 # 2026-03-08 / Изменено: 2026-03-09
# job.tf одноразовая функция: суммирует числа из переданного массива. # job.tf одноразовая функция: суммирует числа из переданного массива.
# Код: code/handler-job.js # Код: code/handler-job.js
#
# Использование:
# terraform apply
# # apply блокируется до завершения джоба (~2 мин kaniko + выполнение)
# terraform output job_message
#
# Повторный запуск изменить event_json и снова terraform apply.
data "archive_file" "handler_job" {
type = "zip"
source_file = "${path.module}/code/handler-job.js"
output_path = "${path.module}/dist/handler-job.zip"
}
resource "sless_function" "hello_job" { resource "sless_function" "hello_job" {
name = "hello-job" name = "hello-job"
@ -22,13 +9,10 @@ resource "sless_function" "hello_job" {
memory_mb = 128 memory_mb = 128
timeout_sec = 30 timeout_sec = 30
code_path = data.archive_file.handler_job.output_path source_dir = "${path.module}/code"
# filesha256 исходного файла надёжнее чем output_md5 zip
code_hash = filesha256("${path.module}/code/handler-job.js")
} }
# Одноразовый запуск. Все поля immutable изменение любого пересоздаёт джоб. # Одноразовый запуск. Для повторного запуска увеличь run_id (123...).
# run_id: 0 = не запускать, 1+ = запустить. Для повторного запуска увеличь run_id (123...).
resource "sless_job" "hello_run" { resource "sless_job" "hello_run" {
name = "hello-run" name = "hello-run"
function = sless_function.hello_job.name function = sless_function.hello_job.name

View File

@ -8,11 +8,7 @@ terraform {
required_providers { required_providers {
sless = { sless = {
source = "terra.k8c.ru/naeel/sless" source = "terra.k8c.ru/naeel/sless"
version = "~> 0.1.9" version = "~> 0.1.10"
}
archive = {
source = "hashicorp/archive"
version = "~> 2.0"
} }
} }
} }

View File

@ -14,12 +14,7 @@ terraform {
# Провайдер для управления serverless функциями через sless API # Провайдер для управления serverless функциями через sless API
sless = { sless = {
source = "terra.k8c.ru/naeel/sless" source = "terra.k8c.ru/naeel/sless"
version = "~> 0.1.9" version = "~> 0.1.10"
}
# hashicorp/archive для упаковки исходников в zip перед загрузкой
archive = {
source = "hashicorp/archive"
version = "~> 2.0"
} }
} }
} }

View File

@ -1,22 +1,6 @@
# 2026-03-09 # 2026-03-09
# notes-list.tf функция для чтения всех заметок одним запросом. # notes-list.tf read-only эндпоинт: возвращает все заметки, сортировка новые первые.
#
# Отдельная от CRUD функция «read-only» эндпоинт без роутинга.
# Принимает GET или POST, параметры игнорирует.
# Возвращает JSON-массив всех записей, сортировка: новые первые.
#
# Пример запроса:
# curl https://sless-api.kube5s.ru/fn/default/notes-list
# Упаковка исходников notes_list.py в zip.
data "archive_file" "notes_list_zip" {
type = "zip"
source_dir = "${path.module}/code/notes-list"
output_path = "${path.module}/dist/notes-list.zip"
}
# Read-only функция в кластере.
# entrypoint = "notes_list.list_notes" файл notes_list.py, функция list_notes().
resource "sless_function" "notes_list" { resource "sless_function" "notes_list" {
name = "notes-list" name = "notes-list"
runtime = "python3.11" runtime = "python3.11"
@ -28,12 +12,9 @@ resource "sless_function" "notes_list" {
PG_DSN = var.pg_dsn PG_DSN = var.pg_dsn
} }
code_path = data.archive_file.notes_list_zip.output_path source_dir = "${path.module}/code/notes-list"
code_hash = filesha256("${path.module}/code/notes-list/notes_list.py")
} }
# HTTP-триггер для read-only функции.
# Создаёт Ingress, URL доступен в outputs.tf.
resource "sless_trigger" "notes_list_http" { resource "sless_trigger" "notes_list_http" {
name = "notes-list-http" name = "notes-list-http"
type = "http" type = "http"

View File

@ -1,24 +1,11 @@
# 2026-03-09 # 2026-03-09
# notes.tf CRUD функция для управления заметками (CREATE / UPDATE / DELETE). # notes.tf CRUD функция для управления заметками (CREATE / UPDATE / DELETE).
# #
# Одна функция обрабатывает все операции роутинг по sub-path URL. # Маршруты (рекомендуется POST):
# Sub-path и query string пробрасывает прокси (invoke.go) runtime добавляет # /fn/default/notes/add?title=...&body=... INSERT
# их в event как _path и _query. # /fn/default/notes/update?id=1&title=...&body=... UPDATE
# # /fn/default/notes/delete?id=1 DELETE
# Маршруты (все методы принимаются, рекомендуется POST):
# /fn/default/notes/add?title=...&body=... INSERT, возвращает запись
# /fn/default/notes/update?id=1&title=...&body=... UPDATE, возвращает запись
# /fn/default/notes/delete?id=1 DELETE, возвращает {deleted: id}
# Упаковка исходников notes_crud.py в zip.
data "archive_file" "notes_crud_zip" {
type = "zip"
source_dir = "${path.module}/code/notes"
output_path = "${path.module}/dist/notes.zip"
}
# CRUD функция в кластере.
# entrypoint = "notes_crud.crud" файл notes_crud.py, функция crud().
resource "sless_function" "notes_crud" { resource "sless_function" "notes_crud" {
name = "notes" name = "notes"
runtime = "python3.11" runtime = "python3.11"
@ -30,13 +17,9 @@ resource "sless_function" "notes_crud" {
PG_DSN = var.pg_dsn PG_DSN = var.pg_dsn
} }
code_path = data.archive_file.notes_crud_zip.output_path source_dir = "${path.module}/code/notes"
code_hash = filesha256("${path.module}/code/notes/notes_crud.py")
} }
# HTTP-триггер для CRUD функции.
# Создаёт Ingress в кластере, URL доступен в outputs.tf.
# Базовый URL: https://sless-api.kube5s.ru/fn/default/notes
resource "sless_trigger" "notes_crud_http" { resource "sless_trigger" "notes_crud_http" {
name = "notes-http" name = "notes-http"
type = "http" type = "http"

View File

@ -5,17 +5,6 @@
# Это сделано намеренно: функция выполняет произвольный SQL, и открывать её # Это сделано намеренно: функция выполняет произвольный SQL, и открывать её
# наружу через HTTP было бы небезопасно. # наружу через HTTP было бы небезопасно.
# Упаковка исходников в zip для загрузки в кластер.
# archive_file пересоздаёт zip при изменении любого файла в source_dir.
data "archive_file" "sql_runner_zip" {
type = "zip"
source_dir = "${path.module}/code/sql-runner"
output_path = "${path.module}/dist/sql-runner.zip"
}
# Сама функция в кластере.
# entrypoint = "sql_runner.run_sql" файл sql_runner.py, функция run_sql().
# memory_mb=128 достаточно DDL запросы не требуют памяти на вычисления.
resource "sless_function" "sql_runner" { resource "sless_function" "sql_runner" {
name = "sql-runner" name = "sql-runner"
runtime = "python3.11" runtime = "python3.11"
@ -27,7 +16,5 @@ resource "sless_function" "sql_runner" {
PG_DSN = var.pg_dsn PG_DSN = var.pg_dsn
} }
code_path = data.archive_file.sql_runner_zip.output_path source_dir = "${path.module}/code/sql-runner"
# code_hash при изменении кода terraform пересобирает образ функции
code_hash = filesha256("${path.module}/code/sql-runner/sql_runner.py")
} }

View File

@ -19,11 +19,7 @@ terraform {
required_providers { required_providers {
sless = { sless = {
source = "terra.k8c.ru/naeel/sless" source = "terra.k8c.ru/naeel/sless"
version = "~> 0.1.9" version = "~> 0.1.10"
}
archive = {
source = "hashicorp/archive"
version = "~> 2.0"
} }
} }
} }

View File

@ -1,14 +1,7 @@
# Создано: 2026-03-09 # Создано: 2026-03-09 / Изменено: 2026-03-09
# time-display.tf HTTP-функция, доступная по URL после apply. # time-display.tf HTTP-функция, доступная по URL после apply.
# Получает результат джоба (из time-getter.tf) через переменную окружения JOB_TIME. # Получает результат джоба (из time-getter.tf) через переменную окружения JOB_TIME.
# Упаковываем код функции в zip для загрузки
data "archive_file" "time_display_zip" {
type = "zip"
source_dir = "${path.module}/code/time_display"
output_path = "${path.module}/dist/time_display.zip"
}
# HTTP-функция отвечает на запросы по URL из outputs.tf # HTTP-функция отвечает на запросы по URL из outputs.tf
resource "sless_function" "time_display" { resource "sless_function" "time_display" {
name = "simple-node-time-display" # уникальное имя в namespace name = "simple-node-time-display" # уникальное имя в namespace
@ -22,8 +15,7 @@ resource "sless_function" "time_display" {
JOB_TIME = sless_job.run_getter.message JOB_TIME = sless_job.run_getter.message
} }
code_path = data.archive_file.time_display_zip.output_path source_dir = "${path.module}/code/time_display"
code_hash = filesha256("${path.module}/code/time_display/time_display.js") # для пересборки при изменении кода
depends_on = [sless_job.run_getter] # ждём завершения джоба перед деплоем функции depends_on = [sless_job.run_getter] # ждём завершения джоба перед деплоем функции
} }

View File

@ -1,15 +1,8 @@
# Создано: 2026-03-09 # Создано: 2026-03-09 / Изменено: 2026-03-09
# time-getter.tf скрипт который запускается ОДИН РАЗ при terraform apply. # time-getter.tf скрипт который запускается ОДИН РАЗ при terraform apply.
# После запуска его результат доступен через: sless_job.run_getter.message # После запуска его результат доступен через: sless_job.run_getter.message
# Смотри time-display.tf там этот результат передаётся в функцию. # Смотри time-display.tf там этот результат передаётся в функцию.
# Упаковываем код скрипта в zip для загрузки
data "archive_file" "time_getter_zip" {
type = "zip"
source_dir = "${path.module}/code/time_getter"
output_path = "${path.module}/dist/time_getter.zip"
}
# Функция для скрипта без HTTP-триггера, вызывается только через джоб ниже # Функция для скрипта без HTTP-триггера, вызывается только через джоб ниже
resource "sless_function" "time_getter" { resource "sless_function" "time_getter" {
name = "simple-node-time-getter" # уникальное имя в namespace name = "simple-node-time-getter" # уникальное имя в namespace
@ -17,8 +10,7 @@ resource "sless_function" "time_getter" {
entrypoint = "time_getter.getTime" # файл.функция в code/time_getter/ entrypoint = "time_getter.getTime" # файл.функция в code/time_getter/
memory_mb = 64 memory_mb = 64
code_path = data.archive_file.time_getter_zip.output_path source_dir = "${path.module}/code/time_getter"
code_hash = filesha256("${path.module}/code/time_getter/time_getter.js") # для пересборки при изменении кода
} }
# Джоб запускает функцию time_getter один раз прямо при apply. # Джоб запускает функцию time_getter один раз прямо при apply.

View File

@ -18,11 +18,7 @@ terraform {
required_providers { required_providers {
sless = { sless = {
source = "terra.k8c.ru/naeel/sless" source = "terra.k8c.ru/naeel/sless"
version = "~> 0.1.9" version = "~> 0.1.10"
}
archive = {
source = "hashicorp/archive"
version = "~> 2.0"
} }
} }
} }

View File

@ -1,14 +1,7 @@
# Создано: 2026-03-09 # Создано: 2026-03-09 / Изменено: 2026-03-09
# time-display.tf HTTP-функция, доступная по URL после apply. # time-display.tf HTTP-функция, доступная по URL после apply.
# Получает результат джоба (из time-getter.tf) через переменную окружения JOB_TIME. # Получает результат джоба (из time-getter.tf) через переменную окружения JOB_TIME.
# Упаковываем код функции в zip для загрузки
data "archive_file" "time_display_zip" {
type = "zip"
source_dir = "${path.module}/code/time_display"
output_path = "${path.module}/dist/time_display.zip"
}
# HTTP-функция отвечает на запросы по URL из outputs.tf # HTTP-функция отвечает на запросы по URL из outputs.tf
resource "sless_function" "time_display" { resource "sless_function" "time_display" {
name = "simple-py-time-display" # уникальное имя в namespace name = "simple-py-time-display" # уникальное имя в namespace
@ -22,8 +15,7 @@ resource "sless_function" "time_display" {
JOB_TIME = sless_job.run_getter.message JOB_TIME = sless_job.run_getter.message
} }
code_path = data.archive_file.time_display_zip.output_path source_dir = "${path.module}/code/time_display"
code_hash = filesha256("${path.module}/code/time_display/time_display.py") # для пересборки при изменении кода
depends_on = [sless_job.run_getter] # ждём завершения джоба перед деплоем функции depends_on = [sless_job.run_getter] # ждём завершения джоба перед деплоем функции
} }

View File

@ -1,15 +1,8 @@
# Создано: 2026-03-09 # Создано: 2026-03-09 / Изменено: 2026-03-09
# time-getter.tf скрипт который запускается ОДИН РАЗ при terraform apply. # time-getter.tf скрипт который запускается ОДИН РАЗ при terraform apply.
# После запуска его результат доступен через: sless_job.run_getter.message # После запуска его результат доступен через: sless_job.run_getter.message
# Смотри time-display.tf там этот результат передаётся в функцию. # Смотри time-display.tf там этот результат передаётся в функцию.
# Упаковываем код скрипта в zip для загрузки
data "archive_file" "time_getter_zip" {
type = "zip"
source_dir = "${path.module}/code/time_getter"
output_path = "${path.module}/dist/time_getter.zip"
}
# Функция для скрипта без HTTP-триггера, вызывается только через джоб ниже # Функция для скрипта без HTTP-триггера, вызывается только через джоб ниже
resource "sless_function" "time_getter" { resource "sless_function" "time_getter" {
name = "simple-py-time-getter" # уникальное имя в namespace name = "simple-py-time-getter" # уникальное имя в namespace
@ -17,8 +10,7 @@ resource "sless_function" "time_getter" {
entrypoint = "time_getter.get_time" # файл.функция в code/time_getter/ entrypoint = "time_getter.get_time" # файл.функция в code/time_getter/
memory_mb = 64 memory_mb = 64
code_path = data.archive_file.time_getter_zip.output_path source_dir = "${path.module}/code/time_getter"
code_hash = filesha256("${path.module}/code/time_getter/time_getter.py") # для пересборки при изменении кода
} }
# Джоб запускает функцию time_getter один раз прямо при apply. # Джоб запускает функцию time_getter один раз прямо при apply.