57 lines
2.1 KiB
Markdown
57 lines
2.1 KiB
Markdown
# 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](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:
|
|
|
|
```yaml
|
|
http:
|
|
cors_allowed_origins:
|
|
- https://cast.home-assistant.io
|
|
- http://IP-OF-DEV-MACHINE:8080
|
|
```
|
|
|
|
## Running development
|
|
|
|
```bash
|
|
cd cast
|
|
script/develop_cast
|
|
```
|
|
|
|
The launcher application will be accessible at [http://localhost:8080](http://localhost:8080) and the receiver application will be accessible at [http://localhost:8080/receiver.html](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`).
|