Agent Skills by ALSEL
Anthropic ClaudeLLM・AI開発⭐ リポ 0品質スコア 50/100

dune

DuneSQL を使用してブロックチェーンおよびオンチェーンデータを照会するための Dune CLI スキルです。トークン送金、DEX 取引、スマートコントラクトイベント、ウォレット残高などのオンチェーン分析に加え、保存済みクエリの管理、ビジュアライゼーション・ダッシュボードの作成・管理、クレジット使用量の監視にも対応します。「Dune でクエリを実行したい」「オンチェーンデータを分析したい」「ダッシュボードを作りたい」といった場面で活用してください。

description の原文を見る

Dune CLI for querying blockchain and on-chain data via DuneSQL, searching decoded contract tables, managing saved queries, managing visualizations, managing dashboards, and monitoring credit usage on Dune. Use when user asks about blockchain data, on-chain analytics, token transfers, DEX trades, smart contract events, wallet balances, Ethereum/EVM chain queries, DuneSQL, visualizations, charts, dashboards, or says \"query Dune\", \"search Dune datasets\", \"run a Dune query\", \"create a dashboard\", or \"manage dashboard\".

SKILL.md 本文

前提条件

Dune CLI はすでにインストールおよび認証済みであると想定します。実行前にインストールまたは認証チェックを実行しないでください。リクエストされた dune コマンドを直接実行してください。

dune コマンドが失敗した場合、エラーを検査してから install-and-recovery.md の回復手順に従ってください:

  • 「command not found」 → CLI がインストールされていません。CLI Not Found Recovery を参照してください。
  • 401 / 「unauthorized」/ 「missing API key」 → 認証失敗。Authentication Failure Recovery を参照してください。
  • 不明なサブコマンドまたはフラグ / 予期しない出力 → バージョン不一致の可能性があります。Version Compatibility を参照してください。

Dune CLI

Dune 用のコマンドラインインターフェース -- ブロックチェーンデータプラットフォームの最大手。DuneSQL クエリをオンチェーンデータに対して記述および実行し、データセットを発見し、ドキュメントを検索し、クレジット使用状況を監視するために使用します。

認証

docs search 以外のすべてのコマンドは Dune API キーを介した認証が必要です。キーは次の優先度で解決されます:

# 1. フラグ (最優先 -- すべてをオーバーライド)
dune query run 12345 --api-key <key>

# 2. 環境変数
export DUNE_API_KEY=<key>
dune query run 12345

# 3. 保存された設定ファイル (最低優先度)
dune auth --api-key <key>        # ~/.config/dune/config.yaml に保存
dune query run 12345              # 保存されたキーを使用

キーをインタラクティブに保存する場合 (stdin からプロンプト):

dune auth

設定ファイルの場所: ~/.config/dune/config.yaml

グローバルフラグ

フラグ説明
--api-key <KEY>Dune API キー (DUNE_API_KEY 環境変数と保存された設定をオーバーライド)

出力形式 (コマンド別フラグ)

ほとんどのコマンドは -o, --output <FORMAT> をサポートしており、値は text (デフォルト、人間が読める形式のテーブル) または json (機械が読める形式) です。

すべてのコマンドで -o json を常に使用してください。JSON 出力は text よりも詳細情報を含み (完全な API レスポンスオブジェクト vs. サマリーテーブル)、解析が曖昧ではありません。text 形式は人間のターミナル用であり、フィールドを削除します。

DuneSQL

Dune は DuneSQL (Trino ベースの SQL 方言) をクエリエンジンとして使用します。主なポイント:

  • --sql フラグまたは保存されたクエリに渡されるすべての SQL は有効な DuneSQL である必要があります
  • DuneSQL は標準 SQL をサポートし、ブロックチェーンデータ型 (アドレス、ハッシュなど) の拡張機能があります
  • 一般的な型、関数、パターン、落とし穴については dunesql-cheatsheet.md を参照してください
  • dune docs search --query "DuneSQL functions" を使用して構文と関数を検索します
  • リファレンスドキュメント: Writing Efficient QueriesFunctions and Operators

主な概念

