Gitter Chat | Build Status |
---|---|
Using the .NET Bridge Accessory Server for HomeKit to control your home appliances and IOT devices.
If you are an iOS user that is using HomeKit to control devices at home, you might be interested in controlling your own devices that you might have put together, purchased online or even controlling your home computers.
We have made it simple for you to build HapSharp is a Net implementation of the HomeKit Accessory Server.
With this host you would be able to create your own custom HomeKit Accessory on a Raspberry Pi, Mac computer or any other platform that can run Mono.
HapSharp also supports create your own custom accessories and share between the community installed by using NuGet.org platform.. explore now all available nugets ready to use!
Since Siri could interact with HomeKit accessories, this means we can ask Siri to control devices that don’t have support for HomeKit.
For instance, using just some of the available accessories, you can say:
- Siri, unlock the back door.
- Siri, open the garage door.
- Siri, turn on the coffee maker.
- Siri, turn on the living room lights.
- Siri, good morning!
HapSharp project basically is a library which includes a class session to host your .net virtual accessories and expose they over HomeKit.
To use it, you will only need create a simple console, desktop, forms.. application and include the library (or nuget), and… with a few lines of code your host will be available in your network and ready to use from any application that use HomeKit API (for example the Home App)
To establish communication between HapSharp and HomeKit, we need a new player into the game, HAP-NodeJS. His mission is keep the communication with HomeKit and tunnel this information to our HapSharp host using MQTT.
HAP-NodeJS is a consolidated project, started at 2014, with a very active community and a solid and tested connection logic. In the future we can thing about the posibility of port to C# this layer.
HapSharp requires some previous steps before start to work with. I tried to simplify all with a setup guide.
Once your installation is done we are ready to the next step.
NOTES BEFORE LAUNCH
Remember you will need run any MQTT broker before start the host server
Note: If you are experiencing issues executing, check the Troubleshooting section
Once we have all our NodeJS accessories are generated in place, we launch the NodeJS process in background.
Right now, in this prototype there are 4 type of accessories to include in your host:
-
BridgedCore: This an special accessory, like a hub, can host other Accessories “behind”. This way we can simply publish the Bridge (with a simple HAPServer on a single port) and all bridged Accessories will be hosted automatically.
-
Light: This accessory exposes the behaviour of a single light, with 2 states: On/Off
-
Light with Brightness: Same like simple light but adds a regulable brightness bar
-
Temperature sensor: It allows handle the temperature in a specific timeout sending the calculated values to HomeKit.
-
Humidity sensor: It allows handle the humidty in a specific timeout sending the calculated values to HomeKit.
Every new accessory inherits from Accessory class which has all the metadata required by HomeKit.
This accessories are useless without a logic, and here the Messages Delegates come into play. They handle and configures the MQTT channel messages and transforms the MQTT calls into events.
For example:
If you want create your own managed Temperature accessory, you will need create your own CustomMessageTemperatureDelegate class:
class CustomLightMessageDelegate : LightMessageDelegate
{
bool actualValue;
public CustomLightMessageDelegate (LightAccessory lightAccessory)
: base (lightAccessory)
{
}
public override void OnChangePower (bool value)
{
actualValue = value;
Console.WriteLine ($"[{Accessory.Name}][Set] " + value);
}
public override bool OnGetPower ()
{
return actualValue;
}
public override void OnIdentify ()
{
Console.WriteLine ($"[{Accessory.Name}] Identified.");
}
}
OnGetTemperature method includes the logic to calculate the temperature and returns the resulting value.
OnIdentify method is common to all delegates and is called every time HomeKit identifies the accessory.
As we said, our most important piece, has the logic to make all this things possible! It’s the responsible of:
- Run and manage a clean environment
- Keeps alive the current .net session with all the accessories
- Generates metadata necessary and runs an internal HAP-NodeJS process
- Establish MQTT connection with a Broker and communicate with a HAP-NodeJS endpoint
But we don't have to be worry about that… The Host is available in a nuget package you’ll only need create a simple Console Application and include it.
Session instantiation.
var session = new HapSession();
Configuring our session with Accessories and Message Delegates.
//Bridge accessory is mandatory
session.Add<BridgedCore, MessageBridgedCoreDelegate> ("Xamarin Net Bridge", "22:32:43:54:65:14");
//Adding an example of custom temperature accessory
session.Add<LightAccessory, CustomLightMessageDelegate> ("First Light", "AA:21:4D:87:66:78");
Starting the session
session.Start ([Your HAP-NodeJS full path], [Optional: Broker MQTT IP/host address for communication, default value is connect to localhost]);
As we talked before, this process will kill any other running process in memory, before start the session to be sure your port is not busy.
After this, we start loading and initializing all the Accessories and Delegates, also will clean and dynamically generates HAP-NodeJS metadata into it’s accessory folder.
This accessories in node-js files are prepared to create our MQTT bridge to propagate to our .net world all events received from HAP protocol and vice versa.
The console output will inform you about what’s happening and if something goes wrong. The host finishes session, closes communications and stops processes calling to Stop() method or Dispose.
Important: To restore correctly current submodules you will need clone this repository, it doesn't work if you download directly from zip file
You can do it from terminal using Git (or using your favorite git client):
git clone https://github.com/netonjm/HapSharp
Also to execute all scripts correctly, it's a requirement install node in your machine/device.
If you don't want to worry about this, we added an easy target in make script to do this magically..
make install-mac
This will install Brew and Node for you.
Not tested yet. But I supose, if your download from website the correct installer version to HAP-NodeJS will work.
We need volunteers here!
In progress...
sudo apt-get update
sudo apt-get install git-core libnss-mdns libavahi-compat-libdnssd-dev
xxxxxx with your architecture - check your rpi's docs)
wget https://nodejs.org/dist/latest-v7.x/node-v7.9.0-linux-xxxxxx.tar.gz
tar -xvf node-v7.9.0-linux-xxxxxx.tar.gz
cd node-v7.9.0-linux-xxxxxx.tar.gz
sudo cp -R * /usr/local/
cd ..
sudo npm config set registry http://registry.npmjs.org/
sudo npm install -g node-gyp
As we mention, HAP-NodeJS is executed in background, but first we need install and make sure it works.
make configure
Not tested yet. We need volunteers here
This target in Makefile script builds the solution and executes the broker instance and the generated HapSharp.Host.Console binary instance.
make run
Not tested yet. We need volunteers here
Open your home app in any IOS device with iOS 10+
- Select add new accessory
- Select the use a code option
- Select your net bridge in the accessory list detected
- Type the code of your bridge (by default is: 031-45-154)
- Configure each accessory in your desired room
- Enjoy your new .Net accessories!
MQTT protocol allows users publish/subscribe topics and send messages between themselves, it follows a star topology setup.
In our case, we are only to use this in a localhost scope to communicate HAP-NodeJS and HapSharp.
Because protocol specification, they need before run and connect a Broker installed in the localhost machine (or you will get an exception), this is because we recommend install Mosquitto Broker in your host machine, they provide a very easy installation and scripts to auto-execution on every reboot (Daemon).
Follow this easily guide to install it.
Another alternative is execute the Broker included in the solution (HapSharp.Host.Broker.exe). This is added to the host project and is compiled and generated every time you build the solution (the executable will be generated in HapSharp.Host.Console output directory)
You can easily execute the compiled broker executable with :
make broker
Or
mono HapSharp.Host.Console/bin/Debug/HapSharp.Host.Console.exe $(PWD)/HAP-NodeJS
After HAP-Sharp 0.41 version we added the feature of extensions points, and it allows read resources from external assemblies and resolve it for the file generation.
You only need create an empty library with the follow structure:
- Library
- template (folder) foo_accessory.js -> this is your js template, build as EmbeddedResource and be sure your resource id match with it.
- FooAccessory.cs -> based from Accessory based classes
- FooMesssageDelegate.cs based from MessageDelegates based classes
Generate your nuget and share with the community!!!!!
All host + accessories are published under NuGet.org
But maybe you want compile a not published version or a custom one… then try execute this script:
make package
This will generate all *.nupkg files and you will only need to create a local folder and include like a NuGet local source
- Issue executing 'make configure': fatal: Not a git repository (or any of the parent directories .git).
You downloaded the repository like a .zip file. You can't restore the git submodules if you don't do it using a git client
Follow the setup guide
- Exception in session.Start: "Exception connecting to the broker"
This is because you don't have running any broker session in background before executing your HAP session.
You will need execute in another terminal the Broker project included in the solution or install any other famous Broker like a service, for example in Mac or Linux Mosquitto works very well.
You have detailed in broker section how to do it
- Your port is bussy with some instance of HAP-NodeJS zombie
Show processes using the current port:
sudo lsof -iTCP:51826 -sTCP:LISTEN
-
Extra logging
var session = new HapSession() { Debug = True };
https://www.apple.com/ios/home/accessories/
This is a link of the protocol specification:
https://developer.apple.com/homekit/specification/
IoTSharp.Components: https://github.com/netonjm/IoTSharp.Components Using an abstraction library to access IoT Components in your Raspberry using Raspbian/AndroidThings.