AndreasHassing / SmartZensor

To control smarthome devices using sensors in my Galaxy Watch (Gear S3)

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Smart Zensor

Double-click Home, rotate your wrist; volume goes up and down! Leave control-mode by pressing Back.

See it in action here (twitter video).

I want this on my Samsung Watch ⌚!

Ok cool 🍦, follow these steps:

Prerequisites

Let's go!

  1. Clone this repository.

  2. Copy src/config.template.ts to src/config.ts and make changes to the sonosClientId and sonosClientSecret properties.

  3. Bootstrap a Sonos API token:

    # *nix in pwsh shell, or Win in PowerShell shell:
    ./tools/Set-BootstrappedSonosApiToken.ps1 -ClientId <client id from config.ts> -ClientSecret <client secret from config.ts>
    • You may think: "Why do I need to do all this?": I didn't bother implementing a OAuth2 authentication flow on the Gear - or in a companion app on Android). Instead, you run the initial access-token generation, and then let the app run it inside your watch for consecutive refreshes. Never do that in the real world! Your server should be creating and refreshing tokens on behalf of your users - do not share your integration secrets with devices that are not completely in your control.

  4. Run npm install and npm run build in the project folder.

  5. Load the ./tizenproject project in Tizen Studio and run it on your watch.

    • You can also run npm run build-dev to get source maps and easier debugging.
  6. Configure double-press of the Home button to open this app.

    • Press the Back button to stop controlling the volume.

Can you add feature x to "Smart Zensor"?

Feel free to open an issue against this repository and/or create a pull request. If feature requests are quick and easy to implement, I might add them when I find the time 😊.

About

To control smarthome devices using sensors in my Galaxy Watch (Gear S3)

License:MIT License


Languages

Language:TypeScript 75.4%Language:PowerShell 13.2%Language:JavaScript 5.1%Language:HTML 4.0%Language:CSS 2.4%