WTH Do I have to go to a strange forum to search for Blueprints?

I don’t know how much this will resonate with people. Blueprints have really helped my automation game. No longer do I have to have “what happens when someone enters” be a separate automation from “what happens when someone exits”. Stuff like that. Amazing.

However the whole discovery experience is very “developer UX”. It should be a first party solution and not a bolt-on of the forums.

I will describe to you, however, my experience searching for Blueprints the first time.

Click on “Import Blueprint”. Internal monologue: I hope there is a way to find blueprints in this import thing. I don’t know how to import something, but we will see.

Presented with “Blueprint Address”. Me: Ok, I don’t know the address? Blueprints have addresses? AHA! There is a “view blueprints on the community forum!”

Arrive at the forums. Me: Ok, this looks like a list of blueprints. I don’t care about any of these. How do I search? Are there categories? Aha, a search button.

Search for “motion light”. Me: Ok, why am I getting results that aren’t blueprints? Did I do something wrong? Aha, if I click on search there is a “In Blueprints Exchange” option. Try again.

Click on any blueprint listing. Me: Ok, each post is completely different. Where is the download link? What is the short description / long description / implementation details. Some people document the journey of their development. Some people post almost nothing. Sometimes the download link is in a reply, sometimes in the original post. Sometimes there is no link and it’s just the code.

Madness. I didn’t even get into the inconsistency of bringing in blueprints, the versioning story, etc. This needs investment - it is one of the most powerful parts of Home Assistant and it’s terribly difficult to use and I suspect lots of people aren’t using it because of that.

The experience should be a first-party discovery UI with consistent places to find certain data (like in Add-ons) and discovery / import should be one cohesive experience instead of two separate things.

So you want something like HACS for blueprints?

9 Likes

HACS for blueprints would be awesome. The discoverability and consistency of the presentation because of the requirements to get into HACS helps a lot.

3 Likes

It was proposed, partially written, and rejected, so I agree awesome, but not happening… (FYI)

1 Like

There is another WTH for this an Frenck even replied to that in regards to HACS.

I was just clarifying what they wanted, I don’t actually use blueprints. I like to write my own automations customised for my use cases.

1 Like

This WTH is written very much from a perspective of the consumer of the blueprint. I agree the sharing process could be better. But let’s not forget many blueprints are made by regular users, tinkerers, not developers. Some of these users will not have github accounts to host their code on. Some will have spent most of their available time to get the underlying automation to work, most of what was left in making that into a blueprint, and don’t want to spend more time on adding detailed documentation or complying with specific templates.
I think it is a great idea to make the process of creating and sharing blueprints easier. And it would be awesome if those improvements also make it easier for other users to find those blueprints. But let’s keep the barrier for sharing as low as possible.

3 Likes

HACS is not excluding other ways of sharing.
It is just setting a framework for presenting, downloading and installing the code.
Some of the things you request.

1 Like

Yup, you are right. Clicking that my: link in the blueprint exchange is really hard to figure out, and searching for what you want is really hard as well. Stuff like this should exist.
Tips on Searching for Answers & Duplicate Topics in the Forum.

@Sir_Goodenough is this a reply to my post or to the OP? The point I was trying to make is that I don’t want to force blueprint authors to add more metadata and comply with specific templates etc in order to make finding blueprints easier. I am not sure how your reply relates to that?
As for your first remark, I think part of the OP’s point is that some posts in the Blueprints forum have a my: link but some don’t, and it’s that inconsistency that they want to be addressed.
I definitely see value in something like an AI chat blueprint search function inside HA. To which you can describe the functionality you desire, and that will find you relevant existing blueprints, using knowledge about your configuration to make sure you can actually use them. I do not, however, want to get there by making more restrictive rules on how to share blueprints.

I really like this WTH, if it goes the path of HACS-styling, you could even refine your search for blueprints that work with your devices. Touches on the WTH’s about suggesting things to users as well.

HACS for blueprints is exactly the kind of thing I was thinking of! Love that idea.

1 Like

Yeah +1 for a Blueprint store

I also like the HACS for Blueprints idea. Think about it: Blueprints are an officially supported feature, yet the UI for discovering and installing them is worse than the UI for the not-supported, not-official add ons you find via HACS… :wink:

W.r.t. the remarks about “forcing people to add more structured meta data” presumably making it more difficult to share blueprints: I don’t agree. A little bit of guidance can even make it easier. “Free form” is not always easier. Having a set place where you can fill in some meta data in a structured way can actually be easier than a “free form” solution. Just don’t make it too complicated and be very careful with making things mandatory.

This has been my biggest problem with Blueprints as well. Forums are a horrible way to discover them, as you have to wade through pages of comments to tell if they still work.

A Blueprint exchange needs to allow blueprint authors to publish a manifest for their blueprint that has properties like:

  • Blueprint Name
  • Blueprint id? (not sure if this is needed? would be an implementation detail of the store)
  • Blueprint Description
  • Blueprint homepage
  • keywords
  • version number
  • issue/bugs: (link to repo or forum thread)
  • HA version compatibility
  • indicate dependent add-ons
  • last updated date (should automatically update on publish)
  • status [active, deprecated, experimental] (oneOf)
  • docs? (link to docs)
  • license?
  • Author (name, email?, url?)

Here would be an example Manifest for a blueprint I’m working on now to test servo motors for 3D printer MMU :

name: ESP Servo Motor Tester
id: esp-servo-tester
version: 1.0.0
homepage: https://github.com/LongLiveCHIEF/esp-servo-tester
issues: https://github.com/LongLiveCHIEF/esp-servo-tester/issues
author:
  name: Brian
  url: https://github.com/LongLiveCHIEF
dependencies: 
  - addons: [esphome builder]
status: experimental
description: Adds servo controls to HA for calibrating a servo motor using an esphome device
keywords: [esp32, servo, 3D Printing, RC Hobby]
license: MIT