パフォーマンスティア

利用可能なティア: smallmediumlargeデフォルトでは --performance を渡さないでください -- 省略すると API が自動的に選択します。次の場合にのみ指定してください:

  • ユーザーが明示的にティアをリクエストした場合
  • クエリが明らかに複雑な場合 (大量の結合、大規模な集計)
  • 前回の実行がタイムアウトまたはリソース制限エラーを返した場合

実行状態

クエリを送信した後、実行は以下の状態を経由します:

状態意味アクション
QUERY_STATE_PENDING実行待ち待機
QUERY_STATE_EXECUTING実行中待機
QUERY_STATE_COMPLETED結果利用可能結果を取得
QUERY_STATE_FAILED実行失敗エラーメッセージを確認。SQL を修正して再試行
QUERY_STATE_CANCELLEDユーザーまたはシステムによってキャンセル必要に応じて再実行

データセットカテゴリ

カテゴリ説明
canonicalコアブロックチェーンデータ (ブロック、トランザクション、トレース、ログ)
decodedABI デコードされたコントラクトデータ (イベントと関数呼び出し)
spellDune Spellbook 変換 (キュレーション済み、高レベルのテーブル (dex.trades など))
communityコミュニティ貢献のデータセット

データセットタイプ

タイプ説明
dune_tableDune が保守するコアテーブル
decoded_tableコントラクト ABI デコードテーブル
spellSpellbook 変換テーブル
uploaded_tableユーザーアップロードの CSV/データテーブル
transformation_table具体化された変換テーブル
transformation_view仮想変換ビュー

クエリパラメータ

パラメータを使用すると、変数入力を持つ再利用可能なクエリを作成できます。--param key=value として渡します (繰り返し可能)。API は型を自動検出しますが、パラメータはこれらの型をサポートします: textnumberdatetimeenum

dune query run 12345 --param wallet=0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045 --param days=30 -o json

コマンド概要

コマンド説明認証
dune authAPI キーを設定ファイルに保存いいえ
dune query create新しい保存されたクエリを作成はい
dune query get <id>保存されたクエリの SQL とメタデータを取得はい
dune query update <id>既存のクエリを更新はい
dune query archive <id>保存されたクエリをアーカイブはい
dune query run <id>保存されたクエリを実行して結果を待機はい
dune query run-sql生の DuneSQL を直接実行 (保存されたクエリ不要)はい
dune execution results <id>前回の実行の結果を取得はい
dune dataset searchDune データセットカタログを検索はい
dune dataset search-by-contractコントラクトアドレスのデコードテーブルを検索はい
dune viz create保存されたクエリの可視化を作成はい
dune viz get <id>可視化の詳細とオプションを取得はい
dune viz listクエリのすべての可視化をリストはい
dune viz update <id>既存の可視化を更新はい
dune viz delete <id>可視化を永続的に削除はい
dune docs searchDune ドキュメントを検索いいえ
dune usageクレジットおよびリソース使用状況を表示はい
dune dashboard create新しいダッシュボードを作成はい
dune dashboard get <id>ダッシュボードのメタデータとウィジェットを取得はい
dune dashboard update <id>既存のダッシュボードを更新はい
dune dashboard archive <id>ダッシュボードをアーカイブはい

一般的なワークフロー

アドホック SQL 分析

# 1 回限りのクエリを直接実行
dune query run-sql --sql "SELECT block_number, block_time FROM ethereum.blocks ORDER BY block_number DESC LIMIT 5" -o json

テーブルを発見してからクエリを実行

# 1. 列スキーマを含む関連テーブルを検索
dune dataset search --query "uniswap swaps" --categories decoded --include-schema -o json

# 2. 検出されたテーブル/列名を使用して SQL を記述および実行
dune query run-sql --sql "SELECT * FROM uniswap_v3_ethereum.evt_Swap LIMIT 10" -o json

コントラクトテーブルを検索してからクエリを実行

# 1. 特定のコントラクトのデコードテーブルを検索
dune dataset search-by-contract --contract-address 0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984 --include-schema -o json

