ArduPilot uçuş loglarını teşhis eden deterministik MCP sunucusu · Deterministic MCP server that diagnoses ArduPilot DataFlash flight logs
Project description
ardupilot-mcp
🇹🇷 Türkçe · 🇬🇧 English
Drone'un mu düştü ya da kötü mü uçtu? ArduPilot uçuş kontrolcüsü her uçuşta bir kara-kutu dosyası tutar — .bin uçuş logu. Bu araç o dosyayı okur ve bir yapay zekâ sohbet uygulamasının uçuşta ne olduğunu düz dille anlatmasını sağlar: düşük batarya, aşırı titreşim, GPS kaybı, kablo arızası, kötü ayar… Tahminle değil, deterministik bir kontrol motoruyla.
Nasıl bir şey bu? Kendi penceresi/uygulaması yok. Bir yapay zekâ sohbet uygulamasına takılır — Claude Desktop, Cursor, VS Code gibi (bunlara "MCP istemcisi" denir). Önce o uygulamalardan birini kurarsın, bu aracı ona eklersin, sonra düz dille sorarsın. (MCP = Model Context Protocol; bu uygulamaların araçlarla konuştuğu standart "fiş".)
Neden bunu kullanayım?
Mission Planner'ın Auto Analysis'i ve UAV Log Viewer zaten var ve iyiler — ama farklı bir iş yapıyorlar. Kısaca: o araçlar veriyi gösterir, yorumu sen yaparsın; bu araç veriyi yorumlar, düz dille anlatır ve sorularını cevaplar.
| MP Auto Analysis | UAV Log Viewer | ardupilot-mcp | |
|---|---|---|---|
| Çıktı | sabit geç/kal listesi | grafik + 3B uçuş tekrarı | düz dille açıklama + sohbet |
| "Neden düştü?" diye sorup gerekçeli cevap | — | — | ✓ |
| Doğal dille takip sorusu ("15–30 sn titreşim?") | — | — | ✓ |
| Konfig/kurulum hataları (param denetimi, kalibrasyon, kablo, pre-arm) | kısmen | — | ✓ |
| Fiziksel muhakeme (güç marjı, itki/ağırlık) | — | — | ✓ |
| Her bulguda resmi ArduPilot doküman linki | — | — | ✓ |
| Grafik / 3B harita görselleştirme | — | ✓ | — |
| Anında, kurulum yok | ✓ (MP'de hazır) | ✓ (web) | AI istemcisi + uv gerekir |
Diğerlerini ne zaman kullan: bir sinyali grafikte görmek veya uçuş yolunu 3B izlemek için → UAV Log Viewer. Elinde Mission Planner açıkken hızlı bir geç/kal için → MP Auto Analysis. Bu araç onların yerini almaz; "neden böyle oldu?"yu açıklaması ve takip sorularını cevaplaması, kararı deterministik bir motora + resmi dokümana dayandırması, ve uçuş sinyallerinin yanı sıra konfig/kurulum ve fiziksel tarafı da kapsaması için var. Ayrıca tamamen offline ve salt-okunur çalışır.
Hızlı başlangıç (5 dakika)
En kısa yol — Claude Desktop ile:
- Claude Desktop'ı kur: https://claude.ai/download
- uv'yi kur — bu aracı senin yerine indirip çalıştıran küçük, ücretsiz bir program (
uvxonunla gelir):- Windows (PowerShell):
powershell -c "irm https://astral.sh/uv/install.ps1 | iex" - macOS / Linux:
curl -LsSf https://astral.sh/uv/install.sh | sh - Dokümanı: https://docs.astral.sh/uv/getting-started/installation/ · Çalıştı mı:
uv --versionbir sürüm yazmalı.
- Windows (PowerShell):
- Claude Desktop'ta Settings → Developer → Edit Config; şunu yapıştır ve kaydet:
{ "mcpServers": { "ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"] } } }
Sonra Claude Desktop'ı tamamen kapatıp yeniden aç — pencereyi kapatmak yetmez; sistem tepsisinden de çık. - Bir
.binlogu edin (aşağıdaki Uçuş logunu nereden bulurum?). Elinde yoksa AI istemcisi olmadan dene ile demo üret. - Sohbet kutusuna yaz: "C:\loglar\ucus.bin logunu analiz et — neden düştü?" (yolu kendi dosyanla değiştir).
uv yerine pip kullanmak ya da başka bir uygulama (Cursor, VS Code, Cline, LM Studio…) eklemek için → İstemcine ekle.
Uçuş logunu (.bin) nereden bulurum?
Uçuş kontrolcün her uçuş için bir .bin DataFlash logu kaydeder. Bilgisayarına almak için:
- En kolayı — Mission Planner: USB ile bağlan → Flight Data → DataFlash Logs → Download DataFlash Log Via Mavlink → uçuşu seç → kaydet (ör.
C:\loglar\). QGroundControl da olur. - Ya da SD karttan: kontrolcünün SD kartında genelde
APM/LOGSveya/LOGSklasörü; dosya adı00000042.BINgibi görünür.
Tam dosya yolunu not et — yapay zekâya vereceğin şey o. Detay: ArduPilot — Downloading and Analyzing Data Logs.
AI istemcisi olmadan dene
Bir AI uygulaması kurmadan, motorun çalıştığını görmek istersen kaynağı indir (örnek scriptler pip paketinde gelmez, repoyu klonlaman gerekir):
git clone https://github.com/furkanisikay/ardupilot-mcp
cd ardupilot-mcp
pip install -e .
python examples/generate_demo_log.py demo.bin # gerçekçi bir kaza logu üretir
python examples/analyze.py demo.bin # tam teşhisi terminale yazar
Hazır olunca demo.bin yerine kendi .bin dosyanı ver.
Cevap neye benziyor?
Yukarıdaki analyze.py demo.bin çıktısından (kısaltıldı). Bir AI istemcisinde aynı bulgular senin dilinde, sohbet havasında anlatılır:
ArduCopter V4.5.7 — 30 sn uçuş — 8 kritik, 2 uyarı, 3 bilgi
[KRİTİK] titreşim @ 9s : VibeZ titreşimi 72 m/s² zirve yaptı (>60); örneklerin %20'si eşiği aştı.
[KRİTİK] attitude @ 20s : Roll komutu 3 sn takip edilemedi, hata 35°'ye çıktı — kontrol kaybı / mekanik arıza.
[KRİTİK] gps @ 22s : GPS 3D fix'i 22–24 sn arasında kayboldu — konum desteği gitti.
[KRİTİK] güç @ 30s : Paket voltajı 13.22 V'a düştü (kritik 13.50 V failsafe) — acil iniş gerek.
...
TUNING (yalnız tavsiye): 80 Hz harmonik notch öner.
Her bulgu ilgili resmi ArduPilot doküman linkini ve somut sayıları (zaman, değer, eşik) taşır.
İstemcine ekle
Tek tıkla:
Kurulum (bir kez). Aşağıdaki config'lerin hepsi uvx ardupilot-mcp komutunu kullanır.
- Önerilen — uv: yukarıdaki Hızlı başlangıç adım 2'deki tek satırla kur. uv kuruluysa config'ler olduğu gibi çalışır; ayrıca
pip installgerekmez. - Alternatif — pip:
pip install ardupilot-mcpyaptıysan, aşağıdaki config'lerde"command": "uvx", "args": ["ardupilot-mcp"]yerine"command": "ardupilot-mcp"yaz (args'sız). İkisi de çalışır; ikisini karıştırma.
Python da gerekir (3.11+). Kontrol: terminalde python --version 3.11 veya üstünü yazmalı. Yoksa https://python.org/downloads'dan kur (Windows'ta kurulumda **"Add Python to PATH"**i işaretle). uv yolunu kullanırsan uv uygun bir Python'u kendi indirebilir, ayrıca kurman gerekmeyebilir.
Önemli: Config'i ekledikten/değiştirdikten sonra uygulamayı yeniden yükle. Dosya-tabanlı uygulamalarda (Claude Desktop, Cursor, VS Code, Windsurf, LM Studio, Zed) tamamen kapatıp aç — pencereyi kapatmak yetmez, tepside/menü çubuğunda açık kalır. Sonra araç listesini kontrol et.
Claude Code
claude mcp add ardupilot-mcp -- uvx ardupilot-mcp
Tüm projelerde kullanmak için --scope user, takımla paylaşmak için --scope project (repoya .mcp.json yazar). Doğrula: claude mcp list.
Ya da eklenti olarak (MCP sunucusu + /diagnose komutu birlikte gelir):
/plugin marketplace add furkanisikay/ardupilot-mcp
/plugin install ardupilot-mcp@ardupilot-tools
Claude Desktop
Settings → Developer → Edit Config ile claude_desktop_config.json'a ekle, sonra Claude Desktop'ı tamamen kapatıp yeniden aç:
{
"mcpServers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"] }
}
}
Cursor
Üstteki Add to Cursor düğmesi; ya da ~/.cursor/mcp.json (projeye özel: .cursor/mcp.json):
{
"mcpServers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"] }
}
}
VS Code / VS Code Insiders
Üstteki düğme; ya da .vscode/mcp.json:
{
"servers": {
"ardupilot-mcp": { "type": "stdio", "command": "uvx", "args": ["ardupilot-mcp"] }
}
}
Komut satırı: code --add-mcp '{"name":"ardupilot-mcp","command":"uvx","args":["ardupilot-mcp"]}'
Antigravity (IDE + CLI)
~/.gemini/config/mcp_config.json (Windows: %USERPROFILE%\.gemini\config\mcp_config.json) — IDE ile CLI aynı dosyayı paylaşır:
{
"mcpServers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"] }
}
}
IDE: agent panelindeki ... → MCP Servers → View raw config → yapıştır → Refresh. CLI: agy çalıştırıp /mcp ile doğrula.
Windsurf
~/.codeium/windsurf/mcp_config.json (Windows: %USERPROFILE%\.codeium\windsurf\mcp_config.json):
{
"mcpServers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"] }
}
}
Cascade → MCP paneli → View raw config → yapıştır → Refresh.
Cline
Cline paneli → MCP Servers → Configure → cline_mcp_settings.json:
{
"mcpServers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"], "disabled": false, "autoApprove": [] }
}
}
Continue
Çalışma alanında .continue/mcpServers/ardupilot-mcp.yaml:
name: ArduPilot MCP
version: 0.0.1
schema: v1
mcpServers:
- name: ArduPilot MCP
type: stdio
command: uvx
args:
- ardupilot-mcp
Zed
settings.json (context_servers altına):
{
"context_servers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"], "env": {} }
}
}
Goose
goose configure
# Add Extension → Command-line Extension → komut: uvx ardupilot-mcp
LM Studio (açık-kaynak / yerel modeller)
Üstteki Add to LM Studio düğmesi; ya da ~/.lmstudio/mcp.json (Windows: %USERPROFILE%\.lmstudio\mcp.json):
{
"mcpServers": {
"ardupilot-mcp": { "command": "uvx", "args": ["ardupilot-mcp"] }
}
}
Model bağımsız: ardupilot-mcp, MCP'yi stdio üzerinden konuşur; alttaki modelden bağımsız olarak MCP destekli her istemcide çalışır — tamamen açık-kaynak / yerel modeller dahil (ör. LM Studio'da yerel GGUF modeller; Ollama veya LM Studio'ya bağlanan Continue / Cline / Goose). Anthropic/OpenAI hesabı gerektirmez; yeterli olan, istemcinin seçtiği modelin araç-çağırma (tool-calling) desteğidir.
Çalışmıyorsa
- Araç hiç görünmüyor / "command not found: uvx" → uv kurulu değil veya bulunamıyor. uv'yi kur (yukarıdaki link), ya da
pip install ardupilot-mcpyapıp config'i"command": "ardupilot-mcp"olarak değiştir. - Config'i düzenledim ama hâlâ yok → uygulamayı tamamen kapatıp aç (pencere kapatmak yetmez; tepside/menü çubuğunda açık kalır).
- Doğru dosyayı mı düzenledim? → her istemcinin kendi bölümünde yazan tam yolu kullan; JSON'da eksik virgül/parantez olmasın.
- "Dosya bulunamadı" →
.binuzantısı dahil tam yolu ver; Windows'ta yolu çift tırnak içine al. - Motorun kendisi çalışıyor mu? → yukarıdaki AI istemcisi olmadan dene ile bağımsız teyit et (
python examples/analyze.py demo.bin).
Araçlar (hepsi salt-okunur)
| Araç | Ne yapar |
|---|---|
analyze_log(path) |
Tüm kontrol paketini çalıştırır → önem-sıralı bulgular + özet. Her bulgu resmi ArduPilot doküman linkleri taşır; rapor 4.x firmware için sürüm-özel parametre dokümanlarını da içerir. Manşet araç. |
log_summary(path) |
Araç, firmware, süre, mesaj sayıları, uçuş modları, max irtifa, bütünlük. |
vehicle_profile(path) |
Fiziksel / mimari profil: frame & tip, motor sayısı, batarya hücresi/kapasitesi, hover gazı, güç marjı ve itki/ağırlık. Fiziğe-dayalı muhakeme için. |
list_events(path, kinds?, start_s?, end_s?) |
Çözümlenmiş ERR/MODE/EV/MSG zaman çizelgesi. |
query_timeseries(path, message_type, fields, start_s?, end_s?, max_points?) |
Bir bulguya derinlemesine bakmak için seyreltilmiş sayısal seri. |
get_params(path, name_glob?) |
Logun PARM dökümünden parametre değerleri (ör. INS_HNTCH_*), toplam sayı, yorumlamak için sürüm-özel metadata linki, ve döküm eksikse bir uyarı. |
load_param_file(path, name_glob?) |
Kullanıcının dışa aktardığı .param/.params dosyasını okur — log dökümü kesikse veya "uçtuğu config vs şimdiki"yi karşılaştırmak için tam, otoriter config. |
recommend_tuning(path, area?) |
Tavsiye niteliğinde tuning (gyro FFT'sinden harmonik notch, PID, autotune). Sadece öneri — asla uygulanmaz. |
list_checks() |
Kayıtlı teşhis kontrolleri (genişletilebilir katalog). |
Örnek kullanım senaryoları
Sunucuyu istemcine ekledikten sonra yapay zekâya düz dille sor; ilgili araçları kendisi çağırır:
- "
C:\loglar\ucus.binneden düştü?" — tüm kontrol paketini çalıştırır (analyze_log), önem-sıralı bulguları doküman linkleriyle açıklar. - "Bu araç motorlarına göre yeterince güçlü müydü?" —
vehicle_profileile frame / motor / batarya / hover gazından güç marjını ve itki-ağırlık oranını çıkarır. - "15. ile 30. saniye arası titreşim yüksek miydi?" —
query_timeseriesileVIBEserisini çekip eşiklerle karşılaştırır. - "Arming neden engellendi?" —
list_eventsileERR/MSGzaman çizelgesini ve pre-arm uyarılarını çözer. - "
INS_HNTCH_*parametrelerimi göster ve harmonik notch öner." —get_params+recommend_tuning(yalnızca tavsiye, asla uygulanmaz). - "Şu
.paramdosyasını logdaki ayarlarla karşılaştır." —load_param_fileile uçtuğu config'i otoriter dosyayla karşılaştırır.
Claude Code kullanıyorsan (Claude Desktop'tan farklı bir uygulama) ve eklentiyi kurduysan (yukarıdaki Claude Code bölümü — düz MCP-sunucu kurulumu /diagnose eklemez), tek komut yeter: /diagnose C:\loglar\ucus.bin — uçtan uca teşhisi yukarıdaki araçları sırayla kullanarak yapar. Diğer istemcilerde bunun yerine düz dille sor.
Neden log teşhisi?
Bir ArduPilot .bin logunu okumak uzmanlık ister: ERR satırlarını filtreler, mekanik arıza için ATT.DesRoll ile ATT.Roll'u karşılaştırır, titreşim / EKF / batarya clipping'ine göz gezdirirsin. Drone'un düştüğünde "neden?" sorusunun cevabı bu logun içindedir ama okumak doktorun röntgen okuması gibidir. Bu sunucu o kontrolleri deterministik olarak çalıştırır ve yapay zekânın sonucu sade dille anlatmasını sağlar.
Nasıl çalışır
.bin ──▶ parser.py (pymavlink DFReader) ──▶ FlightLog (saf domain modeli)
│
▼
checks/ registry ──▶ Check eklentileri (her biri bir konu)
│
▼
orchestrator.diagnose() ──▶ DiagnosisReport (yapısal)
│
▼
server.py (FastMCP, stdio) ──▶ Yapay zekâ bulguları anlatır
- Anahtar ilke: deterministik motor tek doğruluk kaynağı; yapay zekâ sadece açıklar ve kaynak gösterir, karar vermez.
FlightLogsaf,pymavlink-bağımsız bir domain modelidir; bu yüzden kontroller ve testler gerçek.binolmadan sentetik loglarla çalışır.- Kontroller bağımsız, registry'e kayıtlı eklentilerdir (
@register_check). Yeni bir tane eklemek = tek bir yeni modül. Orchestrator, verisi loglanmamış kontrolü zarifçe atlar, araç tipine uymayanı (ör. heli/uçakta motor-dengesi) çalıştırmaz ve hata fırlatan kontrolü izole eder. - Katalog iki aile: Uçuş dinamiği — olaylar/hatalar, EKF sağlığı, titreşim, güç (BAT/CURR), GPS (fix/uydu/HDOP, armed pencerede), pusula, attitude takibi, motor dengesi, RC sinyal kaybı, zamanlama. Konfigürasyon & kurulum (çünkü çoğu kaza uçuş anında değil kurulum hatasıdır): riskli parametreler (kapalı arming/failsafe), çelişkili/kapalı/mantıksız değerlerin parametre denetimi, kalibrasyon (büyük/sıfır pusula offset'i), yapılandırılmış-ama-sessiz sensörler (kablo/bağlantı arızası), ve firmware'in kendi pre-arm/açılış uyarıları. Artı tavsiye niteliğinde tuning.
- Araç-farkında (copter / heli / uçak / rover): çoklu-rotora özel kontroller bir helinin swashplate servolarında ya da bir uçağın kontrol yüzeylerinde çalışmaz. Copter 3.2–4.6, Plane, QuadPlane, Heli ve Rover'ı kapsayan 40 gerçek forum loguyla doğrulandı.
- Bulgular doküman-temelli: her biri ilgili resmi ArduPilot sayfasına link verir; raporlar 4.x için sürüm-özel parametre tanımlarını (
apm.pdef.xml) yüzeye çıkarır. Sunucu offline/deterministik kalır; bu işaretçileri web erişimi olan yapay zekâya verir, o okur ve alıntılar. - Fiziksel profil (
vehicle_profile) logu airframe gerçeklerine dönüştürür — frame, motor sayısı, batarya hücresi ve özellikle güç marjı (hover gazı → itki/ağırlık). Motorlarını sonuna kadar açıp düşen gerçek bir 12 kg'lık quad'da "underpowered, %69 gazda asılı, sadece %31 pay" diyor — kazanın asıl sebebi.
Güvenlik
Bu sürüm offline ve salt-okunur. MAVLink bağlantısı yok, arming yok, parametre yazma yok, aktüasyon yok. Tuning çıktısı sadece tavsiyedir. Canlı-araç özellikleri (düzgün bir güvenlik gateway'i ile: SITL-önce, insan-onayı, kill switch) bilinçli olarak kapsam dışı ve ertelenmiş.
Kaynaklar & varsayımlar
Koddaki her sayısal eşik, enum, varsayılan ve davranışsal iddia otoriter kaynaklara karşı (ArduPilot wiki/firmware, MAVLink, MCP spec) docs/SOURCES.md'de denetlenmiştir — her biri onaylandı (atıflı), heuristik (bizim ihtiyatlı seçimimiz, en yakın rehber atıflı) veya tasarım kararı (bizim severity sınırımız) olarak işaretli. Bu denetim 8 gerçek hatayı bulup düzeltti (ör. yanlış bir heli FRAME_CLASS kümesi, yanlış-numaralı event id'leri, innovation test-ratio'su olmayan bir EKF alanı).
Geliştirme
Katkılar için: CONTRIBUTING.md ve AGENTS.md (insanlar ve yapay zekâ asistanları için kurallar).
pip install -e ".[dev]"
ruff check ardupilot_mcp tests # lint
mypy ardupilot_mcp # tip kontrolü
pytest # testler
Kontroller sentetik in-memory loglarla (tests/helpers.py) test edilir; sentetik bir DataFlash yazıcısı (tests/synth_bin.py) parser'a round-trip için gerçek, hermetik bir .bin verir — repoya büyük ikili fixture girmez.
Bilinen sınırlamalar
- Toilet-bowl / pusula-heading arızaları henüz tespit edilmiyor — sadece alan-büyüklüğü stabilitesi değil, dairesel-pozisyon-drift analizi gerektiriyor (planlı).
- Gerçekten bozuk bir log (ör. bit-flip'li mesaj formatı) kısmi-kurtarma yerine net bir hatayla başarısız olur.
- Büyük loglar (3–4 MB / ~100k kayıt) ~12–15 sn'de parse olur; MCP sunucusu parse'ı path+mtime ile cache'ler, yani bu maliyeti sadece ilk araç çağrısı öder.
Yol haritası
- Bu sürüm: ArduPilot offline
.binteşhisi + tuning tavsiyesi + genişletilebilir kontrol çerçevesi. - PX4 / ULog desteği (ayrı parser + kurallar; ortak teşhis soyutlaması).
- Canlı MAVLink bağlantısı (SITL-önce) + tam güvenlik gateway'i.
- Topluluk kontrol-paylaşımı; onay-kapılı tuning uygulaması.
Lisans
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ardupilot_mcp-0.1.2.tar.gz.
File metadata
- Download URL: ardupilot_mcp-0.1.2.tar.gz
- Upload date:
- Size: 90.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e01a9b0dc47684aeeeb1280ec2681ce0b846ad8d0630eddbc39ba39dab10ea57
|
|
| MD5 |
dcb9a7c939f6fa0524509baa63261075
|
|
| BLAKE2b-256 |
51051f94485a74406a2f9a114ea2d80b65b6f0ffb6111a7dd4efad447c674d0c
|
Provenance
The following attestation bundles were made for ardupilot_mcp-0.1.2.tar.gz:
Publisher:
publish.yml on furkanisikay/ardupilot-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ardupilot_mcp-0.1.2.tar.gz -
Subject digest:
e01a9b0dc47684aeeeb1280ec2681ce0b846ad8d0630eddbc39ba39dab10ea57 - Sigstore transparency entry: 1819865323
- Sigstore integration time:
-
Permalink:
furkanisikay/ardupilot-mcp@2b0f53207a65f6e4a5c35d90d043a3afa76a3911 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/furkanisikay
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@2b0f53207a65f6e4a5c35d90d043a3afa76a3911 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file ardupilot_mcp-0.1.2-py3-none-any.whl.
File metadata
- Download URL: ardupilot_mcp-0.1.2-py3-none-any.whl
- Upload date:
- Size: 88.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3656e0b041e3c76054dad41e02fc4f96795d9eba5f41a16d2741a56e993843c1
|
|
| MD5 |
49552ec091520d6ec438535b40df2de4
|
|
| BLAKE2b-256 |
8b691a43a377ad3c4c4ff8749359a40954a4ccd9fca3fc3ecb82ec2cc64fe324
|
Provenance
The following attestation bundles were made for ardupilot_mcp-0.1.2-py3-none-any.whl:
Publisher:
publish.yml on furkanisikay/ardupilot-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ardupilot_mcp-0.1.2-py3-none-any.whl -
Subject digest:
3656e0b041e3c76054dad41e02fc4f96795d9eba5f41a16d2741a56e993843c1 - Sigstore transparency entry: 1819865336
- Sigstore integration time:
-
Permalink:
furkanisikay/ardupilot-mcp@2b0f53207a65f6e4a5c35d90d043a3afa76a3911 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/furkanisikay
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@2b0f53207a65f6e4a5c35d90d043a3afa76a3911 -
Trigger Event:
workflow_dispatch
-
Statement type: