3d1817a6b9 | ||
---|---|---|
.. | ||
public | ||
script | ||
src | ||
README.md |
README.md
Home Assistant Cast
Home Assistant Cast is made up of two separate applications:
- Chromecast receiver application that can connect to Home Assistant and display relevant information.
- Launcher website that allows users to authorize with their Home Assistant installation and launch the receiver app on their Chromecast.
Development
- Run
script/develop_cast
to launch the Cast receiver dev server. Keep this running. - Navigate to http://localhost:8080 to start the launcher
- Debug the receiver running on the Chromecast via chrome://inspect/#devices
Setting up development environment
Registering development cast app
- Go to https://cast.google.com/publish and enroll your account for the Google Cast SDK (costs $5)
- Register your Chromecast as a testing device by entering the serial
- Add new application -> Custom Receiver
- Name: Home Assistant Dev
- Receiver Application URL: http://IP-OF-DEV-MACHINE:8080/receiver.html
- Guest Mode: off
- Google Case for Audio: off
Setting dev variables
Open src/cast/dev_const.ts
and change CAST_DEV_APP_ID
to the ID of the app you just created. And set the CAST_DEV_HASS_URL
to the url of your development machine.
Changing configuration
In configuration.yaml
, configure CORS for the HTTP integration:
http:
cors_allowed_origins:
- https://cast.home-assistant.io
- http://IP-OF-DEV-MACHINE:8080
Running development
cd cast
script/develop_cast
The launcher application will be accessible at http://localhost:8080 and the receiver application will be accessible at http://localhost:8080/receiver.html (but only works if accessed by a Chromecast).
Developing cast widgets in HA ui
If your work involves interaction with the Cast parts from the normal Home Assistant UI, you will need to have that development script running too (script/develop
).
Developing the cast demo
The cast demo is triggered from the Home Assistant demo. To work on that, you will also need to run the development script for the demo (script/develop_demo
).