- What it can do
- How to setup
- Full table with available actions
- How to update to the latest version
- Troubleshooting
Follow these steps to easily control your kodi using simple voice commands with your Google Home or Google assistant:
"Hey Google, kodi play [movie name]" --> will search for the given movie name and play it.
"Hey Google, kodi resume [movie name]" --> will search for given movie name and pick up playback from where you left it.
"Hey Google, kodi play a random movie" --> will play a random movie.
"Hey Google, kodi play a random horror movie" --> will play a random movie of the genre "Horror".
"Hey Google, kodi play a random movie of the year 2010" --> will play a random movie of the year 2010.
"Hey Google, kodi play a random horror movie of the year 2010" --> will play a random movie of the genre "Horror" and of the year 2010.
Play the next unwatched episode: "Hey Google, kodi play tv show [tv show name]" --> will search for the given tv show and play the next unwatched episode.
Play a specific episode: "Hey Google, kodi play [tv show name] season 3 episode 1" --> will search for the given tv show and play season 3 episode 1.
Play a random episode from a tv show: "Hey Google, kodi shuffle [tv show name]" --> will search for the given tv show and play a random episode.
Play the most recently added episode: "Hey Google, kodi play new episode" --> will play the most recently added episode to the kodi library.
Binge watch a tv shoe: "Hey Google, kodi binge watch [tv show name]" --> will add all unwatched episodes to the playlist and play it.
"Hey Google youtube [youtube title]" --> will search a youtube video, and play the first video.
"Hey Google, pause kodi"
"Hey Google, stop kodi"
Mute kodi: "Hey Google, mute/unmute kodi"
Set volume: "Hey Google, set kodi volume to 60"
Increase volume: "Hey Google, Kodi volume up [by 10]" --> increase the volume by the requested amount or by 20% if no amount was specified
Decrease volume: "Hey Google, Kodi volume down [by 10]" --> similar to the above
"Hey Google, switch kodi to BBC channel" or "Hey Google, switch kodi to channel 10"
"Hey Google, switch to kodi" --> will turn on the TV and switch to Kodi's HDMI input
"Hey Google, kodi shutdown" "Hey Google, kodi hibernate" "Hey Google, kodi reboot" "Hey Google, kodi suspend"
"Hey Google, kodi scan library" --> Will start a full library scan
Navigate up: "Hey Google, kodi navigate up [3]" --> Will navigate up the requested amount or just once if no number was specified
Navigate Down: "Hey Google, kodi navigate down [3]" --> same as above for navigating down
Navigate Left: "Hey Google, kodi navigate left [3]" --> same as above for navigating left
Navigate Right: "Hey Google, kodi navigate right [3]" --> same as above for navigating right
Navigate Back: "Hey Google, kodi go back [3]" --> Will navigate back the requested amount or just once if no number was specified
Navigate Select: "Hey Google, kodi Select" --> Will select the hightlighted item
Navigate Context Menu: "Hey Google, kodi open context menu" --> Will open the context menu for the selected item
Navigate Go Home: "Hey Google, kodi go home" --> Will open the main menu page
"Hey Google, kodi show favourites"
"Hey Google, kodi show movies"
"Hey Google, kodi show movies by title"
"Hey Google, kodi show movies by genre"
"Hey Google, kodi show recently added movies"
"Hey Google, kodi show tv shows"
"Hey Google, kodi show tv shows by title"
"Hey Google, kodi show tv shows by genre"
"Hey Google, kodi show recently added episodes"
"Hey Google, kodi show video addons"
"Hey Google, kodi show music addons"
"Hey Google, kodi show video files"
"Hey Google, kodi show music files"
"Hey Google, kodi show the top 100 albums"
"Hey Google, kodi show system settings"
"Hey Google, kodi show file manager"
There are many more windows to choose from, a full list can be found here.
"Hey Google, kodi Whats Playing" --> Will show whats playing information
"Hey Google, kodi subtitles on/off/previous/next" --> Will change subtitle settings
"Hey Google, kodi change subtitle to track 3" --> Will change subtitle track to a specific track
"Hey Google, kodi audiostream previous/next" --> Will change audiostream settings
"Hey Google, kodi change audiostream to track 3" --> Will change audiostream settings
"Hey Google, kodi go forward 30 minutes" --> will seek forward [the requested number] of minutes or just 1 minute if no number was specified
"Hey Google, kodi go backward 30 minutes" --> same as above just seeking backward
"Hey Google, kodi jump to 30 minutes"
"Hey Google, kodi play the song [song name]" --> will search for the given song name and play it.
"Hey Google, kodi play the album [album name]" --> will search for the given album name and play it.
"Hey Google, kodi play songs by the artist [music artist name]" --> will search for the given music artist name and play it.
"Hey Google, kodi play some [genre name] music" --> will play shuffled songs of that genre.
"Hey Google, kodi toggle party mode" --> starts the kodi party mode.
"Hey Google, kodi playlist previous/next/list item number" --> This will go forward/backward or select an item on the playlist #.
Disclaimer: Use on your own risk and choose complex username & password in the below steps.
- In Kodi, go to Settings >> Web server
- Set Allow remote contorl via HTTP to On
- Choose a port number (e.g. 8080).
- Choose a username and password (Important!)
- Configure your router to forward the port you selected to your kodi device
Note: Not needed if you decide to go with a local node webserver (B.2) - Find your external IP address (i.e. Google 'what's my ip?')
We currently support three methods of how this app can be hosted.
- Hosting it in Glitch, a 3rd-party web-hosting service
- Hosting it yourself
- Hosting it yourself with Docker
The first method is very easy to set up and to maintain and also free of charge. The second method is for advanced users. You have to setup and maintain the nodejs environment yourself. But it supports multiple Kodi instances, greatly reduces latency and does not expose your kodi-webservice to the internet directly. The third method is also for advanced users. After installing docker, you can simply run our prebuilt docker images.
B.1 Set up a webserver in Glitch (Click to expand instructions)
- Go to Glitch.com and sign in with your github user
- Create a new Glitch project and under advance settings choose Import from GitHub
- Enter this project OmerTu/GoogleHomeKodi
- Change Glitch project settings to private (under share > Make private)
- Edit the .env file in your Glitch project with the following settings: (see this example)
KODI_PROTOCOL="http"
KODI_IP="YOUR_EXTERNAL_IP_ADDRESS"
KODI_PORT="YOUR_KODI_PORT"
KODI_USER="YOUR_KODI_USER_NAME"
KODI_PASSWORD="YOUR_KODI_PASSWORD"
AUTH_TOKEN="YOUR_CONNECTION_PASSWORD"
YOUR_CONNECTION_PASSWORD can be anything you want.
- Check your Glitch server address by choosing 'Show Live' on the top left. A new tab with your server will open. Note your server address in the address bar, you will need that later. We will refer to this address as YOUR_NODE_SERVER. (i.e. https://green-icecream.glitch.me)
B.2 Set up local webserver (Click to expand instructions)
- Install the Node.js application server on your target computer
Note: Required Version is 6.10 or above (8 preferred) - Choose a location, where your app will live (i.e
C:\node\
) - Clone this repo with git or simply download and unzip the sourcecode (green button on the top-right)
- You now should have a folder with a bunch of files in it (i.e. here
C:\node\GoogleHomeKodi
) - Install this app
cd C:\node\GoogleHomeKodi
npm install
- Create a copy of the
kodi-hosts.config.js.dist
file and name itkodi-hosts.config.js
. - Edit the file and make sure the kodiConfig and globalConfig sections match your environment.
- Set up your router to forward the port you just configured.
Default: globalConfig.listenerPort: '8099' - You should now be able to start the node server by running:
node server.js
. - Find your external IP address (i.e. Google 'what's my ip?')
Hint: It is strongly recommended to setup a dynDNS service of your choice. (i.e. selfhost.me) - The address of your self hosted node server now consists of the port of step 9 and the ip/host of step 10.
We will refer to this address later as YOUR_NODE_SERVER. (i.e. http://omertu.selfhost.me:8099)
For Linux-Users only: Here is a systemd init config. To run it as a daemon.
On a debian dist save it as /etc/systemd/system/kodiassistant.service
.
Don't forget to run: sudo systemctl enable sudo systemctl enable kodiassistant.service
to start the deamon on startup.
[Unit]
Description=Node.js Google Home Kodi Interface
[Service]
ExecStart=/usr/bin/node /opt/GoogleHomeKodi/server.js
# Required on some systems
WorkingDirectory=/opt/GoogleHomeKodi
Restart=always
# Restart service after 10 seconds if node service crashes
RestartSec=10
# Output to syslog
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=nodejs-example
[Install]
WantedBy=multi-user.target
B.3 Set up local webserver using Docker (Click to expand instructions)
As an alternative to (B.2), it's possible to use a pre-built Docker image to run a local instance.
You can use either environment variables or a kodi-hosts.config.js
inside a folder mapped to the /config
volume to configure your instance.
-
Install the Docker engine
- If you want to run it on a LibreELEC system
You can simply install the offical service addonDocker
- For all other systems please consult the offical documentation
Docker Installation
- If you want to run it on a LibreELEC system
-
Download or build the docker image
- For 64bit-Systems you can download out prebuilt docker-image
docker pull sinedied/googlehomekodi
- For all other systems you currently have to build the image yourself.
- Clone this repo with git or simply download and unzip the sourcecode (green button on the top-right)
- You now should have a folder with a bunch of files in it (i.e. here
C:\node\GoogleHomeKodi
) - Build the image
cd C:\node\GoogleHomeKodi docker build -t sinedied/googlehomekodi .
- For 64bit-Systems you can download out prebuilt docker-image
-
Run the docker image
- with the use of environment variables:
docker run -d -p 8099:8099 \ --restart always \ -e KODI_PROTOCOL="http" \ -e KODI_IP="YOUR_EXTERNAL_IP_ADDRESS" \ -e KODI_PORT="YOUR_KODI_PORT" \ -e KODI_USER="YOUR_KODI_USER_NAME" \ -e KODI_PASSWORD="YOUR_KODI_PASSWORD" \ -e AUTH_TOKEN="YOUR_CONNECTION_PASSWORD" \ --name googlehomekodi \ sinedied/googlehomekodi
- or with the use of the config file:
- Create a copy of the
kodi-hosts.config.js.dist
file and name itkodi-hosts.config.js
. - Edit the file and make sure the kodiConfig and globalConfig sections match your environment.
- Run it
docker run -d -p 8099:8099 \ --restart always \ -v YOUR_CONFIG_DIR:/config \ --name googlehomekodi \ sinedied/googlehomekodi
- Create a copy of the
- with the use of environment variables:
-
In case you need to update to a newer version later, just repeat steps 2 and 3 after executing:
docker stop googlehomekodi docker rm sinedied/googlehomekodi
There are two ways of implementing the scenario of multiple kodi instances (i.e one in the living room and another in the bedroom). For both methods you will need two IFTTT-Applets with different phrases, due to the text-parameter limitation of IFTTT.
- Having two node servers. Each targeting one instance. (Recommended when hosting with glitch)
i.e. the phraseliving room kodi play...
could targethttps://mylivingroom.glitch.com/playpause
and the phrasebedroom kodi play...
could targethttps://bedroom.glitch.com/playpause
.- Note: Behind a single external IP the kodi instances need still to be distinguishable.
This can be achieved in two ways:- Configuring both kodi instances with different ports
(i.e. 8080 and 8090)
or - Mapping with your routers port forwarding two different ports to the same port on different hosts
(i.e. 8080 -> 192.168.100.1:8080 and 8090 -> 192.168.100.2:8080)
- Configuring both kodi instances with different ports
- Note: Behind a single external IP the kodi instances need still to be distinguishable.
- Having one node server targeting both kodi instances. (Recommended when hosting yourself)
The utilization of the kodi-hosts.config.js allows you to name your instances and target them individually.
i.e. the phraseliving room kodi play...
could targethttp://192.168.100.1:8080/playpause
and the phrasebedroom kodi play...
could targethttp://192.168.100.2:8080/playpause
).
C.2 utilize the kodi-hosts.config.js (Click to expand instructions)
For this you will need to extend the list of configured kodi instances. Like in this example:
exports.kodiConfig = [
{
id: 'kodi', // Give your main instance here any name you want
// YOUR_KODI_PROTOCOL (http or https)
kodiProtocol: 'http',
// YOUR_KODI_IP_ADDRESS
kodiIp: '192.168.178.10',
// YOUR_KODI_PORT
kodiPort: '8080',
// YOUR_KODI_USER_NAME
kodiUser: 'kodi',
// YOUR_KODI_PASSWORD
kodiPassword: 'myKodiPass'
},
// You can use this to specify additonal kodi installation, that you'd like to control.
// For example alternate kodi destination 1:
{
id: 'bedroom',
// YOUR_2ND_KODI_PROTOCOL (http or https)
kodiProtocol: 'http',
// YOUR_2ND_KODI_IP_ADDRESS
kodiIp: '192.168.1.11',
// YOUR_2ND_KODI_PORT
kodiPort: '8080',
// YOUR_2ND_KODI_USER_NAME
kodiUser: 'kodi',
// YOUR_2ND_KODI_PASSWORD
kodiPassword: 'myKodiPass'
},
// You can use this to specify additonal kodi installation, that you'd like to control.
// For example alternate kodi destination 2:
{
id: 'kitchen',
// YOUR_3RD_KODI_PROTOCOL (http or https)
kodiProtocol: 'http',
// YOUR_3RD_KODI_IP_ADDRESS
kodiIp: '192.168.1.12',
// YOUR_3RD_KODI_PORT
kodiPort: '8080',
// YOUR_3RD_KODI_USER_NAME
kodiUser: 'kodi',
// YOUR_3RD_KODI_PASSWORD
kodiPassword: 'myKodiPass'
}
];
The id
(a name you can choose freely) will match your kodi instance with a spoken keyword.
For every command / kodi destination you will need to add a new IFTTT applet.
The only difference is found in the body
. As up until now you have been using a body only with a token attribute like: {"token":"*YOUR_CONNECTION_PASSWORD*"}
.
Now you will need to add the kodiid
attribute to it, matching the id
of your configuration.
Example scan library
If you normally would use a sentence like: "Hey Google, kodi scan library" --> Will start a full library scan
.
For running this command on your second kodi instance, you could copy the applet, and change it to:
"Hey Google, kodi scan library in the bedroom"
.
In this new applet, you will need to make sure it will recognize this new sentence, and add the attribute kodiid
to the body.
For example: {"token":"*YOUR_CONNECTION_PASSWORD*", "kodiid":"bedroom"}
-
Go to IFTTT
-
Create a new applet: if This then That
-
For This choose: Google Assistance
- Choose Say a phrase with a text ingredient
- In What do you want to say? enter something like:
Kodi play movie $
- In What do you want the Assistant to say in response? enter something like:
ok playing $ movie
-
For That choose: Maker Webhooks
- Choose Make a web request
- In URL enter:
YOUR_NODE_SERVER/playmovie?q={{TextField}}
For example, if your node server address is 'green-icecream.glitch.me', your should enter:
- Method: POST
- Content Type: application/json
- Body:
{"token":"YOUR_CONNECTION_PASSWORD"}
Check out this example to make sure your settings are correct
Now every time you say "Hey Google, Kodi play movie bla bla", it should play bla bla on your kodi.
Note: If your external IP changes, this will stop working (consider getting a static IP address)
For Tv show support - Next unwatched episode, follow all the steps in D, except these changes:
- Choose a different phrase (e.g. "Kodi play an episode of $")
- Use this URL:
YOUR_NODE_SERVER/playtvshow?q={{TextField}}
For Tv show support - Specific episode, follow all the steps in D, except these changes:
- Choose "Say a phrase with both a number and a text ingredient" in step 3
- Choose a different phrase (e.g. "Kodi play $ episode #").
For this to work, when you talk to your GoogleHome, the $ part must be in the format of "[TV_SHOW_NAME] season [SEASON_NUMBER]". Meaning the word "Season" has to be said, the tv show name must be said before it and the season number must be said after it (i.e. "okay google kodi play bla season 4 episode 1")
- Use this URL:
YOUR_NODE_SERVER/playepisode?q={{TextField}}&e={{NumberField}}
To pause or resume kodi follow the instructions in D, except these changes:
- Choose "Say a simple phrase" in step 3
- Use this URL:
YOUR_NODE_SERVER/playpause
To Stop kodi, follow the same instructions as pause but use this URL:
YOUR_NODE_SERVER/stop
To Mute kodi, follow the same instructions as pause but use this URL:
YOUR_NODE_SERVER/mute
To Set Volume on kodi use "Say a phrase with a number" and the URL:
YOUR_NODE_SERVER/volume?q={{NumberField}}
To Seek forward by x minutes use "Say a phrase with a number" and the URL:
YOUR_NODE_SERVER/seekforwardminutes?q={{NumberField}}
For PVR TV support - Set channel by name, follow all the steps in D, except these changes:
- Choose a different phrase (e.g. "switch kodi to $ channel")
- Use this URL:
YOUR_NODE_SERVER/playpvrchannelbyname?q={{TextField}}
For PVR TV support - Set channel by number, use "Say a phrase with a number" and the URL:
YOUR_NODE_SERVER/playpvrchannelbynumber?q={{NumberField}}
Type of phrase | phrase | url |
---|---|---|
Say a phrase with a text ingredient | Kodi play $ | YOUR_NODE_SERVER/playmovie?q={{TextField}} |
Say a phrase with a text ingredient | Kodi resume $ | YOUR_NODE_SERVER/resumemovie?q={{TextField}} |
Say a phrase with a text ingredient | Kodi play a random [$] movie [of year #] | YOUR_NODE_SERVER/playrandommovie?genre={{TextField}}&year={{NumberField}} |
Say a phrase with a text ingredient | Kodi play an episode of $ | YOUR_NODE_SERVER/playtvshow?q={{TextField}} |
Say a phrase with a text ingredient | Kodi resume an episode of $ | YOUR_NODE_SERVER/resumetvshow?q={{TextField}} |
Say a phrase with a text ingredient | Kodi binge watch $ | YOUR_NODE_SERVER/bingewatchtvshow?q={{TextField}} |
Say a phrase with both a number and a text ingredient | Kodi play $ episode # | YOUR_NODE_SERVER/playepisode?q={{TextField}}&e= {{NumberField}} |
Say a simple phrase | Kodi play new episode | YOUR_NODE_SERVER/playrecentepisode |
Say a simple phrase | Kodi pause | YOUR_NODE_SERVER/playpause |
Say a simple phrase | Kodi stop | YOUR_NODE_SERVER/stop |
Say a simple phrase | Kodi mute | YOUR_NODE_SERVER/mute |
Say a phrase with a number | Kodi set volume # | YOUR_NODE_SERVER/volume?q={{NumberField}} |
Say a phrase with a number Say a simple phrase |
Kodi volume up by # Kodi volume up |
YOUR_NODE_SERVER/volumeup?q={{NumberField}} YOUR_NODE_SERVER/volumeup |
Say a phrase with a number Say a simple phrase |
Kodi volume down by # Kodi volume down |
YOUR_NODE_SERVER/volumedown?q={{NumberField}} YOUR_NODE_SERVER/volumedown |
Say a phrase with a text ingredient | Kodi switch to $ channel | YOUR_NODE_SERVER/playpvrchannelbyname?q={{TextField}} |
Say a phrase with a number | Kodi switch to channel number # | YOUR_NODE_SERVER/playpvrchannelbynumber?q={{NumberField}} |
Say a simple phrase | Kodi activate | YOUR_NODE_SERVER/activatetv |
Say a simple phrase | Kodi standby | YOUR_NODE_SERVER/standbytv |
Say a simple phrase | Kodi shutdown | YOUR_NODE_SERVER/shutdown |
Say a simple phrase | Kodi hibernate | YOUR_NODE_SERVER/hibernate |
Say a simple phrase | Kodi reboot | YOUR_NODE_SERVER/reboot |
Say a simple phrase | Kodi suspend | YOUR_NODE_SERVER/suspend |
Say a phrase with a text ingredient | Kodi shuffle $ | YOUR_NODE_SERVER/shuffleepisode?q={{TextField}} |
Say a phrase with a text ingredient | Kodi youtube play $ | YOUR_NODE_SERVER/playyoutube?q={{TextField}} |
Say a simple phrase | Kodi scan library | YOUR_NODE_SERVER/scanlibrary |
Say a phrase with a number Say a simple phrase |
Kodi Navigate up # Kodi Navigate up |
YOUR_NODE_SERVER/navup?q={{NumberField}} YOUR_NODE_SERVER/navup |
Say a phrase with a number Say a simple phrase |
Kodi Navigate down # Kodi Navigate down |
YOUR_NODE_SERVER/navdown?q={{NumberField}} YOUR_NODE_SERVER/navdown |
Say a phrase with a number Say a simple phrase |
Kodi Navigate left # Kodi Navigate left |
YOUR_NODE_SERVER/navleft?q={{NumberField}} YOUR_NODE_SERVER/navleft |
Say a phrase with a number Say a simple phrase |
Kodi Navigate right # Kodi Navigate right |
YOUR_NODE_SERVER/navright?q={{NumberField}} YOUR_NODE_SERVER/navright |
Say a phrase with a number Say a simple phrase |
Kodi Navigate back # Kodi Navigate back |
YOUR_NODE_SERVER/navback?q={{NumberField}} YOUR_NODE_SERVER/navback |
Say a simple phrase | Kodi select | YOUR_NODE_SERVER/navselect |
Say a simple phrase | Kodi show context menu | YOUR_NODE_SERVER/navcontextmenu |
Say a simple phrase | Kodi go home | YOUR_NODE_SERVER/navhome |
Say a simple phrase | Kodi whats playing | YOUR_NODE_SERVER/displayinfo |
Say a phrase with a text ingredient | Kodi show $ | YOUR_NODE_SERVER/showWindow?q={{TextField}} |
Say a phrase with a text ingredient | Kodi show movie genre $ | YOUR_NODE_SERVER/showMovieGenre?q={{TextField}} |
Say a phrase with a text ingredient | Kodi execute addon $ | YOUR_NODE_SERVER/executeAddon?q={{TextField}} |
Say a phrase with a text ingredient | Kodi subtitles $ | YOUR_NODE_SERVER/setsubtitles?q={{TextField}} |
Say a phrase with a number | Kodi subtitles direct select # | YOUR_NODE_SERVER/setsubtitlesdirect?q={{NumberField}} |
Say a phrase with a text ingredient | Kodi audio stream $ | YOUR_NODE_SERVER/setaudio?q={{TextField}} |
Say a phrase with a number | Kodi audio stream direct select # | YOUR_NODE_SERVER/setaudiodirect?q={{NumberField}} |
Say a phrase with a number Say a simple phrase |
Kodi seek forward # minutes Kodi seek forward |
YOUR_NODE_SERVER/seekforwardminutes?q={{NumberField}} YOUR_NODE_SERVER/seekforwardminutes |
Say a phrase with a number Say a simple phrase |
Kodi seek backward # minutes Kodi seek backward |
YOUR_NODE_SERVER/seekbackwardminutes?q={{NumberField}} YOUR_NODE_SERVER/seekbackwardminutes |
Say a phrase with a number | Kodi seek to # minutes | YOUR_NODE_SERVER/seektominutes?q={{NumberField}} |
Say a phrase with a text ingredient | Kodi play the song $ | YOUR_NODE_SERVER/playsong?q={{TextField}} |
Say a phrase with a text ingredient | Kodi play the album $ | YOUR_NODE_SERVER/playalbum?q={{TextField}} |
Say a phrase with a text ingredient | Kodi play the artist $ | YOUR_NODE_SERVER/playartist?q={{TextField}} |
Say a phrase with a text ingredient | Kodi play the music genre $ | YOUR_NODE_SERVER/playgenre?q={{TextField}} |
Say a phrase with a text ingredient | Kodi playlist $ | YOUR_NODE_SERVER/playercontrol?q={{TextField}} |
Say a simple phrase | Kodi toggle party mode | YOUR_NODE_SERVER/togglePartymode |
Say a phrase with a text ingredient | Kodi open $ from my favourites | YOUR_NODE_SERVER/playfavourite?q={{TextField}} |
Say a simple phrase | Kodi toggle fullscreen | YOUR_NODE_SERVER/togglefullscreen |
Say a phrase with a text ingredient | Kodi load profile $ | YOUR_NODE_SERVER/loadProfile |
To Turn on/off the TV and switch Kodi's HDMI input
-
This requires Kodi 17 (Krypton) and above
-
This also requires that both your kodi device and TV support CEC commands
-
You need to install this script.json-cec add-on: Download and move it to your kodi device and then in Kodi choose Settings>Add-ons>Install from zip file > choose the zip your just downloaded.
-
Finally you can use this in 2 ways:
- Turn on: Add another command: follow the same instructions as pause but use this URL:
YOUR_NODE_SERVER/activatetv
- If host your server on Glitch, add the following line to your .env file (see step B.1 - (5) above) and kodi will automaticly turn on the tv and switch the HDMI input everytime your trigger the main playing actions (play a move / tv show / episode / pvr channel)
ACTIVATE_TV="true"
- If you host your server yourself (see step B.2 - (7) above), then add the following line at the end of your kodi-hosts.config.js file instead
process.env['ACTIVATE_TV'] = 'true';
- Turn off: Add another command: follow the same instructions as pause but use this URL:
YOUR_NODE_SERVER/standbytv
- Go to Glitch.com and sign in with your github user
- Select your Glitch project and under advance settings choose Import from GitHub
- Enter this project OmerTu/GoogleHomeKodi
If your can't preform a simple action like pausing a video, try to narrow down to problem:
- While a video is being played in Kodi, try pausing it by entering this in your browser:
http://YOUR_INTERNAL_KODI_IP:PORT/jsonrpc?request={"jsonrpc":"2.0","id":1,"method":"Player.playpause","params":{"playerid":1}}
If you get prompt to enter username and password choose the ones you set in Kodi (step A above). If that doesn't work, you probably have a problem with your kodi setup.
- If that works, try pausing a video using your external IP:
http://YOUR_EXTERNAL_IP:PORT/jsonrpc?request={"jsonrpc":"2.0","id":1,"method":"Player.playpause","params":{"playerid":1}}
If that doesn't work you probably have a problem with your router configuration.
- If it does work, there might be something wrong in your glich or IFTTT settings.
Thanks for everyone who contributed to this projects: p0psicles, keydon, Keljian and Lunatixz
I also used some code from these 3 projects: MarvinSchenkel/HomeyKodi Jephuff/kodi-rpc joshjowen/script.json-cec
And this wonderful website makes setting this up super easy - Glitch
I hope you find this helpful! If you'd like, you can give me a cup of coffee :)