[{"data":1,"prerenderedAt":3506},["ShallowReactive",2],{"navigation":3,"/blog/software-development/1200-looms-how-async-video-became-our-development-superpower-post":734,"/blog/software-development/1200-looms-how-async-video-became-our-development-superpower-surround":1253,"/blog/software-development/1200-looms-how-async-video-became-our-development-superpower-related":1258},[4,70,207,312,721],{"title":5,"path":6,"stem":7,"children":8,"page":69},"Case Study","/blog/case-study","blog/case-study",[9,13,17,21,25,29,33,37,41,45,49,53,57,61,65],{"title":10,"path":11,"stem":12},"Ambistream – Multi-Layer Streaming Platform","/blog/case-study/ambistream-building-a-multi-layer-streaming-platform-from-a-spark-of-an-idea","blog/case-study/ambistream-building-a-multi-layer-streaming-platform-from-a-spark-of-an-idea",{"title":14,"path":15,"stem":16},"Custom Chromecast & AirPlay Casting App","/blog/case-study/chromecast-airplay-casting-app-case-study","blog/case-study/chromecast-airplay-casting-app-case-study",{"title":18,"path":19,"stem":20},"Direct Music Licensing Platform Case Study","/blog/case-study/dlm-music-catalog-case-study","blog/case-study/dlm-music-catalog-case-study",{"title":22,"path":23,"stem":24},"Assembly Instructions App - Galeco Mobile App","/blog/case-study/galeco-mobile-app-case-study","blog/case-study/galeco-mobile-app-case-study",{"title":26,"path":27,"stem":28},"MemoSonic: Building an Audio Memory Game","/blog/case-study/how-we-built-memosonic-accessible-audio-memory-game-flutter","blog/case-study/how-we-built-memosonic-accessible-audio-memory-game-flutter",{"title":30,"path":31,"stem":32},"Loyalty Program App for Shopping Mall","/blog/case-study/loyalty-program-application-case-study","blog/case-study/loyalty-program-application-case-study",{"title":34,"path":35,"stem":36},"Mobile Application for Music Catalogs","/blog/case-study/mobile-app-for-music-catalog","blog/case-study/mobile-app-for-music-catalog",{"title":38,"path":39,"stem":40},"Universal Music Data Parser for 20+ Platforms","/blog/case-study/musicdata-lab-universal-music-data-parser-case-study","blog/case-study/musicdata-lab-universal-music-data-parser-case-study",{"title":42,"path":43,"stem":44},"Panther ML/AI Pricing Recommendation Tool","/blog/case-study/panther-pricing-recommendation-tool-case-study","blog/case-study/panther-pricing-recommendation-tool-case-study",{"title":46,"path":47,"stem":48},"4D Grupa Roofing Wholesalers Platform","/blog/case-study/roofing-wholesalers-website-case-study","blog/case-study/roofing-wholesalers-website-case-study",{"title":50,"path":51,"stem":52},"Talent Alpha HR Frontend Platform","/blog/case-study/talent-alpha-hr-platform-case-study","blog/case-study/talent-alpha-hr-platform-case-study",{"title":54,"path":55,"stem":56},"Ticketing & Events Platform Development","/blog/case-study/ticketing-events-platform-case-study","blog/case-study/ticketing-events-platform-case-study",{"title":58,"path":59,"stem":60},"Turn Fans into Superfans — Roadie.co","/blog/case-study/turn-fans-into-superfans-roadie-co","blog/case-study/turn-fans-into-superfans-roadie-co",{"title":62,"path":63,"stem":64},"Walkative 2.0 Global Booking Engine","/blog/case-study/walkative-2-booking-platform-case-study","blog/case-study/walkative-2-booking-platform-case-study",{"title":66,"path":67,"stem":68},"Why Merch Is the New Royalty Check, and How Tech Is Closing the Gap","/blog/case-study/why-merch-is-the-new-royalty-check","blog/case-study/why-merch-is-the-new-royalty-check",false,{"title":71,"path":72,"stem":73,"children":74,"page":69},"Music Data","/blog/music-data","blog/music-data",[75,79,83,87,91,95,99,103,107,111,115,119,123,127,131,135,139,143,147,151,155,159,163,167,171,175,179,183,187,191,195,199,203],{"title":76,"path":77,"stem":78},"13 Distributors, 5 File Formats, Zero Standards -The Reality of Music Royalty Data","/blog/music-data/13-distributors-5-file-formats-zero-standards-the-reality-of-music-royalty-data","blog/music-data/13-distributors-5-file-formats-zero-standards-the-reality-of-music-royalty-data",{"title":80,"path":81,"stem":82},"830 Ways to Say Spotify - Normalizing Music Streaming Data","/blog/music-data/830-ways-to-say-spotify-normalizing-music-streaming-data","blog/music-data/830-ways-to-say-spotify-normalizing-music-streaming-data",{"title":84,"path":85,"stem":86},"Why Music Companies Need AI-Powered Analytics (And How We Built One)","/blog/music-data/ai-powered-analytics-dashboard-django-clickhouse-ollama","blog/music-data/ai-powered-analytics-dashboard-django-clickhouse-ollama",{"title":88,"path":89,"stem":90},"AI Rehearsal: Spaced Repetition for Your Musical Ideas","/blog/music-data/ai-rehearsal-spaced-repetition-for-musical-ideas","blog/music-data/ai-rehearsal-spaced-repetition-for-musical-ideas",{"title":92,"path":93,"stem":94},"Audio Project Organization Is a Mess — Here's Why","/blog/music-data/audio-project-organization-mess","blog/music-data/audio-project-organization-mess",{"title":96,"path":97,"stem":98},"Why Audio Search Is Still Broken and How to Fix It with Embeddings","/blog/music-data/audio-search-broken-fix-with-embeddings","blog/music-data/audio-search-broken-fix-with-embeddings",{"title":100,"path":101,"stem":102},"AI Song Structure Analysis: Intro, Verse, Chorus","/blog/music-data/automatic-song-structure-analysis-how-ai-detects-intro-verse-chorus","blog/music-data/automatic-song-structure-analysis-how-ai-detects-intro-verse-chorus",{"title":104,"path":105,"stem":106},"The Broken Feedback Loop in Music Collaboration","/blog/music-data/broken-feedback-loop-music-collaboration","blog/music-data/broken-feedback-loop-music-collaboration",{"title":108,"path":109,"stem":110},"Building a Claude Skill for DDEX Validation: Automate Music Metadata Checks with AI","/blog/music-data/building-a-claude-skill-for-ddex-validation-music-metadata","blog/music-data/building-a-claude-skill-for-ddex-validation-music-metadata",{"title":112,"path":113,"stem":114},"Building a Custom Music Delivery Platform on the Revelator API","/blog/music-data/building-a-custom-music-delivery-platform-on-the-revelator-api","blog/music-data/building-a-custom-music-delivery-platform-on-the-revelator-api",{"title":116,"path":117,"stem":118},"Building a Suno AI Remix App with Nuxt & Firebase","/blog/music-data/building-a-suno-remix-app-with-nuxt-and-firebase","blog/music-data/building-a-suno-remix-app-with-nuxt-and-firebase",{"title":120,"path":121,"stem":122},"C2PA & DDEX: Authenticity Meets Rights in the Age of AI Music","/blog/music-data/c2pa-and-ddex-authenticity-meets-rights-in-the-age-of-ai-music","blog/music-data/c2pa-and-ddex-authenticity-meets-rights-in-the-age-of-ai-music",{"title":124,"path":125,"stem":126},"C2PA in Music: A Claude MCP for Reading Content Provenance","/blog/music-data/c2pa-in-music-mcp","blog/music-data/c2pa-in-music-mcp",{"title":128,"path":129,"stem":130},"Data Modeling in MongoDB Using Design Patterns","/blog/music-data/data-modeling-in-mongodb-with-the-usage-of-design-patterns","blog/music-data/data-modeling-in-mongodb-with-the-usage-of-design-patterns",{"title":132,"path":133,"stem":134},"Office Hours with MusicTech Lab's DDEX Expert","/blog/music-data/ddex-office-hours-musictech","blog/music-data/ddex-office-hours-musictech",{"title":136,"path":137,"stem":138},"DDEX Open Source Projects Review","/blog/music-data/ddex-open-source-projects-review","blog/music-data/ddex-open-source-projects-review",{"title":140,"path":141,"stem":142},"Extracting Data from Ableton .als and .asd Files","/blog/music-data/extracting-data-from-ableton-als-asd-files","blog/music-data/extracting-data-from-ableton-als-asd-files",{"title":144,"path":145,"stem":146},"Maciej Dulski on Sound Connections Podcast","/blog/music-data/from-startups-to-musictech-maciej-dulski-on-sound-connections-podcast","blog/music-data/from-startups-to-musictech-maciej-dulski-on-sound-connections-podcast",{"title":148,"path":149,"stem":150},"How to Transcribe Video to Text Using OpenAI Whisper","/blog/music-data/how-to-transcribe-video-to-text-using-whisper","blog/music-data/how-to-transcribe-video-to-text-using-whisper",{"title":152,"path":153,"stem":154},"Epidemic Sound MCP with Claude for Devs","/blog/music-data/how-to-use-epidemic-sound-mcp-with-claude","blog/music-data/how-to-use-epidemic-sound-mcp-with-claude",{"title":156,"path":157,"stem":158},"Hybrid Database Model in Django for Speed","/blog/music-data/hybrid-database-model-in-django-as-a-performance-booster","blog/music-data/hybrid-database-model-in-django-as-a-performance-booster",{"title":160,"path":161,"stem":162},"Introduction to generating DDEX file using Python","/blog/music-data/introduction-to-generating-ddex-file-using-python","blog/music-data/introduction-to-generating-ddex-file-using-python",{"title":164,"path":165,"stem":166},"Maintaining Music Tech Tools: The SLA Dilemma for Small Teams","/blog/music-data/maintaining-music-tech-tools-the-sla-dilemma-for-small-teams","blog/music-data/maintaining-music-tech-tools-the-sla-dilemma-for-small-teams",{"title":168,"path":169,"stem":170},"Querying Bandcamp Revenue Reports with Natural Language — Meet mtl-bandcamp-mcp","/blog/music-data/mtl-bandcamp-mcp-open-source-revenue-dashboard","blog/music-data/mtl-bandcamp-mcp-open-source-revenue-dashboard",{"title":172,"path":173,"stem":174},"mtl-metadata-mcp: Open Source Audio Metadata Embedding for Claude Code","/blog/music-data/mtl-metadata-mcp-open-source-audio-metadata-embedding","blog/music-data/mtl-metadata-mcp-open-source-audio-metadata-embedding",{"title":176,"path":177,"stem":178},"MusicTech Resources for Builders","/blog/music-data/musictech-resources-curated-insights-for-the-musictech-builders","blog/music-data/musictech-resources-curated-insights-for-the-musictech-builders",{"title":180,"path":181,"stem":182},"Poland's Creative Tech and MusicTech Rise","/blog/music-data/polands-creative-tech-sector-is-on-the-rise-and-musictech-is-part-of-it","blog/music-data/polands-creative-tech-sector-is-on-the-rise-and-musictech-is-part-of-it",{"title":184,"path":185,"stem":186},"Batch ISRC Enrichment That Turns Messy Catalogs Into Clean Data","/blog/music-data/scout-isrc-metadata-enrichment-spotify-musicbrainz","blog/music-data/scout-isrc-metadata-enrichment-spotify-musicbrainz",{"title":188,"path":189,"stem":190},"Music Self-Publishing: The Emuze.me Story","/blog/music-data/self-publishing-in-the-music-industry-a-tale-of-emuze-me","blog/music-data/self-publishing-in-the-music-industry-a-tale-of-emuze-me",{"title":192,"path":193,"stem":194},"Understanding the API First Approach","/blog/music-data/understanding-the-api-first-approach","blog/music-data/understanding-the-api-first-approach",{"title":196,"path":197,"stem":198},"The Voice Memo Graveyard Problem","/blog/music-data/voice-memo-graveyard-problem","blog/music-data/voice-memo-graveyard-problem",{"title":200,"path":201,"stem":202},"Which Database for Music Data? Redshift vs BigQuery vs ClickHouse and When to Use Each","/blog/music-data/which-database-for-music-data-redshift-vs-bigquery-vs-clickhouse","blog/music-data/which-database-for-music-data-redshift-vs-bigquery-vs-clickhouse",{"title":204,"path":205,"stem":206},"Why we decided to use wavesurfer.js","/blog/music-data/why-we-decided-to-use-wavesurfer","blog/music-data/why-we-decided-to-use-wavesurfer",{"title":208,"path":209,"stem":210,"children":211,"page":69},"Newsletter","/blog/newsletter","blog/newsletter",[212,216,220,224,228,232,236,240,244,248,252,256,260,264,268,272,276,280,284,288,292,296,300,304,308],{"title":213,"path":214,"stem":215},"Music Industry Tech Openings (April 2024 Update)","/blog/newsletter/music-industry-tech-openings-april-2024-update","blog/newsletter/music-industry-tech-openings-april-2024-update",{"title":217,"path":218,"stem":219},"Music Industry Tech Openings (April 2025 Update)","/blog/newsletter/music-industry-tech-openings-april-2025-update","blog/newsletter/music-industry-tech-openings-april-2025-update",{"title":221,"path":222,"stem":223},"Music Industry Tech Openings (August 2024 Update)","/blog/newsletter/music-industry-tech-openings-august-2024-update","blog/newsletter/music-industry-tech-openings-august-2024-update",{"title":225,"path":226,"stem":227},"Music Industry Tech Openings (December 2024 Update)","/blog/newsletter/music-industry-tech-openings-december-2024-update","blog/newsletter/music-industry-tech-openings-december-2024-update",{"title":229,"path":230,"stem":231},"Music Industry Tech Openings (February 2025 Update)","/blog/newsletter/music-industry-tech-openings-february-2025-update","blog/newsletter/music-industry-tech-openings-february-2025-update",{"title":233,"path":234,"stem":235},"Music Industry Tech Openings (January 2025 Update)","/blog/newsletter/music-industry-tech-openings-january-2025-update","blog/newsletter/music-industry-tech-openings-january-2025-update",{"title":237,"path":238,"stem":239},"Music Industry Tech Openings (July 2024 Update)","/blog/newsletter/music-industry-tech-openings-july-2024-update","blog/newsletter/music-industry-tech-openings-july-2024-update",{"title":241,"path":242,"stem":243},"Music Industry Tech Openings (June 2024 Update)","/blog/newsletter/music-industry-tech-openings-june-2024-update","blog/newsletter/music-industry-tech-openings-june-2024-update",{"title":245,"path":246,"stem":247},"Music Industry Tech Openings (March 2025 Update)","/blog/newsletter/music-industry-tech-openings-march-2025-update","blog/newsletter/music-industry-tech-openings-march-2025-update",{"title":249,"path":250,"stem":251},"Music Industry Tech Openings (May 2024 Update)","/blog/newsletter/music-industry-tech-openings-may-2024-update","blog/newsletter/music-industry-tech-openings-may-2024-update",{"title":253,"path":254,"stem":255},"Music Industry Tech Openings (May 2025 Update)","/blog/newsletter/music-industry-tech-openings-may-2025","blog/newsletter/music-industry-tech-openings-may-2025",{"title":257,"path":258,"stem":259},"Music Industry Tech Openings (November 2024 Update)","/blog/newsletter/music-industry-tech-openings-november-2024-update","blog/newsletter/music-industry-tech-openings-november-2024-update",{"title":261,"path":262,"stem":263},"Music Industry Tech Openings (October 2024 Update)","/blog/newsletter/music-industry-tech-openings-october-2024-update","blog/newsletter/music-industry-tech-openings-october-2024-update",{"title":265,"path":266,"stem":267},"Music Industry Tech Openings (September 2024 Update)","/blog/newsletter/music-industry-tech-openings-september-2024-update","blog/newsletter/music-industry-tech-openings-september-2024-update",{"title":269,"path":270,"stem":271},"MusicTech Insights #1 by Maciej Dulski","/blog/newsletter/musictech-insights-1-curated-by-maciej-dulski","blog/newsletter/musictech-insights-1-curated-by-maciej-dulski",{"title":273,"path":274,"stem":275},"Provenance, Not Detection, Is the Durable Answer","/blog/newsletter/musictech-insights-10-curated-by-jim-anderson","blog/newsletter/musictech-insights-10-curated-by-jim-anderson",{"title":277,"path":278,"stem":279},"What CMOs can teach us about innovation in uncertain times","/blog/newsletter/musictech-insights-10-curated-by-joanna-kurkowska","blog/newsletter/musictech-insights-10-curated-by-joanna-kurkowska",{"title":281,"path":282,"stem":283},"Feeling the MusicTech Momentum","/blog/newsletter/musictech-insights-2-curated-by-maciej-dulski","blog/newsletter/musictech-insights-2-curated-by-maciej-dulski",{"title":285,"path":286,"stem":287},"AI in Music: Hype, Hope, and a Human Touch","/blog/newsletter/musictech-insights-3-curated-by-drew-thurlow","blog/newsletter/musictech-insights-3-curated-by-drew-thurlow",{"title":289,"path":290,"stem":291},"The Music Metadata Conundrum","/blog/newsletter/musictech-insights-4-curated-by-amanda-schupf","blog/newsletter/musictech-insights-4-curated-by-amanda-schupf",{"title":293,"path":294,"stem":295},"7 Rounds in the First 10 Days of November 2025","/blog/newsletter/musictech-insights-5-curated-by-maciej-dulski","blog/newsletter/musictech-insights-5-curated-by-maciej-dulski",{"title":297,"path":298,"stem":299},"The End of an Era: It's All About to Crash","/blog/newsletter/musictech-insights-6-curated-by-sigurdur-arnason","blog/newsletter/musictech-insights-6-curated-by-sigurdur-arnason",{"title":301,"path":302,"stem":303},"Low-Code Magic Won't Solve MusicTech Reality","/blog/newsletter/musictech-insights-7-curated-by-mariusz-smenzyk","blog/newsletter/musictech-insights-7-curated-by-mariusz-smenzyk",{"title":305,"path":306,"stem":307},"The New Economics of Game Music","/blog/newsletter/musictech-insights-8-curated-by-kenny-vaughan","blog/newsletter/musictech-insights-8-curated-by-kenny-vaughan",{"title":309,"path":310,"stem":311},"Music Business Meets Direct-to-Fan","/blog/newsletter/musictech-insights-9-curated-by-yaw-asamani","blog/newsletter/musictech-insights-9-curated-by-yaw-asamani",{"title":313,"path":314,"stem":315,"children":316,"page":69},"Software Development","/blog/software-development","blog/software-development",[317,321,325,329,333,337,341,345,349,353,357,361,365,369,373,377,381,385,389,393,397,401,405,409,413,417,421,425,429,433,437,441,445,449,453,457,461,465,469,473,477,481,485,489,493,497,501,505,509,513,517,521,525,529,533,537,541,545,549,553,557,561,565,569,573,577,581,585,589,593,597,601,605,609,613,617,621,625,629,633,637,641,645,649,653,657,661,665,669,673,677,681,685,689,693,697,701,705,709,713,717],{"title":318,"path":319,"stem":320},"Benefits of Outsourcing Software Development","/blog/software-development/10-benefits-of-outsourcing-software-development-services","blog/software-development/10-benefits-of-outsourcing-software-development-services",{"title":322,"path":323,"stem":324},"10 Steps to Find the Best MVP Developers","/blog/software-development/10-steps-to-find-the-best-mvp-developers-for-your-startup-idea","blog/software-development/10-steps-to-find-the-best-mvp-developers-for-your-startup-idea",{"title":326,"path":327,"stem":328},"1,200 Looms Later: How Async Video Became My Development Superpower","/blog/software-development/1200-looms-how-async-video-became-our-development-superpower","blog/software-development/1200-looms-how-async-video-became-our-development-superpower",{"title":330,"path":331,"stem":332},"Communication Strategy in Outsourcing Projects","/blog/software-development/5-steps-to-implement-an-effective-communication-strategy-in-outsourcing-software-development-project","blog/software-development/5-steps-to-implement-an-effective-communication-strategy-in-outsourcing-software-development-project",{"title":334,"path":335,"stem":336},"7 Best Practices for Outsourcing Software Development","/blog/software-development/7-best-practices-for-outsourcing-software-development","blog/software-development/7-best-practices-for-outsourcing-software-development",{"title":338,"path":339,"stem":340},"9 Reasons Why Saleor.io Is Best for eCommerce","/blog/software-development/9-reasons-why-the-saleor-io-platform-is-the-best-choice-for-your-ecommerce-website","blog/software-development/9-reasons-why-the-saleor-io-platform-is-the-best-choice-for-your-ecommerce-website",{"title":342,"path":343,"stem":344},"A Look at Bravelab.io’s Clutch 2021 Year In Review","/blog/software-development/a-look-at-bravelab-ios-clutch-2021-year-in-review","blog/software-development/a-look-at-bravelab-ios-clutch-2021-year-in-review",{"title":346,"path":347,"stem":348},"A quick introduction to profit sharing implementation","/blog/software-development/a-quick-introduction-to-profit-sharing-implementation","blog/software-development/a-quick-introduction-to-profit-sharing-implementation",{"title":350,"path":351,"stem":352},"AI Audio Similarity Search: The Future of Sound Library Discovery","/blog/software-development/ai-audio-similarity-search-for-sound-libraries","blog/software-development/ai-audio-similarity-search-for-sound-libraries",{"title":354,"path":355,"stem":356},"Automate Repetitive Tasks for Better Results","/blog/software-development/automate-repetitive-tasks-to-improve-your-business-performance","blog/software-development/automate-repetitive-tasks-to-improve-your-business-performance",{"title":358,"path":359,"stem":360},"Automating Success: The Art of Unified Documentation","/blog/software-development/automating-success-the-art-of-unified-documentation","blog/software-development/automating-success-the-art-of-unified-documentation",{"title":362,"path":363,"stem":364},"Brave 3.0 Website Redesign, Part 2: Solution","/blog/software-development/brave-3-0-how-we-conducted-website-redesign-part-2-solution","blog/software-development/brave-3-0-how-we-conducted-website-redesign-part-2-solution",{"title":366,"path":367,"stem":368},"Brave 3.0, Part 4: Tech Stack and Recap","/blog/software-development/brave-3-0-part-4-technologies-behind-and-final-series-recap","blog/software-development/brave-3-0-part-4-technologies-behind-and-final-series-recap",{"title":370,"path":371,"stem":372},"Brave 3.0 – redesign process part 1. The Challenge","/blog/software-development/brave-3-0-redesign-process-part-1-challenge","blog/software-development/brave-3-0-redesign-process-part-1-challenge",{"title":374,"path":375,"stem":376},"Brave 3.0 – redesign process, part 3. Lesson learned","/blog/software-development/brave-3-0-redesign-process-part-3-lesson-learned","blog/software-development/brave-3-0-redesign-process-part-3-lesson-learned",{"title":378,"path":379,"stem":380},"Bravelab.io: Top Software Developer by Clutch","/blog/software-development/bravelab-io-is-recognized-as-a-top-custom-software-developer-by-clutch","blog/software-development/bravelab-io-is-recognized-as-a-top-custom-software-developer-by-clutch",{"title":382,"path":383,"stem":384},"Bravelab.io: Top Developer in Poland by Clutch","/blog/software-development/bravelab-io-named-top-software-developer-in-poland-by-clutch","blog/software-development/bravelab-io-named-top-software-developer-in-poland-by-clutch",{"title":386,"path":387,"stem":388},"MusicTech Lab Partners with LALAL.AI","/blog/software-development/bravelab-partners-with-the-audio-lalal-ai","blog/software-development/bravelab-partners-with-the-audio-lalal-ai",{"title":390,"path":391,"stem":392},"MusicTech Lab Partners with The Audio Programmer","/blog/software-development/bravelab-partners-with-the-audio-programmer","blog/software-development/bravelab-partners-with-the-audio-programmer",{"title":394,"path":395,"stem":396},"Bravelab's team about productivity","/blog/software-development/bravelabs-team-about-productivity","blog/software-development/bravelabs-team-about-productivity",{"title":398,"path":399,"stem":400},"Braveloper","/blog/software-development/braveloper","blog/software-development/braveloper",{"title":402,"path":403,"stem":404},"Bravely App: Boost Productivity with Django","/blog/software-development/bravely-app-how-to-be-more-productive-with-django-quick","blog/software-development/bravely-app-how-to-be-more-productive-with-django-quick",{"title":406,"path":407,"stem":408},"DIY MIDI Controller for Ableton with Arduino","/blog/software-development/building-a-diy-midi-controller-for-ableton-live-with-arduino","blog/software-development/building-a-diy-midi-controller-for-ableton-live-with-arduino",{"title":410,"path":411,"stem":412},"C2PA in Ableton: Making AI Music Provenance Visible Inside Your DAW","/blog/software-development/c2pa-in-ableton-max-for-live","blog/software-development/c2pa-in-ableton-max-for-live",{"title":414,"path":415,"stem":416},"Change Detection mechanism in Angular","/blog/software-development/change-detection-mechanism-in-angular","blog/software-development/change-detection-mechanism-in-angular",{"title":418,"path":419,"stem":420},"Communication Channels in Remote Work","/blog/software-development/comparison-of-the-communication-channels-in-remote-work","blog/software-development/comparison-of-the-communication-channels-in-remote-work",{"title":422,"path":423,"stem":424},"Connecting Your Max for Live Device to a Cloud API","/blog/software-development/connecting-your-max-for-live-device-to-a-cloud-api","blog/software-development/connecting-your-max-for-live-device-to-a-cloud-api",{"title":426,"path":427,"stem":428},"From Voice Memo to Studio: The Cross-Platform Problem for Creators","/blog/software-development/cross-platform-problem-for-creators","blog/software-development/cross-platform-problem-for-creators",{"title":430,"path":431,"stem":432},"Cultural transformation through the pandemic era","/blog/software-development/cultural-transformation-through-the-pandemic-era","blog/software-development/cultural-transformation-through-the-pandemic-era",{"title":434,"path":435,"stem":436},"D-Commerce Decoded: Cutting Through the Hype","/blog/software-development/d-commerce-decoded-cutting-through-the-hype","blog/software-development/d-commerce-decoded-cutting-through-the-hype",{"title":438,"path":439,"stem":440},"Dev Meeting 002: Intro to DDD","/blog/software-development/dev-meeting-002-introduction-to-domain-driven-design-ddd","blog/software-development/dev-meeting-002-introduction-to-domain-driven-design-ddd",{"title":442,"path":443,"stem":444},"Dev Meeting 003: Web3 Primer","/blog/software-development/dev-meeting-003-web3-primer","blog/software-development/dev-meeting-003-web3-primer",{"title":446,"path":447,"stem":448},"Dev Meeting 004: Introduction to Event Storming","/blog/software-development/dev-meeting-004-introduction-to-event-storming","blog/software-development/dev-meeting-004-introduction-to-event-storming",{"title":450,"path":451,"stem":452},"Dev Meeting 001: Kubernetes is a Framework","/blog/software-development/dev-meeting-kubernetes-is-a-framework","blog/software-development/dev-meeting-kubernetes-is-a-framework",{"title":454,"path":455,"stem":456},"Did You Know? 10 Developer Tips from Real Codebases","/blog/software-development/did-you-know-dev-tips-part-1","blog/software-development/did-you-know-dev-tips-part-1",{"title":458,"path":459,"stem":460},"10 Surprising MusicTech Facts (Part 2)","/blog/software-development/did-you-know-musictech-facts-part-2","blog/software-development/did-you-know-musictech-facts-part-2",{"title":462,"path":463,"stem":464},"Django-cms and GraphQL","/blog/software-development/django-cms-and-graphql","blog/software-development/django-cms-and-graphql",{"title":466,"path":467,"stem":468},"Does Zappa make it super easy?","/blog/software-development/does-zappa-make-it-super-easy","blog/software-development/does-zappa-make-it-super-easy",{"title":470,"path":471,"stem":472},"Establishing cooperation between Netlify and Bravelab","/blog/software-development/establishing-cooperation-between-netlify-and-bravelab","blog/software-development/establishing-cooperation-between-netlify-and-bravelab",{"title":474,"path":475,"stem":476},"Export Ableton Locators to JSON via Max for Live","/blog/software-development/exporting-ableton-live-locators-to-json-with-max-for-live","blog/software-development/exporting-ableton-live-locators-to-json-with-max-for-live",{"title":478,"path":479,"stem":480},"IT Outsourcing: Success and Failure Factors","/blog/software-development/factors-that-contribute-to-the-success-or-failure-of-an-it-outsourcing-project","blog/software-development/factors-that-contribute-to-the-success-or-failure-of-an-it-outsourcing-project",{"title":482,"path":483,"stem":484},"Flutter 2022 Strategy: Analyzing the Roadmap","/blog/software-development/flutter-strategy-for-2022-analyzing-the-new-flutter-roadmap","blog/software-development/flutter-strategy-for-2022-analyzing-the-new-flutter-roadmap",{"title":486,"path":487,"stem":488},"Git Better #1 — Commit Message Convention","/blog/software-development/git-better-1-see-more-with-a-commit-message-convention","blog/software-development/git-better-1-see-more-with-a-commit-message-convention",{"title":490,"path":491,"stem":492},"Hasura in action. How to use it with Django","/blog/software-development/hasura-in-action","blog/software-development/hasura-in-action",{"title":494,"path":495,"stem":496},"Holacracy why and where we are","/blog/software-development/holacracy-why-and-where-we-are","blog/software-development/holacracy-why-and-where-we-are",{"title":498,"path":499,"stem":500},"How does JavaScript work","/blog/software-development/how-does-javascript-work","blog/software-development/how-does-javascript-work",{"title":502,"path":503,"stem":504},"How important is good UX/UI design?","/blog/software-development/how-important-is-good-ux-ui-design","blog/software-development/how-important-is-good-ux-ui-design",{"title":506,"path":507,"stem":508},"How repetitive tasks impact your business","/blog/software-development/how-repetitive-tasks-impact-your-business","blog/software-development/how-repetitive-tasks-impact-your-business",{"title":510,"path":511,"stem":512},"Becoming a Vue.js Dev: Do Paid Trials Work?","/blog/software-development/how-to-become-a-vue-js-developer-and-whether-paid-trials-in-it-work-out","blog/software-development/how-to-become-a-vue-js-developer-and-whether-paid-trials-in-it-work-out",{"title":514,"path":515,"stem":516},"How to Build an MVP in 6 Steps","/blog/software-development/how-to-build-a-minimum-viable-product-mvp-in-6-steps","blog/software-development/how-to-build-a-minimum-viable-product-mvp-in-6-steps",{"title":518,"path":519,"stem":520},"How to conduct workshops for creative industry?","/blog/software-development/how-to-conduct-workshops-for-creative-industry","blog/software-development/how-to-conduct-workshops-for-creative-industry",{"title":522,"path":523,"stem":524},"How to easily create form in Angular","/blog/software-development/how-to-easily-create-form-in-angular","blog/software-development/how-to-easily-create-form-in-angular",{"title":526,"path":527,"stem":528},"How to export orders in Saleor.io to XLSX file","/blog/software-development/how-to-export-orders-in-saleor-io-to-xlsx-file","blog/software-development/how-to-export-orders-in-saleor-io-to-xlsx-file",{"title":530,"path":531,"stem":532},"Handling High Loads on E-Commerce Platforms","/blog/software-development/how-to-handle-high-loads-on-e-commerce-platform-with-ease","blog/software-development/how-to-handle-high-loads-on-e-commerce-platform-with-ease",{"title":534,"path":535,"stem":536},"How to launch Saleor.io shop instance within 40h","/blog/software-development/how-to-launch-saleor-io-shop-instance-within-40h","blog/software-development/how-to-launch-saleor-io-shop-instance-within-40h",{"title":538,"path":539,"stem":540},"First Steps to Build a Business Relationship","/blog/software-development/how-to-make-the-first-step-to-establish-a-business-relationship","blog/software-development/how-to-make-the-first-step-to-establish-a-business-relationship",{"title":542,"path":543,"stem":544},"Multi-Tenant Apps with Django and Saleor.io","/blog/software-development/how-to-manage-tenants-in-the-multitenant-app-based-on-django-tenants-and-saleor-io-platform","blog/software-development/how-to-manage-tenants-in-the-multitenant-app-based-on-django-tenants-and-saleor-io-platform",{"title":546,"path":547,"stem":548},"Notion Backup Tool Built in 3 Days with Python","/blog/software-development/how-we-built-a-notion-backup-tool-in-3-days-with-pythonvue-and-why","blog/software-development/how-we-built-a-notion-backup-tool-in-3-days-with-pythonvue-and-why",{"title":550,"path":551,"stem":552},"Important new features in Python 3.8","/blog/software-development/important-new-features-in-python-3-8","blog/software-development/important-new-features-in-python-3-8",{"title":554,"path":555,"stem":556},"Installing Proxmox on dedicated server from OVH","/blog/software-development/installing-proxmox-on-dedicated-server-from-ovh","blog/software-development/installing-proxmox-on-dedicated-server-from-ovh",{"title":558,"path":559,"stem":560},"Integrating SignNow E-Signatures into Your Django Application","/blog/software-development/integrating-signnow-e-signatures-into-your-django-application","blog/software-development/integrating-signnow-e-signatures-into-your-django-application",{"title":562,"path":563,"stem":564},"Tempus Metronome and GetSongBPM API","/blog/software-development/integrating-tempus-metronome-with-the-getsongbpm-api-what-bpm-really-means-and-how-to-use-it","blog/software-development/integrating-tempus-metronome-with-the-getsongbpm-api-what-bpm-really-means-and-how-to-use-it",{"title":566,"path":567,"stem":568},"Introducing MusicTech Poland","/blog/software-development/introducing-musictech-poland","blog/software-development/introducing-musictech-poland",{"title":570,"path":571,"stem":572},"Vue.js as a Frontend for Saleor.io","/blog/software-development/is-it-possible-to-use-vue-js-as-a-frontend-for-saleor-io-platform","blog/software-development/is-it-possible-to-use-vue-js-as-a-frontend-for-saleor-io-platform",{"title":574,"path":575,"stem":576},"Is your business ready for the cashless era?","/blog/software-development/is-your-business-ready-for-the-cashless-era","blog/software-development/is-your-business-ready-for-the-cashless-era",{"title":578,"path":579,"stem":580},"Is your face ready to buy?","/blog/software-development/is-your-face-ready-to-buy","blog/software-development/is-your-face-ready-to-buy",{"title":582,"path":583,"stem":584},"JS Frameworks: Trends and Opportunities","/blog/software-development/javascript-trending-frameworks-and-market-opportunities","blog/software-development/javascript-trending-frameworks-and-market-opportunities",{"title":586,"path":587,"stem":588},"Kanban Board: Boost Your Team Productivity","/blog/software-development/kanban-board-methodology-hack-your-companys-productivity","blog/software-development/kanban-board-methodology-hack-your-companys-productivity",{"title":590,"path":591,"stem":592},"Verified Human Cert MCP Server: Prove Your Music Is Human-Made, Right from the Terminal","/blog/software-development/mcp-verified-human-cert-open-source","blog/software-development/mcp-verified-human-cert-open-source",{"title":594,"path":595,"stem":596},"Migrating from TravisCI to Github Actions","/blog/software-development/migrating-from-travisci-to-github-actions","blog/software-development/migrating-from-travisci-to-github-actions",{"title":598,"path":599,"stem":600},"MusicTech Lab: Top Software Developer by Clutch","/blog/software-development/musictechlab-is-recognized-as-a-top-custom-software-developer-by-clutch","blog/software-development/musictechlab-is-recognized-as-a-top-custom-software-developer-by-clutch",{"title":602,"path":603,"stem":604},"MusicTech Lab x Verified Human: Building a Trust Layer for Human-Made Music","/blog/software-development/musictechlab_blog_verified_human_partnership","blog/software-development/musictechlab_blog_verified_human_partnership",{"title":606,"path":607,"stem":608},"MusicXML: Standard for Music Notation","/blog/software-development/musicxml-standard-for-music-notation-and-education","blog/software-development/musicxml-standard-for-music-notation-and-education",{"title":610,"path":611,"stem":612},"Only a few books but dozens of ideas","/blog/software-development/only-a-few-books-but-dozens-of-ideas","blog/software-development/only-a-few-books-but-dozens-of-ideas",{"title":614,"path":615,"stem":616},"Overdue Invoices and Issue Tracker Integration","/blog/software-development/overdue-invoices-integration-with-the-issue-tracking-system","blog/software-development/overdue-invoices-integration-with-the-issue-tracking-system",{"title":618,"path":619,"stem":620},"Performing SAML SSO using JWT in Django","/blog/software-development/performing-saml-sso-using-jwt-in-django","blog/software-development/performing-saml-sso-using-jwt-in-django",{"title":622,"path":623,"stem":624},"Progressive Web Apps for Mobile Development","/blog/software-development/progressive-web-apps-a-new-way-of-creating-mobile-application","blog/software-development/progressive-web-apps-a-new-way-of-creating-mobile-application",{"title":626,"path":627,"stem":628},"Recruitment System: Gmail, Jira, and CRM","/blog/software-development/recruitment-system-integrating-gmail-bravely-jira-slack-and-copper-crm","blog/software-development/recruitment-system-integrating-gmail-bravely-jira-slack-and-copper-crm",{"title":630,"path":631,"stem":632},"Scratch Me: Chrome Extension for Leads","/blog/software-development/scratch-me-a-simple-chrome-extension-which-will-increase-your-productivity","blog/software-development/scratch-me-a-simple-chrome-extension-which-will-increase-your-productivity",{"title":634,"path":635,"stem":636},"Scratch Me – integration with the Copper CRM","/blog/software-development/scratch-me-integration-with-the-copper-crm","blog/software-development/scratch-me-integration-with-the-copper-crm",{"title":638,"path":639,"stem":640},"SignNow MCP Server: E-Signatures Straight from Claude Code","/blog/software-development/signnow-mcp-server-e-signatures-from-claude-code","blog/software-development/signnow-mcp-server-e-signatures-from-claude-code",{"title":642,"path":643,"stem":644},"Music Industry Tech Openings (March 2024 Update)","/blog/software-development/technical-job-opportunities-in-the-music-industry","blog/software-development/technical-job-opportunities-in-the-music-industry",{"title":646,"path":647,"stem":648},"Thanks app – a Management 3.0 solution","/blog/software-development/thanks-app-a-management-3-0-solution","blog/software-development/thanks-app-a-management-3-0-solution",{"title":650,"path":651,"stem":652},"Colonial Pipeline Case: 7 Security Reminders","/blog/software-development/the-case-of-colonial-pipeline-and-7-security-reminders","blog/software-development/the-case-of-colonial-pipeline-and-7-security-reminders",{"title":654,"path":655,"stem":656},"The Evolution and Future of E-commerce Platforms","/blog/software-development/the-evolution-and-future-of-e-commerce-platforms","blog/software-development/the-evolution-and-future-of-e-commerce-platforms",{"title":658,"path":659,"stem":660},"The Gender Gap in the Tech Industry","/blog/software-development/the-gender-gap-in-the-tech-industry","blog/software-development/the-gender-gap-in-the-tech-industry",{"title":662,"path":663,"stem":664},"First Attempt to Implement 4DX at Bravelab.io","/blog/software-development/the-very-first-attempt-to-implement-4dx-in-bravelab-io","blog/software-development/the-very-first-attempt-to-implement-4dx-in-bravelab-io",{"title":666,"path":667,"stem":668},"The WTF Scale: IT Project Complexity","/blog/software-development/the-wtf-programming-scale-measuring-it-project-complexity","blog/software-development/the-wtf-programming-scale-measuring-it-project-complexity",{"title":670,"path":671,"stem":672},"Top 10 articles through the eyes of our developers","/blog/software-development/top-10-articles-through-the-eyes-of-our-developers","blog/software-development/top-10-articles-through-the-eyes-of-our-developers",{"title":674,"path":675,"stem":676},"Top 6 apps made with Flutter","/blog/software-development/top-6-apps-made-with-flutter","blog/software-development/top-6-apps-made-with-flutter",{"title":678,"path":679,"stem":680},"Uber 101: How Uber Made It to the Top","/blog/software-development/uber-101-how-this-ride-sharing-behemoth-made-it-to-the-top","blog/software-development/uber-101-how-this-ride-sharing-behemoth-made-it-to-the-top",{"title":682,"path":683,"stem":684},"MusicTech Lab Partners with Music Glue","/blog/software-development/unifying-artists-and-audiences-exploring-music-glue","blog/software-development/unifying-artists-and-audiences-exploring-music-glue",{"title":686,"path":687,"stem":688},"Why AI Will Defeat Traditional HR","/blog/software-development/warning-why-artificial-intelligence-will-defeat-traditional-hr","blog/software-development/warning-why-artificial-intelligence-will-defeat-traditional-hr",{"title":690,"path":691,"stem":692},"What is a Discovery Document?","/blog/software-development/what-is-discovery-document","blog/software-development/what-is-discovery-document",{"title":694,"path":695,"stem":696},"What is Flutter, and Why is it Worth Considering?","/blog/software-development/what-is-flutter-and-why-is-it-worth-considering","blog/software-development/what-is-flutter-and-why-is-it-worth-considering",{"title":698,"path":699,"stem":700},"What is a Watermarked Song?","/blog/software-development/what-is-watermarked-song","blog/software-development/what-is-watermarked-song",{"title":702,"path":703,"stem":704},"Choosing a Frontend Framework for the Web","/blog/software-development/which-framework-should-you-choose-for-the-frontend-web-platform-development","blog/software-development/which-framework-should-you-choose-for-the-frontend-web-platform-development",{"title":706,"path":707,"stem":708},"Why DAWs Are the Wrong Tool for Starting a Song","/blog/software-development/why-daws-wrong-tool-for-starting-song","blog/software-development/why-daws-wrong-tool-for-starting-song",{"title":710,"path":711,"stem":712},"Why the Programming World Loves Python","/blog/software-development/why-the-programming-world-loves-python","blog/software-development/why-the-programming-world-loves-python",{"title":714,"path":715,"stem":716},"Why We Don't Build Chat From Scratch (And Neither Should You)","/blog/software-development/why-we-dont-build-chat-from-scratch","blog/software-development/why-we-dont-build-chat-from-scratch",{"title":718,"path":719,"stem":720},"Why we use Sanity.io","/blog/software-development/why-we-use-sanity-io","blog/software-development/why-we-use-sanity-io",{"title":722,"path":723,"stem":724,"children":725,"page":69},"Sportstech","/blog/sportstech","blog/sportstech",[726,730],{"title":727,"path":728,"stem":729},"BeatBuddy Replay: Video Analysis App Challenges","/blog/sportstech/beatbuddy-replay-video-analysis-app-for-swimmers-flutter","blog/sportstech/beatbuddy-replay-video-analysis-app-for-swimmers-flutter",{"title":731,"path":732,"stem":733},"How to Create a Watch Face App for Garmin Watch","/blog/sportstech/how-to-create-watch-face-app-for-garmin-watch","blog/sportstech/how-to-create-watch-face-app-for-garmin-watch",{"id":735,"title":326,"authors":736,"badge":742,"body":744,"category":1208,"client":1209,"date":1210,"description":1211,"extension":1212,"faq":1213,"featured":1223,"featuredOrder":1224,"hidden":69,"image":1225,"keyTakeaways":1227,"meta":1241,"navigation":1223,"path":327,"seo":1242,"status":1209,"stem":328,"tags":1245,"teaser":1209,"__hash__":1252},"posts/blog/software-development/1200-looms-how-async-video-became-our-development-superpower.md",[737],{"name":738,"to":739,"avatar":740},"Mariusz Smenżyk","https://www.linkedin.com/in/mariusz-smenzyk/",{"src":741},"/images/people/mariusz-smenzyk2.webp",{"label":5,"color":743},"#f59e0b",{"type":745,"value":746,"toc":1186},"minimark",[747,760,765,768,858,869,880,883,955,958,962,965,970,973,976,999,1002,1008,1012,1015,1018,1022,1025,1028,1032,1035,1038,1042,1045,1049,1052,1058,1064,1070,1076,1080,1083,1087,1090,1094,1097,1101,1104,1108,1111,1115,1126,1130,1137,1163,1166,1169],[748,749,750,751,755,756,759],"p",{},"I never planned to record over a thousand videos. In January 2021, I hit record on my first Loom — a quick demo for a client who couldn't make a call. Five years and ",[752,753,754],"strong",{},"1,212 videos"," later, it's become one of the most impactful habits I've built as a founder and developer. Over ",[752,757,758],{},"107 hours"," of recordings now document my demos, decisions, estimates, and code walkthroughs. Here's what I've learned.",[761,762,764],"h2",{"id":763},"the-numbers-tell-a-story","The Numbers Tell a Story",[748,766,767],{},"I didn't set out to build an async video habit. It happened organically — and the growth curve surprised even me:",[769,770,771,788],"table",{},[772,773,774],"thead",{},[775,776,777,781,785],"tr",{},[778,779,780],"th",{},"Year",[778,782,784],{"align":783},"right","Videos Recorded",[778,786,787],{"align":783},"Growth",[789,790,791,803,814,825,836,847],"tbody",{},[775,792,793,797,800],{},[794,795,796],"td",{},"2021",[794,798,799],{"align":783},"46",[794,801,802],{"align":783},"—",[775,804,805,808,811],{},[794,806,807],{},"2022",[794,809,810],{"align":783},"71",[794,812,813],{"align":783},"+54%",[775,815,816,819,822],{},[794,817,818],{},"2023",[794,820,821],{"align":783},"175",[794,823,824],{"align":783},"+146%",[775,826,827,830,833],{},[794,828,829],{},"2024",[794,831,832],{"align":783},"276",[794,834,835],{"align":783},"+58%",[775,837,838,841,844],{},[794,839,840],{},"2025",[794,842,843],{"align":783},"434",[794,845,846],{"align":783},"+57%",[775,848,849,852,855],{},[794,850,851],{},"2026",[794,853,854],{"align":783},"47 (Q1 so far)",[794,856,857],{"align":783},"on pace for 188+",[748,859,860,861,864,865,868],{},"What started as an occasional demo tool became a daily habit. My peak month — ",[752,862,863],{},"February 2025"," — saw 145 videos recorded. That's roughly ",[752,866,867],{},"7 Looms per working day",".",[748,870,871,872,875,876,879],{},"The average video is ",[752,873,874],{},"5 minutes and 30 seconds"," long — but the median is just ",[752,877,878],{},"1 minute 44 seconds",". That gap tells an important story: most of my Looms are quick, focused messages under 3 minutes. The longer client demos and sprint walkthroughs pull the average up. No meeting preamble, no \"can everyone hear me?\", no waiting for latecomers.",[748,881,882],{},"Here's the full distribution:",[769,884,885,898],{},[772,886,887],{},[775,888,889,892,895],{},[778,890,891],{},"Duration",[778,893,894],{"align":783},"Videos",[778,896,897],{"align":783},"Share",[789,899,900,911,922,933,944],{},[775,901,902,905,908],{},[794,903,904],{},"Under 1 min",[794,906,907],{"align":783},"433",[794,909,910],{"align":783},"36%",[775,912,913,916,919],{},[794,914,915],{},"1–3 min",[794,917,918],{"align":783},"326",[794,920,921],{"align":783},"27%",[775,923,924,927,930],{},[794,925,926],{},"3–7 min",[794,928,929],{"align":783},"221",[794,931,932],{"align":783},"18%",[775,934,935,938,941],{},[794,936,937],{},"7–10 min",[794,939,940],{"align":783},"51",[794,942,943],{"align":783},"4%",[775,945,946,949,952],{},[794,947,948],{},"Over 10 min",[794,950,951],{"align":783},"140",[794,953,954],{"align":783},"11%",[748,956,957],{},"Over a third of my recordings are under a minute — quick answers, visual pointers, \"here's what I mean\" moments. The majority (63%) are under 3 minutes. Only the deep demos and walkthroughs go longer.",[761,959,961],{"id":960},"what-i-actually-use-loom-for","What I Actually Use Loom For",[748,963,964],{},"Looking at my library, clear patterns emerge across five years of recordings:",[966,967,969],"h3",{"id":968},"client-demos-and-pocs-80-videos","Client Demos and PoCs (80+ videos)",[748,971,972],{},"This is where async video delivers the most impact for me. When I finish a sprint or build a proof of concept, I record a walkthrough instead of scheduling a demo call. The client watches it when they have time, pauses to take notes, and rewatches sections they want to discuss.",[748,974,975],{},"A few real examples from my account:",[977,978,979,987,993],"ul",{},[980,981,982,986],"li",{},[983,984,985],"em",{},"\"PoC SingBuddy\""," — walking a client through a new product concept before committing to a full sprint",[980,988,989,992],{},[983,990,991],{},"\"Ambistream | Final demo for Sprint 5\""," — end-of-sprint delivery showing dynamic video layers in action",[980,994,995,998],{},[983,996,997],{},"\"Amazon IVS Real-time Mobile Web Demo\""," — a technical PoC demonstrating live streaming capabilities for a music platform",[748,1000,1001],{},"The pattern is always the same: I open the app, walk through what I built, explain the decisions I made, and highlight what's next. Five minutes. Done.",[1003,1004,1005],"tip",{},[748,1006,1007],{},"Record your demo before the call, not instead of it. Send the video ahead so the live session focuses on questions, not presentation. This cuts meeting time by 50% or more.",[966,1009,1011],{"id":1010},"estimates-and-financial-walkthroughs-119-videos","Estimates and Financial Walkthroughs (119 videos)",[748,1013,1014],{},"This one surprised me when I looked at the data. I've recorded 119 videos walking clients through spreadsheets — project estimates, cost breakdowns, timeline projections.",[748,1016,1017],{},"Spreadsheets are notoriously hard to communicate over email. A 3-minute Loom where I point at cells, explain trade-offs, and walk through assumptions eliminates 90% of follow-up questions. The client can pause, rewind, and share the video with their team. It's far more effective than a PDF attachment with a two-line email.",[966,1019,1021],{"id":1020},"internal-tools-and-dashboard-updates-153-videos","Internal Tools and Dashboard Updates (153 videos)",[748,1023,1024],{},"My most recorded category — and the most underrated. Every internal tool I build, every dashboard update, every infrastructure change gets a quick Loom.",[748,1026,1027],{},"When a new team member joins MusicTech Lab and asks \"how does the deployment pipeline work?\" or \"how do I use the Ableton export tool?\", the answer is a 4-minute video, not a 30-minute onboarding session. These recordings aren't polished — they're raw, practical walkthroughs that serve as living documentation.",[966,1029,1031],{"id":1030},"code-and-design-reviews-70-videos","Code and Design Reviews (70 videos)",[748,1033,1034],{},"I started recording code walkthroughs when I realized my PR comments were getting too long. Instead of leaving 20 inline comments, I record a 5-minute Loom explaining the architecture decision, the trade-offs I considered, and what reviewers should watch for.",[748,1036,1037],{},"The same applies to design reviews. When I receive a Figma mockup, I record my feedback as a video — pointing at specific elements, suggesting alternatives, asking questions. It's more nuanced than written comments and much faster to produce.",[966,1039,1041],{"id":1040},"replacing-emails-24-videos","Replacing Emails (24 videos)",[748,1043,1044],{},"Some things are just faster to show than type. I've recorded 24 videos that directly replaced what would have been long email threads — quick screen recordings answering questions that would have taken 500 words to write but only 90 seconds to show.",[761,1046,1048],{"id":1047},"why-this-works-for-me-as-a-founder","Why This Works for Me as a Founder",[748,1050,1051],{},"Running MusicTech Lab means I'm constantly switching between roles — writing code, reviewing designs, talking to clients, planning sprints, handling finances. Async video fits into all of these contexts because it's fast to produce and respects other people's time.",[748,1053,1054,1057],{},[752,1055,1056],{},"Time zone independence."," Our clients span multiple time zones. A client in LA doesn't need to stay up for a demo with our team in Poland. They watch the Loom at 9 AM their time and leave comments. I respond the next morning. The work never stops, but nobody loses sleep.",[748,1059,1060,1063],{},[752,1061,1062],{},"Context preservation."," When I record my thought process, I create an artifact. Six months later, when someone asks \"why did we choose this architecture for the streaming module?\", the answer exists as a searchable video — not as a fading memory from a call nobody recorded.",[748,1065,1066,1069],{},[752,1067,1068],{},"Protecting deep work."," My most productive months — measured by commits and deployments — correlate with my highest Loom output. It sounds counterintuitive, but recording more videos means scheduling fewer meetings, which means more uninterrupted coding time.",[1071,1072,1073],"note",{},[748,1074,1075],{},"I'm not anti-meeting. Some discussions need real-time collaboration — brainstorming sessions, difficult conversations, creative workshops. But the vast majority of \"status updates\" and \"quick demos\" are better served by a recorded video that respects everyone's calendar.",[761,1077,1079],{"id":1078},"what-id-tell-you-if-youre-starting","What I'd Tell You If You're Starting",[748,1081,1082],{},"After five years and 1,200+ recordings, here's what I'd recommend:",[966,1084,1086],{"id":1085},"start-with-client-demos","Start with client demos",[748,1088,1089],{},"This is the highest-ROI use case. Record a 3-5 minute walkthrough of what you built, send it before the scheduled call. You'll immediately notice calls getting shorter and more productive. Clients love it — they can share the video with stakeholders who weren't on the original call.",[966,1091,1093],{"id":1092},"make-it-a-reflex-not-a-process","Make it a reflex, not a process",[748,1095,1096],{},"I never made a rule about when to record. I just started hitting record whenever I caught myself typing a long explanation. Over time, it became second nature. The growth from 46 to 434 videos per year was entirely organic.",[966,1098,1100],{"id":1099},"keep-it-under-2-minutes","Keep it under 2 minutes",[748,1102,1103],{},"My median is 1 minute 44 seconds. Over 60% of my recordings are under 3 minutes. If a Loom is getting longer than a few minutes, I split it. Short videos get watched; long videos get bookmarked and forgotten.",[966,1105,1107],{"id":1106},"dont-polish","Don't polish",[748,1109,1110],{},"The biggest barrier to async video is perfectionism. My Looms have typos on screen, \"umm\"s in the audio, and cursors that occasionally wander off. Nobody has ever complained. The content matters, not the production quality.",[966,1112,1114],{"id":1113},"build-a-searchable-archive","Build a searchable archive",[748,1116,1117,1118,1122,1123,868],{},"At 1,212 videos, finding a specific recording became a challenge. I recently built a custom tool (an MCP server using Claude Code) that connects to my Loom account and lets me search, analyze, and generate statistics from my entire video library. That's actually how I pulled the data for this article - every number here comes from querying my own recordings programmatically. We've built similar MCP integrations for other workflows too, like our ",[1119,1120,1121],"a",{"href":169},"Bandcamp revenue dashboard"," and ",[1119,1124,1125],{"href":639},"SignNow e-signatures",[761,1127,1129],{"id":1128},"the-compounding-effect","The Compounding Effect",[748,1131,1132,1133,1136],{},"The real value of async video isn't in any single recording. It's in the ",[752,1134,1135],{},"compounding archive"," you build over time. My 1,212 videos are now:",[977,1138,1139,1145,1151,1157],{},[980,1140,1141,1144],{},[752,1142,1143],{},"An onboarding library"," — new team members watch relevant Looms instead of attending knowledge-transfer sessions",[980,1146,1147,1150],{},[752,1148,1149],{},"A decision log"," — architecture choices, business decisions, and trade-offs captured with full context",[980,1152,1153,1156],{},[752,1154,1155],{},"A portfolio"," — demos and PoCs I can reference when scoping similar projects",[980,1158,1159,1162],{},[752,1160,1161],{},"A content mine"," — this very article was built by analyzing my Loom data and reflecting on patterns I wouldn't have noticed without it",[748,1164,1165],{},"Every Loom I record today is a small investment in future efficiency. After 107 hours of recordings and over a thousand videos, I can say with confidence: async video isn't a productivity hack. For a developer running a remote-first agency, it's infrastructure.",[1167,1168],"hr",{},[748,1170,1171],{},[983,1172,1173,1174,1180,1181,868],{},"I'm Mariusz, founder of ",[1119,1175,1179],{"href":1176,"rel":1177},"https://musictechlab.io",[1178],"nofollow","MusicTech Lab"," — a software development agency focused on the music industry. If you're curious about how we work or want to discuss a project, ",[1119,1182,1185],{"href":1183,"rel":1184},"https://musictechlab.io/contact",[1178],"let's talk",{"title":1187,"searchDepth":1188,"depth":1188,"links":1189},"",2,[1190,1191,1199,1200,1207],{"id":763,"depth":1188,"text":764},{"id":960,"depth":1188,"text":961,"children":1192},[1193,1195,1196,1197,1198],{"id":968,"depth":1194,"text":969},3,{"id":1010,"depth":1194,"text":1011},{"id":1020,"depth":1194,"text":1021},{"id":1030,"depth":1194,"text":1031},{"id":1040,"depth":1194,"text":1041},{"id":1047,"depth":1188,"text":1048},{"id":1078,"depth":1188,"text":1079,"children":1201},[1202,1203,1204,1205,1206],{"id":1085,"depth":1194,"text":1086},{"id":1092,"depth":1194,"text":1093},{"id":1099,"depth":1194,"text":1100},{"id":1106,"depth":1194,"text":1107},{"id":1113,"depth":1194,"text":1114},{"id":1128,"depth":1188,"text":1129},"software-development",null,"2026-03-06T00:00:00.000Z","I've recorded 1,212 Loom videos over 5 years. Here's how async video transformed the way I demo, communicate with clients, and document decisions as a founder and developer.","md",[1214,1217,1220],{"question":1215,"answer":1216},"How does async video improve software development?","Async video replaces synchronous meetings with recorded walkthroughs that stakeholders can watch on their own time. It reduces scheduling overhead, creates a searchable archive of decisions, and lets developers communicate complex ideas visually without interrupting their flow.",{"question":1218,"answer":1219},"What types of development tasks work best with Loom?","Client demos, PoC walkthroughs, estimate explanations, design reviews, code walkthroughs, and bug reports. Essentially anything where showing your screen adds context that text alone cannot convey.",{"question":1221,"answer":1222},"How long should a development Loom video be?","Based on data across 1,212 videos, the median length is just 1 minute 44 seconds — most recordings are quick, focused messages. Longer demos average around 5-7 minutes. The key is matching length to purpose: quick answers under 2 minutes, demos and walkthroughs under 7.",true,12,{"src":1226},"/images/blog/musictechlab_blog_1200-looms-how-async-video-became-our-development-superpower.webp",{"enabled":1223,"items":1228},[1229,1232,1235,1238],{"text":1230,"icon":1231},"1,212 Loom videos recorded over 5 years, totaling 107+ hours of async communication.","i-lucide-bar-chart-3",{"text":1233,"icon":1234},"Median video length is just 1 min 44 sec; 63% of recordings are under 3 minutes.","i-lucide-clock",{"text":1236,"icon":1237},"Sending demos before calls cuts live meeting time by 50% or more.","i-lucide-zap",{"text":1239,"icon":1240},"Peak usage hit 145 videos in one month, roughly 7 Looms per working day.","i-lucide-trending-up",{},{"title":1243,"description":1244},"1,200 Looms: Async Video in Software Development | MusicTech Lab","How I recorded 1,212 Loom videos in 5 years to replace meetings, demo features, and build async-first culture. Practical lessons from a dev agency founder.",[1246,1247,1248,1208,1249,1250,1251],"async-communication","loom","remote-work","client-demos","team-culture","productivity","FJ1GCyt83AqMTBOQZ_t_hLZyUMhy-U1jz1oiMCxjrto",[1254,1256],{"title":322,"path":323,"stem":324,"description":1255,"children":-1},"How to find skilled MVP developers for your startup, whether building an in-house team or hiring an outsourced development company.",{"title":330,"path":331,"stem":332,"description":1257,"children":-1},"The crucial element in successful outcomes is effective communication between the client and the vendor. See why",[1259,2328,2352,2665],{"id":1260,"title":410,"authors":1261,"badge":1264,"body":1267,"category":1208,"client":1209,"date":2281,"description":2282,"extension":1212,"faq":2283,"featured":69,"featuredOrder":1209,"hidden":69,"image":2299,"keyTakeaways":2301,"meta":2315,"navigation":1223,"path":411,"seo":2316,"status":1209,"stem":412,"tags":2319,"teaser":1209,"__hash__":2327,"score":1188},"posts/blog/software-development/c2pa-in-ableton-max-for-live.md",[1262],{"name":738,"to":739,"avatar":1263},{"src":741},{"label":1265,"color":1266},"Open Source","#7c3aed",{"type":745,"value":1268,"toc":2268},[1269,1276,1287,1291,1294,1302,1305,1312,1319,1323,1326,1337,1341,1542,1545,1590,1594,1703,1710,1714,1717,1761,1767,1771,1774,2043,2054,2058,2068,2075,2079,2082,2177,2185,2189,2198,2201,2236,2240,2248,2250,2254,2257,2264],[748,1270,1271,1272,1275],{},"In May 2026 we shipped ",[1119,1273,1274],{"href":125},"a Claude MCP for reading C2PA manifests in music files",". This post is the follow-up: the same reader, now inside Ableton Live as an open-source Max for Live device.",[748,1277,1278,1279,1282,1283,1286],{},"This is the fourth article in our ",[1119,1280,1281],{"href":475},"Max for Live series",". It builds directly on the ",[1119,1284,1285],{"href":423},"M4L → FastAPI pattern"," we wrote about in January 2026, with one change: the API runs on your laptop, not in the cloud.",[761,1288,1290],{"id":1289},"the-problem","The problem",[748,1292,1293],{},"Google Lyria signs every MP3 it generates with a C2PA manifest. The manifest records who made the file, what model produced it, whether it is AI-generated, what watermarks were applied (Lyria adds SynthID), and who signed the claim. The data is there. Producers cannot see it.",[748,1295,1296,1297,1301],{},"You drop a Lyria stem onto an audio track. Ableton shows you the waveform. It does not show you that the file is AI-generated, who signed it, or what the manifest says about the source. To find out, you have to leave the DAW, run ",[1298,1299,1300],"code",{},"c2patool"," on the file, and read raw JSON.",[748,1303,1304],{},"Andrew Melchior — Massive Attack's CTO, advising the UK DCMS on AI and the Copyright Act — framed the bigger gap in a reply on LinkedIn to our MCP announcement:",[1071,1306,1307],{},[748,1308,1309],{},[752,1310,1311],{},"C2PA now tells you a machine generated this track. It doesn't tell you whose work trained the machine.",[748,1313,1314,1315,1318],{},"Training-corpus provenance is the hard problem. This article is about the easier half — making the ",[983,1316,1317],{},"output"," manifest visible at the point a producer is actually working.",[761,1320,1322],{"id":1321},"the-fix","The fix",[748,1324,1325],{},"A Max for Live device. Click a clip → see the manifest summary. That is the whole product.",[748,1327,1328,1329,1332,1333,1336],{},"Under the hood, the device borrows a pattern we already shipped: a Max for Live ",[1298,1330,1331],{},"js"," object reads the Live Object Model, then routes the work to a Node for Max HTTP client. We wrote about ",[1119,1334,1335],{"href":423},"this exact shape in January 2026",". The only change here is where the HTTP server lives.",[761,1338,1340],{"id":1339},"architecture-in-one-diagram","Architecture in one diagram",[1342,1343,1347],"pre",{"className":1344,"code":1345,"language":1346,"meta":1187,"style":1187},"language-mermaid shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","flowchart TB\n    subgraph Ableton[\"Ableton Live\"]\n        device[\"MTL_C2PA_Ableton_PoC.amxd\"]\n        livepi[\"LiveAPI observer\u003Cbr/>(detail_clip)\"]\n        js[\"c2pa_reader.js\"]\n        node[\"c2pa_node.js\u003Cbr/>(Node for Max)\"]\n        ui[\"UI textedit\u003Cbr/>summary display\"]\n        device --> livepi --> js --> node --> ui\n    end\n\n    subgraph LocalServer[\"mtl-c2pa-http (127.0.0.1:8765)\"]\n        fastapi[\"FastAPI app\"]\n        summary[\"/summary\"]\n        verify[\"/verify\"]\n        scan[\"/scan\"]\n        info[\"/info\"]\n        fastapi --> summary\n        fastapi --> verify\n        fastapi --> scan\n        fastapi --> info\n    end\n\n    subgraph PythonPkg[\"mtl_c2pa_server (in this repo)\"]\n        c2pamod[\"c2pa.py (parser)\"]\n        reader[\"c2pa-python Reader\u003Cbr/>(Rust binding)\"]\n        c2pamod --> reader\n    end\n\n    node -->|POST /summary| fastapi\n    fastapi -->|import| c2pamod\n\n    launchd[\"launchd plist\u003Cbr/>auto-start on login\"]\n    launchd -.->|spawn| fastapi\n","mermaid",[1298,1348,1349,1358,1363,1368,1374,1380,1386,1392,1398,1404,1410,1416,1421,1427,1433,1439,1445,1451,1457,1463,1469,1474,1479,1485,1491,1497,1503,1508,1513,1519,1525,1530,1536],{"__ignoreMap":1187},[1350,1351,1354],"span",{"class":1352,"line":1353},"line",1,[1350,1355,1357],{"class":1356},"sTEyZ","flowchart TB\n",[1350,1359,1360],{"class":1352,"line":1188},[1350,1361,1362],{"class":1356},"    subgraph Ableton[\"Ableton Live\"]\n",[1350,1364,1365],{"class":1352,"line":1194},[1350,1366,1367],{"class":1356},"        device[\"MTL_C2PA_Ableton_PoC.amxd\"]\n",[1350,1369,1371],{"class":1352,"line":1370},4,[1350,1372,1373],{"class":1356},"        livepi[\"LiveAPI observer\u003Cbr/>(detail_clip)\"]\n",[1350,1375,1377],{"class":1352,"line":1376},5,[1350,1378,1379],{"class":1356},"        js[\"c2pa_reader.js\"]\n",[1350,1381,1383],{"class":1352,"line":1382},6,[1350,1384,1385],{"class":1356},"        node[\"c2pa_node.js\u003Cbr/>(Node for Max)\"]\n",[1350,1387,1389],{"class":1352,"line":1388},7,[1350,1390,1391],{"class":1356},"        ui[\"UI textedit\u003Cbr/>summary display\"]\n",[1350,1393,1395],{"class":1352,"line":1394},8,[1350,1396,1397],{"class":1356},"        device --> livepi --> js --> node --> ui\n",[1350,1399,1401],{"class":1352,"line":1400},9,[1350,1402,1403],{"class":1356},"    end\n",[1350,1405,1407],{"class":1352,"line":1406},10,[1350,1408,1409],{"emptyLinePlaceholder":1223},"\n",[1350,1411,1413],{"class":1352,"line":1412},11,[1350,1414,1415],{"class":1356},"    subgraph LocalServer[\"mtl-c2pa-http (127.0.0.1:8765)\"]\n",[1350,1417,1418],{"class":1352,"line":1224},[1350,1419,1420],{"class":1356},"        fastapi[\"FastAPI app\"]\n",[1350,1422,1424],{"class":1352,"line":1423},13,[1350,1425,1426],{"class":1356},"        summary[\"/summary\"]\n",[1350,1428,1430],{"class":1352,"line":1429},14,[1350,1431,1432],{"class":1356},"        verify[\"/verify\"]\n",[1350,1434,1436],{"class":1352,"line":1435},15,[1350,1437,1438],{"class":1356},"        scan[\"/scan\"]\n",[1350,1440,1442],{"class":1352,"line":1441},16,[1350,1443,1444],{"class":1356},"        info[\"/info\"]\n",[1350,1446,1448],{"class":1352,"line":1447},17,[1350,1449,1450],{"class":1356},"        fastapi --> summary\n",[1350,1452,1454],{"class":1352,"line":1453},18,[1350,1455,1456],{"class":1356},"        fastapi --> verify\n",[1350,1458,1460],{"class":1352,"line":1459},19,[1350,1461,1462],{"class":1356},"        fastapi --> scan\n",[1350,1464,1466],{"class":1352,"line":1465},20,[1350,1467,1468],{"class":1356},"        fastapi --> info\n",[1350,1470,1472],{"class":1352,"line":1471},21,[1350,1473,1403],{"class":1356},[1350,1475,1477],{"class":1352,"line":1476},22,[1350,1478,1409],{"emptyLinePlaceholder":1223},[1350,1480,1482],{"class":1352,"line":1481},23,[1350,1483,1484],{"class":1356},"    subgraph PythonPkg[\"mtl_c2pa_server (in this repo)\"]\n",[1350,1486,1488],{"class":1352,"line":1487},24,[1350,1489,1490],{"class":1356},"        c2pamod[\"c2pa.py (parser)\"]\n",[1350,1492,1494],{"class":1352,"line":1493},25,[1350,1495,1496],{"class":1356},"        reader[\"c2pa-python Reader\u003Cbr/>(Rust binding)\"]\n",[1350,1498,1500],{"class":1352,"line":1499},26,[1350,1501,1502],{"class":1356},"        c2pamod --> reader\n",[1350,1504,1506],{"class":1352,"line":1505},27,[1350,1507,1403],{"class":1356},[1350,1509,1511],{"class":1352,"line":1510},28,[1350,1512,1409],{"emptyLinePlaceholder":1223},[1350,1514,1516],{"class":1352,"line":1515},29,[1350,1517,1518],{"class":1356},"    node -->|POST /summary| fastapi\n",[1350,1520,1522],{"class":1352,"line":1521},30,[1350,1523,1524],{"class":1356},"    fastapi -->|import| c2pamod\n",[1350,1526,1528],{"class":1352,"line":1527},31,[1350,1529,1409],{"emptyLinePlaceholder":1223},[1350,1531,1533],{"class":1352,"line":1532},32,[1350,1534,1535],{"class":1356},"    launchd[\"launchd plist\u003Cbr/>auto-start on login\"]\n",[1350,1537,1539],{"class":1352,"line":1538},33,[1350,1540,1541],{"class":1356},"    launchd -.->|spawn| fastapi\n",[748,1543,1544],{},"Three sentences:",[1546,1547,1548,1561,1571],"ol",{},[980,1549,1550,1551,1553,1554,1557,1558,868],{},"A LiveAPI observer in the ",[1298,1552,1331],{}," object watches ",[1298,1555,1556],{},"live_set view detail_clip",". When the selection changes, it pulls the clip's ",[1298,1559,1560],{},"file_path",[980,1562,1563,1564,1567,1568,868],{},"The path flows into a Node for Max script, which ",[1298,1565,1566],{},"POST","s it to ",[1298,1569,1570],{},"http://127.0.0.1:8765/summary",[980,1572,1573,1574,1577,1578,1586,1587,868],{},"The local FastAPI server is shipped in this same repo as the device — a small Python package (",[1298,1575,1576],{},"mtl_c2pa_server",") that wraps the ",[1119,1579,1582,1583],{"href":1580,"rel":1581},"https://github.com/contentauth/c2pa-python",[1178],"official ",[1298,1584,1585],{},"c2pa-python"," Rust binding. One clone, one ",[1298,1588,1589],{},"poetry install",[761,1591,1593],{"id":1592},"selection-to-display-end-to-end","Selection-to-display, end to end",[1342,1595,1597],{"className":1344,"code":1596,"language":1346,"meta":1187,"style":1187},"sequenceDiagram\n    actor User\n    participant Live as Ableton Live\n    participant Device as M4L Device\n    participant Reader as c2pa_reader.js\n    participant Node as c2pa_node.js\n    participant HTTP as mtl-c2pa-http :8765\n    participant Lib as c2pa-python\n\n    User->>Live: click audio clip\n    Live->>Device: detail_clip changed\n    Device->>Reader: observer fires\n    Reader->>Live: get detail_clip.file_path\n    Live-->>Reader: /path/to/lyria.mp3\n    Reader->>Node: outlet \"fetch\" path\n    Node->>HTTP: POST /summary {path}\n    HTTP->>Lib: Reader(mime, stream).json()\n    Lib-->>HTTP: manifest store\n    HTTP-->>Node: summary JSON\n    Node->>Device: outlet \"result\" json\n    Device-->>User: display summary\n",[1298,1598,1599,1604,1609,1614,1619,1624,1629,1634,1639,1643,1648,1653,1658,1663,1668,1673,1678,1683,1688,1693,1698],{"__ignoreMap":1187},[1350,1600,1601],{"class":1352,"line":1353},[1350,1602,1603],{"class":1356},"sequenceDiagram\n",[1350,1605,1606],{"class":1352,"line":1188},[1350,1607,1608],{"class":1356},"    actor User\n",[1350,1610,1611],{"class":1352,"line":1194},[1350,1612,1613],{"class":1356},"    participant Live as Ableton Live\n",[1350,1615,1616],{"class":1352,"line":1370},[1350,1617,1618],{"class":1356},"    participant Device as M4L Device\n",[1350,1620,1621],{"class":1352,"line":1376},[1350,1622,1623],{"class":1356},"    participant Reader as c2pa_reader.js\n",[1350,1625,1626],{"class":1352,"line":1382},[1350,1627,1628],{"class":1356},"    participant Node as c2pa_node.js\n",[1350,1630,1631],{"class":1352,"line":1388},[1350,1632,1633],{"class":1356},"    participant HTTP as mtl-c2pa-http :8765\n",[1350,1635,1636],{"class":1352,"line":1394},[1350,1637,1638],{"class":1356},"    participant Lib as c2pa-python\n",[1350,1640,1641],{"class":1352,"line":1400},[1350,1642,1409],{"emptyLinePlaceholder":1223},[1350,1644,1645],{"class":1352,"line":1406},[1350,1646,1647],{"class":1356},"    User->>Live: click audio clip\n",[1350,1649,1650],{"class":1352,"line":1412},[1350,1651,1652],{"class":1356},"    Live->>Device: detail_clip changed\n",[1350,1654,1655],{"class":1352,"line":1224},[1350,1656,1657],{"class":1356},"    Device->>Reader: observer fires\n",[1350,1659,1660],{"class":1352,"line":1423},[1350,1661,1662],{"class":1356},"    Reader->>Live: get detail_clip.file_path\n",[1350,1664,1665],{"class":1352,"line":1429},[1350,1666,1667],{"class":1356},"    Live-->>Reader: /path/to/lyria.mp3\n",[1350,1669,1670],{"class":1352,"line":1435},[1350,1671,1672],{"class":1356},"    Reader->>Node: outlet \"fetch\" path\n",[1350,1674,1675],{"class":1352,"line":1441},[1350,1676,1677],{"class":1356},"    Node->>HTTP: POST /summary {path}\n",[1350,1679,1680],{"class":1352,"line":1447},[1350,1681,1682],{"class":1356},"    HTTP->>Lib: Reader(mime, stream).json()\n",[1350,1684,1685],{"class":1352,"line":1453},[1350,1686,1687],{"class":1356},"    Lib-->>HTTP: manifest store\n",[1350,1689,1690],{"class":1352,"line":1459},[1350,1691,1692],{"class":1356},"    HTTP-->>Node: summary JSON\n",[1350,1694,1695],{"class":1352,"line":1465},[1350,1696,1697],{"class":1356},"    Node->>Device: outlet \"result\" json\n",[1350,1699,1700],{"class":1352,"line":1471},[1350,1701,1702],{"class":1356},"    Device-->>User: display summary\n",[748,1704,1705,1706,1709],{},"The manual \"Refresh\" button short-circuits the observer and triggers the same ",[1298,1707,1708],{},"POST /summary"," call. Same pipeline, different trigger source.",[761,1711,1713],{"id":1712},"why-local-not-cloud-not-cli","Why local, not cloud, not CLI",[748,1715,1716],{},"We considered three options. Local won.",[1718,1719,1726,1738,1750],"div",{"className":1720},[1721,1722,1723,1724,1725],"grid","grid-cols-1","md:grid-cols-3","gap-4","my-8",[1727,1728,1731],"spotlight-card",{"description":1729,"icon":1237,"title":1730},"Simplest, but Python startup costs ~300 ms. On every clip selection. You feel it.","A CLI shell-out per click",[748,1732,1733,1734,1737],{},"We use ",[1119,1735,1585],{"href":1580,"rel":1736},[1178],", which wraps the Rust binding. The Python interpreter cold-start is the bottleneck, not the C2PA read itself.",[1727,1739,1743],{"description":1740,"icon":1741,"title":1742},"Right for generation, wrong for reading. You'd upload audio just to inspect a local file.","i-lucide-cloud","Cloud Run",[748,1744,1745,1746,1749],{},"Cloud is what our ",[1119,1747,1748],{"href":423},"reference M4L → API article"," uses — and for storing generation events with an audit log, it is the right answer. For reading a manifest already in your file system, it isn't.",[1727,1751,1755],{"description":1752,"icon":1753,"title":1754},"Keeps c2pa-python warm. Loopback only. Reuses the MCP parser without changes.","i-lucide-server","Local FastAPI server",[748,1756,1757,1758,1760],{},"The HTTP layer is ~80 lines wrapping ",[1298,1759,1585],{}," directly. Self-contained in this repo — one clone, one install, no separate dependency on the sibling MCP server.",[748,1762,1763,1764,1766],{},"A persistent local FastAPI server keeps ",[1298,1765,1585],{}," warm in memory, runs on loopback only (no external attack surface), and reuses the existing MCP parser without changes.",[761,1768,1770],{"id":1769},"what-you-see","What you see",[748,1772,1773],{},"For a Lyria-signed MP3, the device shows the same shape the MCP produces:",[1342,1775,1780],{"className":1776,"code":1777,"filename":1778,"language":1779,"meta":1187,"style":1187},"language-json shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","{\n  \"file\": \"/Users/you/Music/Sovereign_Ascent.mp3\",\n  \"generator\": {\"name\": \"Google C2PA Core Generator Library\"},\n  \"is_ai_generated\": true,\n  \"actions\": [\n    {\"action\": \"c2pa.created\", \"description\": \"Created by Google Generative AI.\"},\n    {\"action\": \"c2pa.edited\", \"description\": \"Applied imperceptible SynthID watermark.\"}\n  ],\n  \"watermarks\": [\n    {\"description\": \"Applied imperceptible SynthID watermark.\"}\n  ],\n  \"signature_issuer\": \"Google LLC\",\n  \"validation\": \"valid\"\n}\n","c2pa_summary output in Ableton","json",[1298,1781,1782,1788,1815,1849,1863,1877,1919,1958,1963,1976,1996,2000,2020,2039],{"__ignoreMap":1187},[1350,1783,1784],{"class":1352,"line":1353},[1350,1785,1787],{"class":1786},"sMK4o","{\n",[1350,1789,1790,1793,1797,1800,1803,1806,1810,1812],{"class":1352,"line":1188},[1350,1791,1792],{"class":1786},"  \"",[1350,1794,1796],{"class":1795},"spNyl","file",[1350,1798,1799],{"class":1786},"\"",[1350,1801,1802],{"class":1786},":",[1350,1804,1805],{"class":1786}," \"",[1350,1807,1809],{"class":1808},"sfazB","/Users/you/Music/Sovereign_Ascent.mp3",[1350,1811,1799],{"class":1786},[1350,1813,1814],{"class":1786},",\n",[1350,1816,1817,1819,1822,1824,1826,1829,1831,1835,1837,1839,1841,1844,1846],{"class":1352,"line":1194},[1350,1818,1792],{"class":1786},[1350,1820,1821],{"class":1795},"generator",[1350,1823,1799],{"class":1786},[1350,1825,1802],{"class":1786},[1350,1827,1828],{"class":1786}," {",[1350,1830,1799],{"class":1786},[1350,1832,1834],{"class":1833},"sBMFI","name",[1350,1836,1799],{"class":1786},[1350,1838,1802],{"class":1786},[1350,1840,1805],{"class":1786},[1350,1842,1843],{"class":1808},"Google C2PA Core Generator Library",[1350,1845,1799],{"class":1786},[1350,1847,1848],{"class":1786},"},\n",[1350,1850,1851,1853,1856,1858,1860],{"class":1352,"line":1370},[1350,1852,1792],{"class":1786},[1350,1854,1855],{"class":1795},"is_ai_generated",[1350,1857,1799],{"class":1786},[1350,1859,1802],{"class":1786},[1350,1861,1862],{"class":1786}," true,\n",[1350,1864,1865,1867,1870,1872,1874],{"class":1352,"line":1376},[1350,1866,1792],{"class":1786},[1350,1868,1869],{"class":1795},"actions",[1350,1871,1799],{"class":1786},[1350,1873,1802],{"class":1786},[1350,1875,1876],{"class":1786}," [\n",[1350,1878,1879,1882,1884,1887,1889,1891,1893,1896,1898,1901,1903,1906,1908,1910,1912,1915,1917],{"class":1352,"line":1382},[1350,1880,1881],{"class":1786},"    {",[1350,1883,1799],{"class":1786},[1350,1885,1886],{"class":1833},"action",[1350,1888,1799],{"class":1786},[1350,1890,1802],{"class":1786},[1350,1892,1805],{"class":1786},[1350,1894,1895],{"class":1808},"c2pa.created",[1350,1897,1799],{"class":1786},[1350,1899,1900],{"class":1786},",",[1350,1902,1805],{"class":1786},[1350,1904,1905],{"class":1833},"description",[1350,1907,1799],{"class":1786},[1350,1909,1802],{"class":1786},[1350,1911,1805],{"class":1786},[1350,1913,1914],{"class":1808},"Created by Google Generative AI.",[1350,1916,1799],{"class":1786},[1350,1918,1848],{"class":1786},[1350,1920,1921,1923,1925,1927,1929,1931,1933,1936,1938,1940,1942,1944,1946,1948,1950,1953,1955],{"class":1352,"line":1388},[1350,1922,1881],{"class":1786},[1350,1924,1799],{"class":1786},[1350,1926,1886],{"class":1833},[1350,1928,1799],{"class":1786},[1350,1930,1802],{"class":1786},[1350,1932,1805],{"class":1786},[1350,1934,1935],{"class":1808},"c2pa.edited",[1350,1937,1799],{"class":1786},[1350,1939,1900],{"class":1786},[1350,1941,1805],{"class":1786},[1350,1943,1905],{"class":1833},[1350,1945,1799],{"class":1786},[1350,1947,1802],{"class":1786},[1350,1949,1805],{"class":1786},[1350,1951,1952],{"class":1808},"Applied imperceptible SynthID watermark.",[1350,1954,1799],{"class":1786},[1350,1956,1957],{"class":1786},"}\n",[1350,1959,1960],{"class":1352,"line":1394},[1350,1961,1962],{"class":1786},"  ],\n",[1350,1964,1965,1967,1970,1972,1974],{"class":1352,"line":1400},[1350,1966,1792],{"class":1786},[1350,1968,1969],{"class":1795},"watermarks",[1350,1971,1799],{"class":1786},[1350,1973,1802],{"class":1786},[1350,1975,1876],{"class":1786},[1350,1977,1978,1980,1982,1984,1986,1988,1990,1992,1994],{"class":1352,"line":1406},[1350,1979,1881],{"class":1786},[1350,1981,1799],{"class":1786},[1350,1983,1905],{"class":1833},[1350,1985,1799],{"class":1786},[1350,1987,1802],{"class":1786},[1350,1989,1805],{"class":1786},[1350,1991,1952],{"class":1808},[1350,1993,1799],{"class":1786},[1350,1995,1957],{"class":1786},[1350,1997,1998],{"class":1352,"line":1412},[1350,1999,1962],{"class":1786},[1350,2001,2002,2004,2007,2009,2011,2013,2016,2018],{"class":1352,"line":1224},[1350,2003,1792],{"class":1786},[1350,2005,2006],{"class":1795},"signature_issuer",[1350,2008,1799],{"class":1786},[1350,2010,1802],{"class":1786},[1350,2012,1805],{"class":1786},[1350,2014,2015],{"class":1808},"Google LLC",[1350,2017,1799],{"class":1786},[1350,2019,1814],{"class":1786},[1350,2021,2022,2024,2027,2029,2031,2033,2036],{"class":1352,"line":1423},[1350,2023,1792],{"class":1786},[1350,2025,2026],{"class":1795},"validation",[1350,2028,1799],{"class":1786},[1350,2030,1802],{"class":1786},[1350,2032,1805],{"class":1786},[1350,2034,2035],{"class":1808},"valid",[1350,2037,2038],{"class":1786},"\"\n",[1350,2040,2041],{"class":1352,"line":1429},[1350,2042,1957],{"class":1786},[748,2044,2045,2046,2049,2050,2053],{},"For an unsigned audio clip you get ",[1298,2047,2048],{},"{\"error\": \"No C2PA manifest found\"}",". For a MIDI clip, ",[1298,2051,2052],{},"{\"info\": \"MIDI clip — no C2PA manifest applicable\"}",". The Refresh button re-runs the lookup manually.",[761,2055,2057],{"id":2056},"what-this-doesnt-solve","What this doesn't solve",[2059,2060,2061],"warning",{},[748,2062,2063,2064,2067],{},"This is read-side only. The device tells you the C2PA truth that is ",[983,2065,2066],{},"already in the file",". It does not sign anything. It does not tell you what corpus trained the model. Andrew's point still stands.",[748,2069,2070,2071,2074],{},"The C2PA community is working on the harder problem. There is an active conversation in the C2PA group about capturing provenance ",[983,2072,2073],{},"during"," DAW work — signing the project at bounce time, attributing the samples and MIDI sources that went in. That is the generation side. We would like to help build it next.",[761,2076,2078],{"id":2077},"install-and-try-it","Install and try it",[748,2080,2081],{},"You need Ableton Live with Max for Live (Live Suite, or Standard plus the M4L add-on), and macOS for the auto-start script.",[1342,2083,2088],{"className":2084,"code":2085,"filename":2086,"language":2087,"meta":1187,"style":1187},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","# 1. Clone and install (one-time)\ngit clone https://github.com/musictechlab/mtl-c2pa-ableton.git\ncd mtl-c2pa-ableton && poetry install\n\n# 2. Auto-start on login (macOS)\nbash install/install.sh\n\n# 3. Verify\ncurl http://127.0.0.1:8765/health\n# {\"status\":\"ok\"}\n\n# 4. Drop the device on a track\n# Drag device/MTL_C2PA_Ableton_PoC.amxd onto any audio track in Live.\n","setup.sh","bash",[1298,2089,2090,2096,2107,2125,2129,2134,2141,2145,2150,2158,2163,2167,2172],{"__ignoreMap":1187},[1350,2091,2092],{"class":1352,"line":1353},[1350,2093,2095],{"class":2094},"sHwdD","# 1. Clone and install (one-time)\n",[1350,2097,2098,2101,2104],{"class":1352,"line":1188},[1350,2099,2100],{"class":1833},"git",[1350,2102,2103],{"class":1808}," clone",[1350,2105,2106],{"class":1808}," https://github.com/musictechlab/mtl-c2pa-ableton.git\n",[1350,2108,2109,2113,2116,2119,2122],{"class":1352,"line":1194},[1350,2110,2112],{"class":2111},"s2Zo4","cd",[1350,2114,2115],{"class":1808}," mtl-c2pa-ableton",[1350,2117,2118],{"class":1786}," &&",[1350,2120,2121],{"class":1833}," poetry",[1350,2123,2124],{"class":1808}," install\n",[1350,2126,2127],{"class":1352,"line":1370},[1350,2128,1409],{"emptyLinePlaceholder":1223},[1350,2130,2131],{"class":1352,"line":1376},[1350,2132,2133],{"class":2094},"# 2. Auto-start on login (macOS)\n",[1350,2135,2136,2138],{"class":1352,"line":1382},[1350,2137,2087],{"class":1833},[1350,2139,2140],{"class":1808}," install/install.sh\n",[1350,2142,2143],{"class":1352,"line":1388},[1350,2144,1409],{"emptyLinePlaceholder":1223},[1350,2146,2147],{"class":1352,"line":1394},[1350,2148,2149],{"class":2094},"# 3. Verify\n",[1350,2151,2152,2155],{"class":1352,"line":1400},[1350,2153,2154],{"class":1833},"curl",[1350,2156,2157],{"class":1808}," http://127.0.0.1:8765/health\n",[1350,2159,2160],{"class":1352,"line":1406},[1350,2161,2162],{"class":2094},"# {\"status\":\"ok\"}\n",[1350,2164,2165],{"class":1352,"line":1412},[1350,2166,1409],{"emptyLinePlaceholder":1223},[1350,2168,2169],{"class":1352,"line":1224},[1350,2170,2171],{"class":2094},"# 4. Drop the device on a track\n",[1350,2173,2174],{"class":1352,"line":1423},[1350,2175,2176],{"class":2094},"# Drag device/MTL_C2PA_Ableton_PoC.amxd onto any audio track in Live.\n",[748,2178,2179,2180,868],{},"That's it. Click a Lyria clip — see the manifest. Full setup detail in the ",[1119,2181,2184],{"href":2182,"rel":2183},"https://github.com/musictechlab/mtl-c2pa-ableton",[1178],"repo README",[761,2186,2188],{"id":2187},"roadmap","Roadmap",[748,2190,2191,2192,2197],{},"Generation-side device next. The plan is a Max for Live effect that signs the project at bounce time and emits a C2PA manifest describing the session's ingredients — samples, MIDI sources, plugin chain. We would like input from the ",[1119,2193,2196],{"href":2194,"rel":2195},"https://c2pa.org/community/",[1178],"C2PA community"," before settling on the assertion shape.",[748,2199,2200],{},"If you are interested in the broader open-source MCP family we have shipped:",[1718,2202,2205,2213,2221,2228],{"className":2203},[1721,1722,2204,1724,1725],"md:grid-cols-2",[1727,2206,2210],{"description":2207,"icon":2208,"title":2209,"to":173},"Read and write ID3, FLAC, and Vorbis tags from Claude — siblings on the metadata layer.","i-lucide-tag","mtl-metadata-mcp",[748,2211,2212],{},"ISRCs, artist, album, year — the rights-and-identifier layer that complements C2PA's provenance layer.",[1727,2214,2218],{"description":2215,"icon":2216,"title":2217,"to":591},"Complementary provenance: VHC says a human made this; C2PA says how it was made.","i-lucide-user-check","Verified Human Cert MCP",[748,2219,2220],{},"Together they answer the two questions about an AI-suspect track: was it made by a human, and what does the file declare about its origin?",[1727,2222,2225],{"description":2223,"icon":1231,"title":2224,"to":169},"Natural-language queries over Bandcamp revenue CSVs from Claude.","mtl-bandcamp-mcp",[748,2226,2227],{},"The same MCP-server pattern, different data source. Wraps the official Bandcamp Sales Report exports.",[1727,2229,2233],{"description":2230,"icon":2231,"title":2232,"to":141},"Adjacent metadata extraction — going below the LiveAPI layer.","i-lucide-file-search","Inside .als and .asd files",[748,2234,2235],{},"For when you need to read an Ableton project without opening Ableton — same Max for Live series, different angle.",[761,2237,2239],{"id":2238},"try-it-break-it-send-feedback","Try it, break it, send feedback",[748,2241,2242,2243,2247],{},"The device is MIT-licensed. Repo: ",[1119,2244,2246],{"href":2182,"rel":2245},[1178],"musictechlab/mtl-c2pa-ableton",". Issues and PRs welcome. If you build something on top of the local HTTP server (a Logic plugin, a REAPER script, a standalone viewer), tell us — same pattern works for any DAW that can shell out to localhost.",[1167,2249],{},[761,2251,2253],{"id":2252},"need-help-integrating-c2pa-into-your-music-workflow","Need help integrating C2PA into your music workflow?",[748,2255,2256],{},"Adding provenance to your distribution pipeline, AI music platform, DAW plugin, or rights workflow? We have been there.",[748,2258,2259,2263],{},[1119,2260,2262],{"href":2261},"/contact","Let's talk"," — no sales pitch, just honest engineering advice.",[2265,2266,2267],"style",{},"html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}",{"title":1187,"searchDepth":1188,"depth":1188,"links":2269},[2270,2271,2272,2273,2274,2275,2276,2277,2278,2279,2280],{"id":1289,"depth":1188,"text":1290},{"id":1321,"depth":1188,"text":1322},{"id":1339,"depth":1188,"text":1340},{"id":1592,"depth":1188,"text":1593},{"id":1712,"depth":1188,"text":1713},{"id":1769,"depth":1188,"text":1770},{"id":2056,"depth":1188,"text":2057},{"id":2077,"depth":1188,"text":2078},{"id":2187,"depth":1188,"text":2188},{"id":2238,"depth":1188,"text":2239},{"id":2252,"depth":1188,"text":2253},"2026-05-29T00:00:00.000Z","In May 2026 we shipped an MCP for reading C2PA manifests in music. This post is the follow-up: the same reader, now inside Ableton Live as an open-source Max for Live device.",[2284,2287,2290,2293,2296],{"question":2285,"answer":2286},"Why a local HTTP server instead of a CLI shell-out or a cloud API?","Python startup takes about 300 ms, which you feel on every clip click. A persistent local server keeps c2pa-python warm in memory. Cloud would mean uploading audio to a server just to inspect a file the user already has on disk — wrong shape for reading, right shape for generation.",{"question":2288,"answer":2289},"Does the device work without the Max for Live add-on?","No. You need Ableton Live Suite (which includes Max for Live), or Ableton Live Standard with the Max for Live add-on. The device is a .amxd file — it cannot run as a stock VST or AU plugin.",{"question":2291,"answer":2292},"Does the device upload my audio anywhere?","No. The FastAPI server binds to 127.0.0.1 only — loopback. No external network access. The Node for Max HTTP client only ever talks to your own machine. You can verify with `lsof -i :8765` while the server runs.",{"question":2294,"answer":2295},"What happens with MIDI clips or recorded audio that has no source file?","The device returns a structured info message: MIDI clip — no C2PA manifest applicable, or audio clip has no file path (recorded in session?). It never crashes the device, never blocks Live.",{"question":2297,"answer":2298},"Will this device tell me whose work trained the model that generated my Lyria stem?","No, and that is the next problem the C2PA community is working on. This device surfaces the output manifest — what Google Lyria declared about the file. Training-corpus attribution requires upstream provenance on the training data itself, which almost no major dataset is C2PA-signed today.",{"src":2300},"/images/blog/musictechlab_blog_c2pa-in-ableton-hero.webp",{"enabled":1223,"items":2302},[2303,2306,2309,2312],{"text":2304,"icon":2305},"Google Lyria signs every generated MP3 with a C2PA manifest, but Ableton has no way to display that information today.","i-lucide-eye-off",{"text":2307,"icon":2308},"A Max for Live device + local FastAPI server makes the manifest visible the moment you click a clip.","i-lucide-mouse-pointer-click",{"text":2310,"icon":2311},"All in one repo — Python HTTP server + Max for Live device. One clone, one install, no cloud round-trip.","i-lucide-package",{"text":2313,"icon":2314},"Read-side only — the harder problem (signing the DAW project, attributing the training corpus) is next.","i-lucide-arrow-right",{},{"title":2317,"description":2318},"C2PA in Ableton: Open-Source Max for Live Device | MusicTech Lab","Open-source Max for Live device that displays C2PA provenance manifests for the selected audio clip in Ableton Live. Read Lyria signatures inside your DAW.",[2320,2321,2322,2323,2324,2325,2326],"C2PA","Ableton","max-for-live","provenance","AI","MCP","open-source","f14gknzOHNEQ-GY8JJpiBZPV1xYNtcLHzKhVg9vpE9w",{"id":2329,"title":426,"authors":2330,"badge":1209,"body":2334,"category":1208,"client":1209,"date":2338,"description":2339,"extension":1212,"faq":1209,"featured":69,"featuredOrder":1209,"hidden":69,"image":2340,"keyTakeaways":1209,"meta":2342,"navigation":1223,"path":427,"seo":2343,"status":2344,"stem":428,"tags":2345,"teaser":2350,"__hash__":2351,"score":1188},"posts/blog/software-development/cross-platform-problem-for-creators.md",[2331],{"name":2332,"to":739,"avatar":2333},"Mariusz Smenzyk",{"src":741},{"type":745,"value":2335,"toc":2336},[],{"title":1187,"searchDepth":1188,"depth":1188,"links":2337},[],"2026-05-22T00:00:00.000Z","Ideas happen anywhere — rehearsal room, commute, studio. But syncing between devices is manual and error-prone. Offline support and conflict resolution are nonexistent.",{"src":2341},"/images/blog/musictechlab_blog_cross-platform-creators.webp",{},{"title":426,"description":2339},"upcoming",[2346,2347,2348,2349],"music-tech","mobile","cross-platform","sync","We'll explore the gap between capturing an idea on your phone and working on it in the studio — and why no tool has solved this properly yet.","lMykAOfi6ZnzrGoQwiTRS3ZIXCTLtU-rBei1PqZ3DLg",{"id":2353,"title":602,"authors":2354,"badge":2360,"body":2362,"category":1208,"client":1209,"date":2638,"description":2639,"extension":1212,"faq":1209,"featured":1223,"featuredOrder":1209,"hidden":69,"image":2640,"keyTakeaways":2642,"meta":2653,"navigation":1223,"path":603,"seo":2654,"status":1209,"stem":604,"tags":2657,"teaser":1209,"__hash__":2664,"score":1188},"posts/blog/software-development/musictechlab_blog_verified_human_partnership.md",[2355],{"name":2356,"to":2357,"avatar":2358},"Maciej Dulski","https://www.linkedin.com/in/maciej-dulski/",{"src":2359},"/images/cdn-migrated/maciej-dulski-400x400.webp",{"label":2361,"color":1266},"Partnership",{"type":745,"value":2363,"toc":2620},[2364,2367,2370,2374,2377,2380,2383,2387,2390,2393,2397,2400,2404,2407,2411,2414,2418,2425,2428,2431,2434,2437,2441,2444,2455,2459,2462,2473,2477,2480,2486,2489,2500,2503,2507,2518,2521,2524,2535,2538,2542,2553,2556,2560,2563,2577,2581,2585,2588,2591,2594,2598],[748,2365,2366],{},"The music industry is entering a phase where the question is no longer how music is made, but whether we can still trust what we hear.",[748,2368,2369],{},"At MusicTech Lab, we build software for the future of the music industry. That future must still respect the people who create it. This is why we are partnering with Verified Human — an initiative focused on establishing verifiable standards for human-made music in the age of AI.",[761,2371,2373],{"id":2372},"why-this-partnership-matters","Why this partnership matters",[748,2375,2376],{},"As generative AI tools reshape production workflows, questions around authorship, ownership, and attribution are becoming structural rather than theoretical.",[748,2378,2379],{},"The core challenge is no longer detection. It is provenance.",[748,2381,2382],{},"This collaboration focuses on restoring that missing layer — not by detecting AI usage, but by verifying human creation through structured, evidence-based certification.",[761,2384,2386],{"id":2385},"our-role-in-the-project","Our role in the project",[748,2388,2389],{},"MusicTech Lab acts as a technical advisor and audit partner to Verified Human.",[748,2391,2392],{},"Our involvement spans three areas:",[966,2394,2396],{"id":2395},"technical-review","Technical review",[748,2398,2399],{},"We are conducting a full technical and security review of the certification platform, focusing on architecture, API design, and system reliability.",[966,2401,2403],{"id":2402},"product-and-architecture-advisory","Product and architecture advisory",[748,2405,2406],{},"We support the ongoing development of the platform’s infrastructure, including scalability, developer experience, and integration patterns.",[966,2408,2410],{"id":2409},"ecosystem-and-go-to-market-collaboration","Ecosystem and go-to-market collaboration",[748,2412,2413],{},"We collaborate on ecosystem development and industry adoption of “human-made” music as a verifiable standard.",[761,2415,2417],{"id":2416},"how-verified-human-works","How Verified Human works",[748,2419,2420],{},[2421,2422],"img",{"alt":2423,"src":2424},"Verified Human Registry API interface","/images/blog/musictechlab_verified_human_screenshot_01.webp",[748,2426,2427],{},"Verified Human is not an AI detection system.",[748,2429,2430],{},"Detection asks what something is not. Certification proves what something is.",[748,2432,2433],{},"The system is an evidence-based framework (USPTO Serial #99666944) that verifies whether recorded audio was produced by human professionals.",[748,2435,2436],{},"It operates across two certification tracks:",[966,2438,2440],{"id":2439},"track-a-music-recordings","Track A — Music & Recordings",[748,2442,2443],{},"A tiered evidence model:",[977,2445,2446,2449,2452],{},[980,2447,2448],{},"Fully Verified: session files and professional production evidence provided",[980,2450,2451],{},"Verified: partial production documentation and validation",[980,2453,2454],{},"Historically Attested: recordings created before the era of generative AI",[966,2456,2458],{"id":2457},"track-b-podcasts-spoken-word","Track B — Podcasts & Spoken Word",[748,2460,2461],{},"Verification of whether content is:",[977,2463,2464,2467,2470],{},[980,2465,2466],{},"human-voiced",[980,2468,2469],{},"human-scripted",[980,2471,2472],{},"human-produced",[761,2474,2476],{"id":2475},"api-and-developer-integration","API and developer integration",[748,2478,2479],{},"The Verified Human registry exposes a public API designed for real-time verification using ISRC codes, artist names, or certificate identifiers.",[748,2481,2482],{},[2421,2483],{"alt":2484,"src":2485},"Certificate Details","/images/blog/musictechlab_verified_human_screenshot_02.webp",[748,2487,2488],{},"This enables:",[977,2490,2491,2494,2497],{},[980,2492,2493],{},"streaming platforms",[980,2495,2496],{},"rights organizations",[980,2498,2499],{},"catalog systems",[748,2501,2502],{},"to verify certification status directly during ingestion or playback.",[761,2504,2506],{"id":2505},"mcp-based-ai-integration","MCP-based AI integration",[748,2508,2509,2510,2513],{},"A key technical component of the ecosystem is the MCP server:",[2511,2512],"br",{},[1119,2514,2517],{"href":2515,"rel":2516},"https://github.com/musictechlab/mcp-verifiedhumancert",[1178],"mcp-verifiedhumancert",[748,2519,2520],{},"Built on the Model Context Protocol, it allows AI systems to query the Verified Human registry as a native tool inside LLM-based workflows.",[748,2522,2523],{},"It supports:",[977,2525,2526,2529,2532],{},[980,2527,2528],{},"ISRC-based verification",[980,2530,2531],{},"certificate lookup",[980,2533,2534],{},"artist + track resolution",[748,2536,2537],{},"This enables multi-agent workflows where metadata extraction and certification verification happen in a single automated pipeline.",[761,2539,2541],{"id":2540},"multi-agent-workflow-example","Multi-agent workflow example",[1546,2543,2544,2547,2550],{},[980,2545,2546],{},"One agent extracts ISRC from an audio file",[980,2548,2549],{},"Another agent queries the Verified Human registry",[980,2551,2552],{},"An orchestrator (e.g. Claude) combines the results",[748,2554,2555],{},"This removes the need for custom integration layers between metadata systems and certification APIs.",[761,2557,2559],{"id":2558},"implementation-support","Implementation support",[748,2561,2562],{},"MusicTech Lab supports implementation across the ecosystem:",[977,2564,2565,2568,2571,2574],{},[980,2566,2567],{},"DSPs: batch ISRC verification during catalog ingestion",[980,2569,2570],{},"Search systems: filtering for verified human-made content",[980,2572,2573],{},"Podcast networks: RSS-based certification metadata integration",[980,2575,2576],{},"Developers: embedding MCP-based verification into AI workflows",[2578,2579],"testimonials",{":items":2580},"[{\"quote\":\"Detection asks whether something is fake. Certification proves something is real. Real artists deserve a system that names them, not a model that erases them. That is what we are building, and that is why we wanted MusicTech Lab in the room from day one.\",\"name\":\"Jim Anderson\",\"description\":\"Founder and CEO @ Verified Human\",\"avatar\":\"/images/blog/jim-anderson-400-400.webp\"}]",[761,2582,2584],{"id":2583},"a-new-industry-standard","A new industry standard",[748,2586,2587],{},"This collaboration is not just a technical integration.",[748,2589,2590],{},"It is an attempt to define a trust layer for music in the AI era — where “human-made” becomes a verifiable, machine-readable attribute rather than a subjective claim.",[748,2592,2593],{},"By combining Verified Human’s vision with MusicTech Lab’s technical expertise and independent review, we are working toward infrastructure that keeps the human element at the center of the music industry.",[761,2595,2597],{"id":2596},"resources","Resources",[977,2599,2600,2607,2614],{},[980,2601,2602,2603],{},"Official website: ",[1119,2604,2605],{"href":2605,"rel":2606},"https://verifiedhumancert.com/",[1178],[980,2608,2609,2610],{},"Developer API: ",[1119,2611,2612],{"href":2612,"rel":2613},"https://verifiedhumancert.com/developers",[1178],[980,2615,2616,2617],{},"MCP server (open-source): ",[1119,2618,2515],{"href":2515,"rel":2619},[1178],{"title":1187,"searchDepth":1188,"depth":1188,"links":2621},[2622,2623,2628,2632,2633,2634,2635,2636,2637],{"id":2372,"depth":1188,"text":2373},{"id":2385,"depth":1188,"text":2386,"children":2624},[2625,2626,2627],{"id":2395,"depth":1194,"text":2396},{"id":2402,"depth":1194,"text":2403},{"id":2409,"depth":1194,"text":2410},{"id":2416,"depth":1188,"text":2417,"children":2629},[2630,2631],{"id":2439,"depth":1194,"text":2440},{"id":2457,"depth":1194,"text":2458},{"id":2475,"depth":1188,"text":2476},{"id":2505,"depth":1188,"text":2506},{"id":2540,"depth":1188,"text":2541},{"id":2558,"depth":1188,"text":2559},{"id":2583,"depth":1188,"text":2584},{"id":2596,"depth":1188,"text":2597},"2026-05-13T00:00:00.000Z","MusicTech Lab partners with Verified Human to build infrastructure for authentic, human-made music in the age of AI. Technical review, product development, and MCP-based AI integration.",{"src":2641,"credit":1179},"/images/blog/musictechlab_partnership_verified_human_1.webp",{"enabled":1223,"items":2643},[2644,2647,2650],{"text":2645,"icon":2646},"MusicTech Lab joins Verified Human as technical review and advisory partner.","i-lucide-shield-check",{"text":2648,"icon":2649},"The collaboration focuses on trust infrastructure for human-made music in the AI era.","i-lucide-link",{"text":2651,"icon":2652},"MCP-based tooling enables AI-native verification of music certification status.","i-lucide-terminal",{},{"title":2655,"description":2656},"MusicTech Lab x Verified Human Partnership | Human-Made Music Standard","MusicTech Lab partners with Verified Human to review, build, and scale infrastructure for certifying human-made music in the age of AI.",[2346,2658,2659,2660,2661,2662,2663],"verified-human","ai-music","mcp","music-authenticity","music-industry","ai-governance","nYwOD18TvoMelfM8S0E1IypXytYZGDvbH_WgyniWoEM",{"id":2666,"title":590,"authors":2667,"badge":2670,"body":2671,"category":1208,"client":1209,"date":3466,"description":3467,"extension":1212,"faq":3468,"featured":1223,"featuredOrder":1224,"hidden":69,"image":3484,"keyTakeaways":3487,"meta":3496,"navigation":1223,"path":591,"seo":3497,"status":1209,"stem":592,"tags":3500,"teaser":1209,"__hash__":3505,"score":1188},"posts/blog/software-development/mcp-verified-human-cert-open-source.md",[2668],{"name":738,"to":739,"avatar":2669},{"src":741},{"label":1265,"color":1266},{"type":745,"value":2672,"toc":3452},[2673,2682,2688,2692,2695,2769,2772,2775,2792,2796,2805,2825,2833,2836,2847,2852,2856,2859,2875,2879,2883,2911,2915,2925,3067,3071,3074,3091,3098,3105,3109,3118,3142,3265,3341,3344,3349,3353,3365,3395,3398,3406,3409,3413,3449],[748,2674,2675,2676,2681],{},"The line between human-made and machine-generated music is getting blurry. ",[1119,2677,2680],{"href":2678,"rel":2679},"https://verifiedhumancert.com",[1178],"Verified Human Cert"," (VHC) is one answer to that problem: a public registry where artists and labels certify that their tracks were created by humans.",[748,2683,2684,2685,868],{},"We wanted to query that registry without leaving our terminal. So we built an MCP server for it and open-sourced it: ",[1119,2686,2517],{"href":2515,"rel":2687},[1178],[761,2689,2691],{"id":2690},"what-the-server-does","What the server does",[748,2693,2694],{},"The server exposes six tools that map directly to the VHC public API:",[769,2696,2697,2707],{},[772,2698,2699],{},[775,2700,2701,2704],{},[778,2702,2703],{},"Tool",[778,2705,2706],{},"What it does",[789,2708,2709,2719,2729,2739,2749,2759],{},[775,2710,2711,2716],{},[794,2712,2713],{},[1298,2714,2715],{},"vhc_verify_isrc",[794,2717,2718],{},"Verify a certification by ISRC code",[775,2720,2721,2726],{},[794,2722,2723],{},[1298,2724,2725],{},"vhc_verify_track",[794,2727,2728],{},"Check certification status by artist + track name",[775,2730,2731,2736],{},[794,2732,2733],{},[1298,2734,2735],{},"vhc_verify_cert",[794,2737,2738],{},"Look up a certification by cert number",[775,2740,2741,2746],{},[794,2742,2743],{},[1298,2744,2745],{},"vhc_registry",[794,2747,2748],{},"List recently issued certifications",[775,2750,2751,2756],{},[794,2752,2753],{},[1298,2754,2755],{},"vhc_stats",[794,2757,2758],{},"Platform statistics, tier breakdowns, totals",[775,2760,2761,2766],{},[794,2762,2763],{},[1298,2764,2765],{},"vhc_pricing",[794,2767,2768],{},"Current pricing and bundle options",[748,2770,2771],{},"No API key needed. The VHC registry is public, and all these endpoints are read-only.",[748,2773,2774],{},"Once connected, you just talk to Claude:",[977,2776,2777,2782,2787],{},[980,2778,2779],{},[983,2780,2781],{},"\"Is ISRC USHM82148308 certified as human-made?\"",[980,2783,2784],{},[983,2785,2786],{},"\"Check if 'Yesterday' by The Beatles has a VHC certification\"",[980,2788,2789],{},[983,2790,2791],{},"\"Show me the latest certified tracks\"",[761,2793,2795],{"id":2794},"the-multi-agent-workflow","The multi-agent workflow",[748,2797,2798,2799,2804],{},"This is where it gets interesting. We already had ",[1119,2800,2803],{"href":2801,"rel":2802},"https://github.com/musictechlab/mcp-metadata",[1178],"mcp-metadata",", our open-source MCP server for reading and writing audio file metadata (ID3 tags, ISRC codes, Vorbis comments). Combining the two servers creates a multi-agent pipeline:",[1546,2806,2807,2813,2819],{},[980,2808,2809,2812],{},[752,2810,2811],{},"Agent 1"," (mcp-metadata) reads the ISRC code from an audio file",[980,2814,2815,2818],{},[752,2816,2817],{},"Agent 2"," (mcp-verifiedhumancert) verifies that ISRC against the VHC registry",[980,2820,2821,2824],{},[752,2822,2823],{},"Claude"," orchestrates both agents and presents the result",[1342,2826,2831],{"className":2827,"code":2829,"language":2830,"meta":1187},[2828],"language-text","User: \"Read the ISRC from song.flac and check if it's certified\"\n\nAgent 1 (mcp-metadata): metadata_read(\"song.flac\") -> ISRC: USHM82148308\nAgent 2 (mcp-verifiedhumancert): vhc_verify_isrc(\"USHM82148308\") -> certified: true\n","text",[1298,2832,2829],{"__ignoreMap":1187},[748,2834,2835],{},"Two MCP servers, two specialized agents, one orchestrator. No glue code, no custom integrations. Claude handles the coordination.",[748,2837,2838],{},[2421,2839],{"alt":2840,"className":2841,"src":2846},"Multi-agent workflow: mcp-metadata reads ISRC from an audio file, then mcp-verifiedhumancert checks the VHC registry",[2842,2843,2844,2845],"w-full","max-w-[600px]","rounded-lg","shadow-md","/images/blog/musictechlab_blog_vhc_mcp_multi_agent.webp",[1003,2848,2849],{},[748,2850,2851],{},"This pattern scales to any number of MCP servers. Each server handles one domain, and Claude routes between them based on what the user asks.",[761,2853,2855],{"id":2854},"why-this-matters-for-the-music-industry","Why this matters for the music industry",[748,2857,2858],{},"The rise of generative audio tools has created a trust problem. Listeners, labels, and platforms need a way to distinguish human-created work from machine-generated output. VHC provides that layer of trust, and our MCP server makes it accessible to developers and tooling without building custom API integrations.",[1718,2860,2862,2866,2870],{"className":2861},[1721,1722,1723,1724,1725],[1727,2863],{"description":2864,"icon":2646,"title":2865},"Check any track's certification status by ISRC, artist name, or cert number.","Verify Tracks",[1727,2867],{"description":2868,"icon":2649,"title":2869},"Combine with mcp-metadata to read ISRC from files and verify automatically.","Multi-Agent Pipeline",[1727,2871],{"description":2872,"icon":2873,"title":2874},"The VHC registry is public. No API keys, no signup, no rate limits to worry about.","i-lucide-globe","No Auth Required",[761,2876,2878],{"id":2877},"setting-it-up","Setting it up",[966,2880,2882],{"id":2881},"_1-clone-and-install","1. Clone and install",[1342,2884,2886],{"className":2084,"code":2885,"language":2087,"meta":1187,"style":1187},"git clone https://github.com/musictechlab/mcp-verifiedhumancert.git\ncd mcp-verifiedhumancert\npoetry install\n",[1298,2887,2888,2897,2904],{"__ignoreMap":1187},[1350,2889,2890,2892,2894],{"class":1352,"line":1353},[1350,2891,2100],{"class":1833},[1350,2893,2103],{"class":1808},[1350,2895,2896],{"class":1808}," https://github.com/musictechlab/mcp-verifiedhumancert.git\n",[1350,2898,2899,2901],{"class":1352,"line":1188},[1350,2900,2112],{"class":2111},[1350,2902,2903],{"class":1808}," mcp-verifiedhumancert\n",[1350,2905,2906,2909],{"class":1352,"line":1194},[1350,2907,2908],{"class":1833},"poetry",[1350,2910,2124],{"class":1808},[966,2912,2914],{"id":2913},"_2-register-with-claude-code","2. Register with Claude Code",[748,2916,2917,2918,2921,2922,1802],{},"Add this to your ",[1298,2919,2920],{},"~/.claude/settings.json"," or project ",[1298,2923,2924],{},".claude/settings.local.json",[1342,2926,2929],{"className":1776,"code":2927,"filename":2928,"language":1779,"meta":1187,"style":1187},"{\n  \"mcpServers\": {\n    \"vhc\": {\n      \"command\": \"poetry\",\n      \"args\": [\"--directory\", \"/path/to/mcp-verifiedhumancert\", \"run\", \"python\", \"-m\", \"mcp_verifiedhumancert\"]\n    }\n  }\n}\n","claude_mcp_config.json",[1298,2930,2931,2935,2949,2963,2984,3053,3058,3063],{"__ignoreMap":1187},[1350,2932,2933],{"class":1352,"line":1353},[1350,2934,1787],{"class":1786},[1350,2936,2937,2939,2942,2944,2946],{"class":1352,"line":1188},[1350,2938,1792],{"class":1786},[1350,2940,2941],{"class":1795},"mcpServers",[1350,2943,1799],{"class":1786},[1350,2945,1802],{"class":1786},[1350,2947,2948],{"class":1786}," {\n",[1350,2950,2951,2954,2957,2959,2961],{"class":1352,"line":1194},[1350,2952,2953],{"class":1786},"    \"",[1350,2955,2956],{"class":1833},"vhc",[1350,2958,1799],{"class":1786},[1350,2960,1802],{"class":1786},[1350,2962,2948],{"class":1786},[1350,2964,2965,2968,2972,2974,2976,2978,2980,2982],{"class":1352,"line":1370},[1350,2966,2967],{"class":1786},"      \"",[1350,2969,2971],{"class":2970},"sbssI","command",[1350,2973,1799],{"class":1786},[1350,2975,1802],{"class":1786},[1350,2977,1805],{"class":1786},[1350,2979,2908],{"class":1808},[1350,2981,1799],{"class":1786},[1350,2983,1814],{"class":1786},[1350,2985,2986,2988,2991,2993,2995,2998,3000,3003,3005,3007,3009,3012,3014,3016,3018,3021,3023,3025,3027,3030,3032,3034,3036,3039,3041,3043,3045,3048,3050],{"class":1352,"line":1376},[1350,2987,2967],{"class":1786},[1350,2989,2990],{"class":2970},"args",[1350,2992,1799],{"class":1786},[1350,2994,1802],{"class":1786},[1350,2996,2997],{"class":1786}," [",[1350,2999,1799],{"class":1786},[1350,3001,3002],{"class":1808},"--directory",[1350,3004,1799],{"class":1786},[1350,3006,1900],{"class":1786},[1350,3008,1805],{"class":1786},[1350,3010,3011],{"class":1808},"/path/to/mcp-verifiedhumancert",[1350,3013,1799],{"class":1786},[1350,3015,1900],{"class":1786},[1350,3017,1805],{"class":1786},[1350,3019,3020],{"class":1808},"run",[1350,3022,1799],{"class":1786},[1350,3024,1900],{"class":1786},[1350,3026,1805],{"class":1786},[1350,3028,3029],{"class":1808},"python",[1350,3031,1799],{"class":1786},[1350,3033,1900],{"class":1786},[1350,3035,1805],{"class":1786},[1350,3037,3038],{"class":1808},"-m",[1350,3040,1799],{"class":1786},[1350,3042,1900],{"class":1786},[1350,3044,1805],{"class":1786},[1350,3046,3047],{"class":1808},"mcp_verifiedhumancert",[1350,3049,1799],{"class":1786},[1350,3051,3052],{"class":1786},"]\n",[1350,3054,3055],{"class":1352,"line":1382},[1350,3056,3057],{"class":1786},"    }\n",[1350,3059,3060],{"class":1352,"line":1388},[1350,3061,3062],{"class":1786},"  }\n",[1350,3064,3065],{"class":1352,"line":1394},[1350,3066,1957],{"class":1786},[966,3068,3070],{"id":3069},"_3-start-using-it","3. Start using it",[748,3072,3073],{},"That's it. Ask Claude anything about the VHC registry:",[977,3075,3076,3081,3086],{},[980,3077,3078],{},[983,3079,3080],{},"\"Look up cert number VH-2026-000001\"",[980,3082,3083],{},[983,3084,3085],{},"\"What are the current VHC pricing tiers?\"",[980,3087,3088],{},[983,3089,3090],{},"\"How many tracks are certified on the platform?\"",[748,3092,3093],{},[2421,3094],{"alt":3095,"className":3096,"src":3097},"Looking up cert VH-2026-000001 in Claude Code",[2842,2843,2844,2845],"/images/blog/musictechlab_blog_vhc_mcp_cert_lookup.webp",[748,3099,3100],{},[2421,3101],{"alt":3102,"className":3103,"src":3104},"Querying VHC pricing tiers in Claude Code",[2842,2843,2844,2845],"/images/blog/musictechlab_blog_vhc_mcp_pricing.webp",[761,3106,3108],{"id":3107},"under-the-hood","Under the hood",[748,3110,3111,3112,3117],{},"The server is built with ",[1119,3113,3116],{"href":3114,"rel":3115},"https://github.com/modelcontextprotocol/python-sdk",[1178],"FastMCP",", the Python SDK for the Model Context Protocol. The architecture is straightforward:",[977,3119,3120,3128,3136],{},[980,3121,3122,3127],{},[752,3123,3124],{},[1298,3125,3126],{},"client.py"," - a thin HTTP wrapper around the VHC REST API using httpx",[980,3129,3130,3135],{},[752,3131,3132],{},[1298,3133,3134],{},"server.py"," - six tool definitions that call the client and return JSON",[980,3137,3138,3141],{},[752,3139,3140],{},"Tests"," - full test coverage using respx for HTTP mocking",[1342,3143,3146],{"className":3144,"code":3145,"filename":3134,"language":3029,"meta":1187,"style":1187},"language-python shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","@mcp.tool()\ndef vhc_verify_isrc(isrc: str) -> str:\n    \"\"\"Verify a human-made music certification by ISRC code.\"\"\"\n    result = client.verify_by_isrc(isrc)\n    return json.dumps(result, indent=2, ensure_ascii=False)\n",[1298,3147,3148,3163,3194,3206,3229],{"__ignoreMap":1187},[1350,3149,3150,3153,3155,3157,3160],{"class":1352,"line":1353},[1350,3151,3152],{"class":1786},"@",[1350,3154,2660],{"class":2111},[1350,3156,868],{"class":1786},[1350,3158,3159],{"class":2111},"tool",[1350,3161,3162],{"class":1786},"()\n",[1350,3164,3165,3168,3171,3174,3178,3180,3183,3186,3189,3191],{"class":1352,"line":1188},[1350,3166,3167],{"class":1795},"def",[1350,3169,3170],{"class":2111}," vhc_verify_isrc",[1350,3172,3173],{"class":1786},"(",[1350,3175,3177],{"class":3176},"sHdIc","isrc",[1350,3179,1802],{"class":1786},[1350,3181,3182],{"class":1833}," str",[1350,3184,3185],{"class":1786},")",[1350,3187,3188],{"class":1786}," ->",[1350,3190,3182],{"class":1833},[1350,3192,3193],{"class":1786},":\n",[1350,3195,3196,3200,3203],{"class":1352,"line":1194},[1350,3197,3199],{"class":3198},"s7zQu","    \"\"\"",[1350,3201,3202],{"class":2094},"Verify a human-made music certification by ISRC code.",[1350,3204,3205],{"class":3198},"\"\"\"\n",[1350,3207,3208,3211,3214,3217,3219,3222,3224,3226],{"class":1352,"line":1370},[1350,3209,3210],{"class":1356},"    result ",[1350,3212,3213],{"class":1786},"=",[1350,3215,3216],{"class":1356}," client",[1350,3218,868],{"class":1786},[1350,3220,3221],{"class":2111},"verify_by_isrc",[1350,3223,3173],{"class":1786},[1350,3225,3177],{"class":2111},[1350,3227,3228],{"class":1786},")\n",[1350,3230,3231,3234,3237,3239,3242,3244,3247,3249,3252,3254,3257,3259,3262],{"class":1352,"line":1376},[1350,3232,3233],{"class":3198},"    return",[1350,3235,3236],{"class":1356}," json",[1350,3238,868],{"class":1786},[1350,3240,3241],{"class":2111},"dumps",[1350,3243,3173],{"class":1786},[1350,3245,3246],{"class":2111},"result",[1350,3248,1900],{"class":1786},[1350,3250,3251],{"class":3176}," indent",[1350,3253,3213],{"class":1786},[1350,3255,3256],{"class":2970},"2",[1350,3258,1900],{"class":1786},[1350,3260,3261],{"class":3176}," ensure_ascii",[1350,3263,3264],{"class":1786},"=False)\n",[1342,3266,3268],{"className":3144,"code":3267,"filename":3126,"language":3029,"meta":1187,"style":1187},"def verify_by_isrc(isrc: str) -> dict:\n    \"\"\"Verify a certification by ISRC code.\"\"\"\n    return _get(\"/api/v1/verify\", params={\"isrc\": isrc})\n",[1298,3269,3270,3294,3303],{"__ignoreMap":1187},[1350,3271,3272,3274,3277,3279,3281,3283,3285,3287,3289,3292],{"class":1352,"line":1353},[1350,3273,3167],{"class":1795},[1350,3275,3276],{"class":2111}," verify_by_isrc",[1350,3278,3173],{"class":1786},[1350,3280,3177],{"class":3176},[1350,3282,1802],{"class":1786},[1350,3284,3182],{"class":1833},[1350,3286,3185],{"class":1786},[1350,3288,3188],{"class":1786},[1350,3290,3291],{"class":1833}," dict",[1350,3293,3193],{"class":1786},[1350,3295,3296,3298,3301],{"class":1352,"line":1188},[1350,3297,3199],{"class":3198},[1350,3299,3300],{"class":2094},"Verify a certification by ISRC code.",[1350,3302,3205],{"class":3198},[1350,3304,3305,3307,3310,3312,3314,3317,3319,3321,3324,3327,3329,3331,3333,3335,3338],{"class":1352,"line":1194},[1350,3306,3233],{"class":3198},[1350,3308,3309],{"class":2111}," _get",[1350,3311,3173],{"class":1786},[1350,3313,1799],{"class":1786},[1350,3315,3316],{"class":1808},"/api/v1/verify",[1350,3318,1799],{"class":1786},[1350,3320,1900],{"class":1786},[1350,3322,3323],{"class":3176}," params",[1350,3325,3326],{"class":1786},"={",[1350,3328,1799],{"class":1786},[1350,3330,3177],{"class":1808},[1350,3332,1799],{"class":1786},[1350,3334,1802],{"class":1786},[1350,3336,3337],{"class":2111}," isrc",[1350,3339,3340],{"class":1786},"})\n",[748,3342,3343],{},"The entire server is under 200 lines of Python. That's intentional. MCP servers should be thin wrappers, not application frameworks.",[1071,3345,3346],{},[748,3347,3348],{},"The project uses Poetry for dependency management, Ruff for linting and formatting, and pytest with respx for testing. CI runs on GitHub Actions.",[761,3350,3352],{"id":3351},"what-we-learned-building-mcp-servers","What we learned building MCP servers",[748,3354,3355,3356,1122,3361,3364],{},"This is the third MCP server we have open-sourced at MusicTech Lab (after ",[1119,3357,3360],{"href":3358,"rel":3359},"https://github.com/musictechlab/signnow-mcp",[1178],"signnow-mcp",[1119,3362,2803],{"href":2801,"rel":3363},[1178],"). A few patterns have emerged:",[1546,3366,3367,3373,3379,3385],{},[980,3368,3369,3372],{},[752,3370,3371],{},"Keep servers focused."," One server per domain. Don't bundle unrelated tools into a single server.",[980,3374,3375,3378],{},[752,3376,3377],{},"Separate the client from the server."," The HTTP client should be testable independently of the MCP layer.",[980,3380,3381,3384],{},[752,3382,3383],{},"Return JSON, not prose."," Let Claude format the output for the user. The server's job is to provide structured data.",[980,3386,3387,3390,3391,3394],{},[752,3388,3389],{},"Skip authentication when you can."," Public APIs make MCP servers trivial to set up. No ",[1298,3392,3393],{},".env"," files, no OAuth flows, no token management.",[761,3396,3397],{"id":2326},"Open source",[748,3399,3400,3401,3405],{},"The full source code is on GitHub: ",[1119,3402,3404],{"href":2515,"rel":3403},[1178],"musictechlab/mcp-verifiedhumancert",". MIT licensed. Contributions welcome.",[748,3407,3408],{},"If you're building MCP servers for the music industry, or if you're using Verified Human Cert and want to integrate it into your tooling, we'd love to hear from you.",[761,3410,3412],{"id":3411},"related-resources","Related resources",[977,3414,3415,3422,3429,3435,3441],{},[980,3416,3417,3421],{},[1119,3418,3420],{"href":2515,"rel":3419},[1178],"GitHub: musictechlab/mcp-verifiedhumancert"," - the source code",[980,3423,3424,3428],{},[1119,3425,3427],{"href":2801,"rel":3426},[1178],"GitHub: musictechlab/mcp-metadata"," - audio metadata MCP server",[980,3430,3431,3434],{},[1119,3432,3433],{"href":639},"SignNow MCP Server: E-Signatures from Claude Code"," - our previous MCP server article",[980,3436,3437,3440],{},[1119,3438,2680],{"href":2678,"rel":3439},[1178]," - the certification platform",[980,3442,3443,3448],{},[1119,3444,3447],{"href":3445,"rel":3446},"https://modelcontextprotocol.io/",[1178],"Model Context Protocol"," - the MCP standard",[2265,3450,3451],{},"html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}html pre.shiki code .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}",{"title":1187,"searchDepth":1188,"depth":1188,"links":3453},[3454,3455,3456,3457,3462,3463,3464,3465],{"id":2690,"depth":1188,"text":2691},{"id":2794,"depth":1188,"text":2795},{"id":2854,"depth":1188,"text":2855},{"id":2877,"depth":1188,"text":2878,"children":3458},[3459,3460,3461],{"id":2881,"depth":1194,"text":2882},{"id":2913,"depth":1194,"text":2914},{"id":3069,"depth":1194,"text":3070},{"id":3107,"depth":1188,"text":3108},{"id":3351,"depth":1188,"text":3352},{"id":2326,"depth":1188,"text":3397},{"id":3411,"depth":1188,"text":3412},"2026-04-28T00:00:00.000Z","We open-sourced an MCP server that queries the Verified Human Cert registry. Verify human-made music certifications by ISRC, artist, track, or cert number directly from Claude Code.",[3469,3472,3475,3478,3481],{"question":3470,"answer":3471},"What is Verified Human Cert?","Verified Human Cert is a registry that certifies music tracks as human-made. Artists and labels register their tracks to receive proof that the music was created by humans, not generated by artificial intelligence.",{"question":3473,"answer":3474},"What is the mcp-verifiedhumancert server?","It is an open-source Model Context Protocol server that connects the Verified Human Cert public API to Claude Code and other MCP-compatible clients. It lets you verify certifications, browse the registry, and check pricing directly from your terminal.",{"question":3476,"answer":3477},"Do I need an API key to use this?","No. The server queries the public VHC API, which does not require authentication for read-only operations like verifying certifications and browsing the registry.",{"question":3479,"answer":3480},"What is the multi-agent workflow?","By combining mcp-verifiedhumancert with mcp-metadata, Claude can read the ISRC code embedded in an audio file and then verify its certification status in a single conversation. Two MCP servers, two agents, one orchestrator.",{"question":3482,"answer":3483},"Can I use this with clients other than Claude Code?","Yes. Any MCP-compatible client can use this server. The MCP protocol is open and supported by a growing number of tools.",{"src":3485,"credit":3486},"/images/blog/musictechlab_blog_verified_human_cert_mcp.webp","Photo by [Erika Giraud](https://unsplash.com/@erikasayssmile) on [Unsplash](https://unsplash.com/photos/JXA_BaeaCgM)",{"enabled":1223,"items":3488},[3489,3491,3493],{"text":3490,"icon":2652},"The mcp-verifiedhumancert server exposes 6 tools for querying the Verified Human Cert registry.",{"text":3492,"icon":2649},"Combine with mcp-metadata to read ISRC from audio files and verify certifications automatically.",{"text":3494,"icon":3495},"No API key required. The server queries the public VHC registry at verifiedhumancert.com.","i-lucide-unlock",{},{"title":3498,"description":3499},"Verified Human Cert MCP Server | MusicTech Lab","Open-source MCP server for verifying human-made music certifications. Query by ISRC, artist, track, or cert number from Claude Code.",[2660,2326,3501,3502,3503,3504,3177],"verified-human-cert","music-certification","claude-code","multi-agent","0IMREhC3rcBLrbo0YpbBBh-vAUKPCXfiRMBvZlT0TVc",1780305259043]