Windmillワークフロー開発環境の構築結果まとめ。サーバー接続確認、REST APIヘルパースクリプト作成、ワークフロー定義ファイル作成、wmill CLI制限の発見と代替策の実装を記録。

This commit is contained in:
Akira
2026-02-21 12:38:25 +09:00
parent d5cad8a691
commit 6172e800c2
5 changed files with 250 additions and 0 deletions

View File

@@ -0,0 +1,53 @@
---
description: 新しいWindmillスクリプトを作成する
---
# 新しいWindmillスクリプトの作成
Windmillに新しいスクリプトを追加する手順。
## 手順
1. **スクリプトファイルの作成**: スクリプトは以下のディレクトリ構造に従って作成する
- ユーザースクリプト: `u/<username>/<script_name>/`
- フォルダスクリプト: `f/<folder_name>/<script_name>/`
2. **ファイル構成**: 各スクリプトフォルダには以下のファイルが必要
- `script.yaml` — メタデータ(言語、概要、スキーマなど)
- スクリプト本体(例: `script.py`, `script.ts`, `script.sh`
3. **script.yaml のテンプレート**
```yaml
summary: '<スクリプトの説明>'
description: '<詳細な説明>'
lock: []
schema:
$schema: 'https://json-schema.org/draft/2020-12/schema'
type: object
properties:
param1:
type: string
description: '<パラメータの説明>'
required:
- param1
kind: script
tag: ''
```
4. **Pythonスクリプト (`script.py`) のテンプレート**
```python
def main(param1: str):
"""
スクリプトの説明
"""
return {"result": f"Hello, {param1}!"}
```
5. **TypeScriptスクリプト (`script.ts`) のテンプレート**
```typescript
export async function main(param1: string): Promise<any> {
return { result: `Hello, ${param1}!` };
}
```
6. **サーバーに反映**: `/windmill-push` ワークフローを実行してpush

View File

@@ -0,0 +1,39 @@
---
description: Windmillサーバーからワークフロー情報を取得する
---
# Windmill Pull ワークフロー
Windmillサーバーから最新のスクリプトやフローの情報を取得する手順。
wm-api.sh を使用してREST API経由で取得する。
// turbo-all
1. サーバーバージョンを確認
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh version
```
2. スクリプト一覧を取得
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh scripts
```
3. フロー一覧を取得
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh flows
```
4. 特定のスクリプトの詳細を取得
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh get-script <path>
```
5. 特定のフローの詳細を取得
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh get-flow <path>
```
## 注意
- wmill CLIはCE版ではグローバルAPI認証の制限があるため使用できない
- 代わりに `wm-api.sh` を使用してREST APIで直接操作する

View File

@@ -0,0 +1,35 @@
---
description: ローカルのワークフローをWindmillサーバーにpushする
---
# Windmill Push ワークフロー
ローカルで作成・編集したスクリプトやフローをWindmillサーバーに反映する手順。
wm-api.sh を使用してREST API経由でpushする。
// turbo-all
1. 現在のサーバー接続を確認
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh version
```
2. 既存のスクリプト一覧を確認
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh scripts
```
3. 既存のフロー一覧を確認
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh flows
```
4. スクリプトを作成する場合 (JSONファイルを用意して実行)
```bash
cd /home/akira/develop/windmill_workflow && ./wm-api.sh create-script <script.json>
```
## 注意
- wmill CLIはCE版ではグローバルAPI認証の制限があるため使用できない
- 代わりに `wm-api.sh` を使用してREST APIで直接操作する
- Windmill MCP経由でも操作可能

122
wm-api.sh Executable file
View File

@@ -0,0 +1,122 @@
#!/usr/bin/env bash
# Windmill REST API ヘルパースクリプト
# Usage: ./wm-api.sh <command> [args...]
set -euo pipefail
# 設定
WINDMILL_URL="${WINDMILL_URL:-https://windmill.keinafarm.net}"
WINDMILL_TOKEN="${WINDMILL_TOKEN:-qLJ3VPZ61kTDiIwaUPUu1dXszGrsN1Dh}"
WINDMILL_WORKSPACE="${WINDMILL_WORKSPACE:-admins}"
API_BASE="${WINDMILL_URL}/api/w/${WINDMILL_WORKSPACE}"
AUTH_HEADER="Authorization: Bearer ${WINDMILL_TOKEN}"
# ヘルパー関数
api_get() {
curl -sk -H "${AUTH_HEADER}" "${API_BASE}$1" 2>/dev/null
}
api_post() {
curl -sk -X POST -H "${AUTH_HEADER}" -H "Content-Type: application/json" -d "$2" "${API_BASE}$1" 2>/dev/null
}
api_put() {
curl -sk -X PUT -H "${AUTH_HEADER}" -H "Content-Type: application/json" -d "$2" "${API_BASE}$1" 2>/dev/null
}
api_delete() {
curl -sk -X DELETE -H "${AUTH_HEADER}" "${API_BASE}$1" 2>/dev/null
}
# コマンド
case "${1:-help}" in
whoami)
api_get "/users/whoami" | python3 -m json.tool
;;
scripts|list-scripts)
api_get "/scripts/list?per_page=${2:-100}" | python3 -m json.tool
;;
flows|list-flows)
api_get "/flows/list?per_page=${2:-100}" | python3 -m json.tool
;;
get-script)
if [ -z "${2:-}" ]; then
echo "Usage: $0 get-script <path>"
exit 1
fi
api_get "/scripts/get/p/$2" | python3 -m json.tool
;;
get-flow)
if [ -z "${2:-}" ]; then
echo "Usage: $0 get-flow <path>"
exit 1
fi
api_get "/flows/get/$2" | python3 -m json.tool
;;
create-script)
if [ -z "${2:-}" ]; then
echo "Usage: $0 create-script <json-file>"
exit 1
fi
api_post "/scripts/create" "$(cat "$2")"
;;
run-script)
if [ -z "${2:-}" ]; then
echo "Usage: $0 run-script <path> [json-args]"
exit 1
fi
local_args="${3:-{\}}"
api_post "/jobs/run/p/$2" "${local_args}"
;;
run-flow)
if [ -z "${2:-}" ]; then
echo "Usage: $0 run-flow <path> [json-args]"
exit 1
fi
local_args="${3:-{\}}"
api_post "/jobs/run/f/$2" "${local_args}"
;;
job-status)
if [ -z "${2:-}" ]; then
echo "Usage: $0 job-status <job-id>"
exit 1
fi
api_get "/jobs_u/get/$2" | python3 -m json.tool
;;
job-result)
if [ -z "${2:-}" ]; then
echo "Usage: $0 job-result <job-id>"
exit 1
fi
api_get "/jobs_u/completed/get_result/$2" | python3 -m json.tool
;;
schedules|list-schedules)
api_get "/schedules/list?per_page=${2:-100}" | python3 -m json.tool
;;
version)
curl -sk "${WINDMILL_URL}/api/version" 2>/dev/null
echo ""
;;
help|*)
cat << 'EOF'
Windmill REST API ヘルパー
使い方: ./wm-api.sh <command> [args...]
コマンド:
whoami - 現在のユーザー情報を表示
version - サーバーバージョンを表示
scripts - スクリプト一覧を表示
flows - フロー一覧を表示
get-script <path> - スクリプトの詳細を取得
get-flow <path> - フローの詳細を取得
create-script <file> - JSONファイルからスクリプトを作成
run-script <path> [args] - スクリプトを実行
run-flow <path> [args] - フローを実行
job-status <id> - ジョブのステータスを確認
job-result <id> - ジョブの結果を取得
schedules - スケジュール一覧を表示
EOF
;;
esac

1
wmill.yaml Normal file
View File

@@ -0,0 +1 @@
defaultTs: bun