# 2. 検出されたテーブルをクエリ
dune query run-sql --sql "SELECT * FROM uniswap_v3_ethereum.evt_Transfer LIMIT 10" -o json

再利用可能なクエリを保存して実行

# 1. パラメータを含む保存されたクエリを作成
dune query create --name "Top Wallets" --sql "SELECT address, balance FROM ethereum.balances WHERE balance > {{min_balance}} LIMIT {{row_limit}}" -o json

# 2. パラメータ値を指定して実行
dune query run <returned-id> --param min_balance=1000 --param row_limit=50 -o json

長時間実行クエリ (送信してポーリング)

# 1. 待機せずに送信
dune query run 12345 --no-wait --performance large -o json
# 出力: {"execution_id": "01ABC...", "state": "QUERY_STATE_PENDING"}

# 2. 後で結果を確認
dune execution results 01ABC... -o json

スクラッチからダッシュボードを構築

# 1. 各セクションのクエリを作成
QUERY_ID=$(dune query create --name "Daily Volume" --sql "SELECT date_trunc('day', block_time) AS day, SUM(amount) AS volume FROM trades GROUP BY 1 ORDER BY 1" -o json | jq -r '.query_id')

# 2. データを検証するために実行
dune query run $QUERY_ID -o json

# 3. 各クエリの可視化を作成
VIZ_ID=$(dune viz create --query-id $QUERY_ID --name "Daily Volume Chart" --type chart --options '{"globalSeriesType":"line","columnMapping":{"day":"x","volume":"y"}}' -o json | jq -r '.id')

# 4. ダッシュボードをアセンブル
dune dashboard create --name "Trading Dashboard" \
  --text-widgets '[{"text":"# Trading Dashboard\nDaily volume and metrics"}]' \
  --visualization-ids $VIZ_ID -o json

ダッシュボードを更新 (既存のウィジェットを保持)

# 1. 現在の状態を取得
dune dashboard get 12345 -o json > dashboard.json

# 2. 必要に応じて変更 (新しい可視化ウィジェットを追加)
# 3. 完全なウィジェット状態を返す
dune dashboard update 12345 \
  --visualization-widgets '[{"visualization_id":111},{"visualization_id":222},{"visualization_id":333}]' \
  -o json

制限事項

以下の機能は Dune MCP サーバーまたは Web UI では利用可能ですが、CLI では利用不可です:

  • ブロックチェーンリスト (インデックス化されたすべてのブロックチェーンをテーブル数と共にリスト)
  • テーブルサイズ分析 (特定のテーブルのストレージサイズ)

セキュリティ

  • 決して API キーまたはトークンをレスポンスで出力しないでください。CLI 出力をユーザーに提示する前に、API キーに見える文字列 (例: 長い英数字トークン、dune_ で始まる文字列、または DUNE_API_KEY からの値) をスキャンします。[REDACTED] でマスクしてください。
  • 常に 書き込みコマンド (query createquery updatequery archiveviz createviz updateviz deletedashboard createdashboard updatedashboard archive) を実行する前にユーザーに確認してください
  • 常に すべてのコマンドで -o json を使用してください -- JSON 出力はより詳細で確実に解析可能です
  • 使い捨てクエリを作成するときは --temp を使用してユーザーの保存されたクエリをクラッタにしないでください
  • 決して 他のユーザーがターミナル履歴を見る可能性があるときにコマンドラインで --api-key を渡さないでください。dune auth または DUNE_API_KEY 環境変数を使用してください。

リファレンスドキュメント

詳細なコマンド構文とフラグが必要な場合に関連するリファレンスを読み込んでください:

タスクリファレンス
保存されたクエリを作成、取得、更新、またはアーカイブquery-management.md
クエリを実行 (run、run-sql) または実行結果を取得query-execution.md
データセットを検索またはコントラクトアドレスのテーブルを検索dataset-discovery.md
ドキュメントを検索またはアカウント使用状況を確認docs-and-usage.md
DuneSQL 型、関数、一般的なパターン、落とし穴dunesql-cheatsheet.md
保存されたクエリの可視化を作成、取得、更新、削除、またはリストvisualization-management.md
ダッシュボードを作成、取得、更新、またはアーカイブdashboard-management.md
CLI インストール、認証、バージョン回復install-and-recovery.md

