-
-
Notifications
You must be signed in to change notification settings - Fork 7.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Somfy open api #9625
Merged
Merged
Somfy open api #9625
Changes from 8 commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
2381485
CREATE documentation for new Somfy component
tetienne 1ef9aa4
UPDATE ha_release
tetienne 0c5a6d5
UPDATE ha_release to 0.95
tetienne 6e4bd4e
UPDATE ha_release to 0.95
tetienne 448aa11
MERGE cover documentation within main one
tetienne 6f9b90d
UPDATE No more notification, use Integrations
tetienne 6a53f7d
:pencil2: Tweak
klaasnicolaas f33e1fb
:pencil2: Tweaks
frenck f14f291
REMOVE qa scale
tetienne File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
--- | ||
layout: page | ||
title: "Somfy" | ||
description: "Instructions on how to set up the Somfy hub within Home Assistant." | ||
date: 2019-06-07 12:00 | ||
sidebar: true | ||
comments: false | ||
sharing: true | ||
footer: true | ||
logo: somfy.png | ||
ha_category: | ||
- Hub | ||
ha_iot_class: Cloud Polling | ||
ha_release: 0.95 | ||
ha_qa_scale: gold | ||
--- | ||
|
||
The Somfy component will allow users to integrate their Somfy devices into Home Assistant using the [official API](https://developer.somfy.com/somfy-open-api/apis), unlike the [tahoma](/components/tahoma/) component. | ||
|
||
### {% linkable_title Setting up developer account %} | ||
|
||
To connect Somfy, you need to set up a developer account. | ||
|
||
1. Visit [https://developer.somfy.com](https://developer.somfy.com). | ||
2. Log in using your Somfy credentials. | ||
3. Open the *My Apps* menu. | ||
4. Add a new App: | ||
- App Name: Home Assistant | ||
- Callback URL: `<YOUR_HOME_ASSISTANT_URL>/auth/somfy/callback` | ||
- Description: Home Assistant instance | ||
- Product: Somfy Open API | ||
5. Once Home Assistant restarted, go to Configuration>Integration. | ||
6. Select the Somfy integrations. | ||
|
||
### {% linkable_title Configuration %} | ||
|
||
```yaml | ||
# Example configuration.yaml entry | ||
somfy: | ||
client_id: CONSUMER_KEY | ||
client_secret: CONSUMER_SECRET | ||
``` | ||
|
||
{% configuration %} | ||
client_id: | ||
description: Your Somfy consumer key. | ||
required: true | ||
type: string | ||
client_secret: | ||
description: Your Somfy consumer secret. | ||
required: true | ||
type: string | ||
{% endconfiguration %} | ||
|
||
### {% linkable_title Potential duplicate with the Tahoma component %} | ||
|
||
If you use the [tahoma](/component/tahoma) component, you will have to exclude the covers added by this one. Otherwise, they will be added twice. | ||
|
||
```yaml | ||
# Example configuration.yaml entry | ||
tahoma: | ||
username: YOUR_USERNAME | ||
password: YOUR_PASSWORD | ||
exclude: ['rts:RollerShutterRTSComponent','rts:CurtainRTSComponent','rts:BlindRTSComponent','rts:VenetianBlindRTSComponent','rts:DualCurtainRTSComponent','rts:ExteriorVenetianBlindRTSComponent','io:ExteriorVenetianBlindIOComponent','io:RollerShutterUnoIOComponent','io:RollerShutterWithLowSpeedManagementIOComponent','io:RollerShutterVeluxIOComponent','io:RollerShutterGenericIOComponent','io:WindowOpenerVeluxIOComponent','io:VerticalExteriorAwningIOComponent','io:HorizontalAwningIOComponent'] | ||
``` |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The quality scale index is incorrect IMHO. For a gold standard, there should be tests between HA & the integration. Currently, I only see tests for the configuration flow. (which are excluded from the code coverage, which it should NOT have been btw...)
See: https://developers.home-assistant.io/docs/en/integration_quality_scale_index.html
For now, I suggest removing this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are you talking about this:
What do you think to replace by Silver 🥈 ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For the coverage, I will see how include my tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well for silver it should:
✅ Connection/configuration is handled via a component.
❌ Set an appropriate SCAN_INTERVAL (if a polling integration)
❌ Raise PlatformNotReady if unable to connect during platform setup (if appropriate)
❓ Handles expiration of auth credentials. Refresh if possible or print correct error and fail setup.
❓ If based on a config entry, should trigger a new config entry flow to re-authorize.
❓ Handles internet unavailable. Log a warning once when unavailable, log once when reconnected.
❓ Handles device/service unavailable. Log a warning once when unavailable, log once when reconnected.
❌ Set available property to False if appropriate (docs)
✅ Entities have unique ID (if available) (docs)
Even though I haven't checked on the question marks, I still see missing things for a silver 🥈
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You are right. I will remove it. I have still a lot of stuff to do it seems.
Sadly, it seems that existing component with qa scale don't respect these rules. Do you know a good one?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The QA scale should be correct in the documentation. If you feel like one is incorrect, feel free to raise an issue or open a PR.
Hue & deCONZ are probably good examples.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for the information.