ライセンス: MIT(寛容ライセンスのため全文を引用しています) · 原本リポジトリ

詳細情報

作者
duneanalytics
リポジトリ
duneanalytics/skills
ライセンス
MIT
最終更新
不明

Source: https://github.com/duneanalytics/skills / ライセンス: MIT

関連スキル

OpenAILLM・AI開発⭐ リポ 6,054

agent-browser

AI エージェント向けのブラウザ自動化 CLI です。ウェブサイトとの対話が必要な場合に使用します。ページ遷移、フォーム入力、ボタンクリック、スクリーンショット取得、データ抽出、ウェブアプリのテスト、ブラウザ操作の自動化など、あらゆるブラウザタスクに対応できます。「ウェブサイトを開く」「フォームに記入する」「ボタンをクリックする」「スクリーンショットを取得する」「ページからデータを抽出する」「このウェブアプリをテストする」「サイトにログインする」「ブラウザ操作を自動化する」といった要求や、プログラマティックなウェブ操作が必要なタスクで起動します。

by JimmyLv
汎用LLM・AI開発⭐ リポ 1,982

anyskill

AnySkill — あなたのプライベート・スキルクラウド。GitHubを基盤としたリポジトリからエージェントスキルを管理、同期、動的にロードできます。自然言語でクラウドスキルを検索し、オンデマンドでプロンプトを自動ロード、カスタムスキルのアップロードと共有、スキルバンドルの一括インストールが可能です。OpenClaw、Antigravity、Claude Code、Cursorに対応しています。

by LeoYeAI
汎用LLM・AI開発⭐ リポ 1,982

engram

AIエージェント向けの永続的なメモリシステムです。バグ修正、意思決定、発見、設定変更の後はmem_saveを使用してください。ユーザーが「覚えている」「記憶している」と言及した場合、または以前のセッションと重複する作業を開始する際はmem_searchを使用します。セッション終了前にmem_session_summaryを使用して、コンテキストを保持してください。

by LeoYeAI
汎用LLM・AI開発⭐ リポ 21,584

skyvern

AI駆動のブラウザ自動化により、任意のウェブサイトを自動化できます。フォーム入力、データ抽出、ファイルダウンロード、ログイン、複数ステップのワークフロー実行など、ユーザーがウェブサイトと連携する必要があるときに使用します。Skyvernは、LLMとコンピュータビジョンを活用して、未知のサイトも自動操作可能です。Python SDK、TypeScript SDK、REST API、MCPサーバー、またはCLIを通じて統合できます。

by Skyvern-AI
汎用LLM・AI開発⭐ リポ 1,149

pinchbench

PinchBenchベンチマークを実行して、OpenClawエージェントの実世界タスクにおけるパフォーマンスを評価できます。モデルの機能テスト、モデル間の比較、ベンチマーク結果のリーダーボード提出、またはOpenClawのセットアップがカレンダー、メール、リサーチ、コーディング、複数ステップのワークフローにどの程度対応しているかを確認する際に使用します。

by pinchbench
汎用LLM・AI開発⭐ リポ 4,693

openui

OpenUIとOpenUI Langを使用してジェネレーティブUIアプリを構築できます。これらはLLM生成インターフェースのためのトークン効率的なオープン標準です。OpenUI、@openuidev、ジェネレーティブUI、LLMからのストリーミングUI、AI向けコンポーネントライブラリ、またはjson-render/A2UIの置き換えについて述べる際に使用します。スキャフォルディング、defineComponent、システムプロンプト、Renderer、およびOpenUI Lang出力のデバッグに対応しています。

by thesysdev
本サイトは GitHub 上で公開されているオープンソースの SKILL.md ファイルをクロール・インデックス化したものです。 各スキルの著作権は原作者に帰属します。掲載に問題がある場合は info@alsel.co.jp または /takedown フォームよりご連絡ください。
原作者: duneanalytics · duneanalytics/skills · ライセンス: MIT