-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ikea Tradfri - Client Put is not working after a period of time #43
Comments
A couple of questions.
My first guess is either a) a router is dropping the path from the table so the DTLS connection is no longer getting to the device on the same IP address pair or b) the gateway is dropping the DTLS connection after a period of inactivity. I have not see this when playing with things, but have not tried to do long lived connections. |
|
After sleeping on things, if you are running IPv6 it is possible that you have privacy mode where an automatic address change is done every so often. |
I have checked the Firmware of my tradfri Gateway (it is currently 1.2.42). It says "newest version". The code i've written is near by your example. <- and it already works :) |
I don't know if you can, but putting a wireshark monitor on the same subnet as the gateway would probably give good information as well |
this is a good idea. Imho, the the best way to get this specific traffic is to install a transparent bridge between the Raspberry and the ethernet switch. This gives the opportunity to wireshark on the bridge interface. An other option is to monitor the swich ports itself, but I do not have such infrastructure at home. |
One shot, one hit... my application is now running for about 20 hours on the new ethernet switch. and voila... it seems to work. I'll report if it passes the next days too. |
@bmachuletz I'm looking to do the same thing. Sort of a .net library which would communicate with TradFri gateway. I have a problem with dtls - I haven't found any example of how the package request should look. Can you help with the handshake, how to send the sn and secret to the gateway in coap request? |
This is my code fort he connect:
public TradfriClient()
{
keepAliveTimer = new System.Timers.Timer(60000);
keepAliveTimer.Elapsed += KeepAliveTimer_Elapsed;
keepAliveTimer.Start();
try
{
userKey = new OneKey();
DeviceList = new List<TradfriDevice>();
userKey.Add(CoseKeyKeys.KeyType, GeneralValues.KeyType_Octet);
userKey.Add(CoseKeyParameterKeys.Octet_k, CBORObject.FromObject(Encoding.UTF8.GetBytes("XRgp1htdDiVkBQCV")));
// userKey.Add(CoseKeyKeys.KeyIdentifier, CBORObject.FromObject(Encoding.UTF8.GetBytes("HomeMagic")));
// userKey.Add(CoseKeyKeys.KeyIdentifier, CBORObject.FromObject(Encoding.UTF8.GetBytes("user name")));
ep = new DTLSClientEndPoint(userKey);
client = new CoapClient(new Uri("coaps://GW-DCEFCAB82B4F"))
{
EndPoint = ep
};
ep.Start();
IEnumerable<WebLink> resources = client.Discover();
foreach (var resource in resources)
{
foreach (string s in HomeMagic.Shared.StringHelper.GetMatches(resource.ToString(), "<", ">"))
{
client.UriPath = s;
Response response = client.Get();
Console.WriteLine(response.PayloadString);
try
{
TradfriDevice dev = Newtonsoft.Json.JsonConvert.DeserializeObject<TradfriDevice>(response.PayloadString);
if (dev != null)
{
if (dev.Id >= 65537
&& dev.TradfriDeviceName != "TRADFRI group" && dev.TradfriDeviceName != "RELAX"
&& dev.TradfriDeviceName != "FOCUS" && dev.TradfriDeviceName != "EVERYDAY")
{
dev.Path = s;
DeviceList.Add(dev);
}
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message.ToString());
// nothing
}
}
}
// ep.Stop();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message.ToString());
}
}
And this is how I am sending requests tot he gateway:
private void SwitchOnDevice(TradfriDevice dev)
{
BesureEndpointIsConnected();
Console.WriteLine("Versuche das Gerät einzuschalten.");
if (dev.IsTradfriGroup == true)
{
foreach (long currentId in dev.GroupDefinition.DeviceList.DevicesIds)
{
var tradfriDevice = (from d in DeviceList
where d.Id == currentId
select d).SingleOrDefault();
SwitchOnDevice(tradfriDevice);
}
}
else
{
client.UriPath = dev.Path;
client.Put(@"{ ""3311"":[{ ""5850"":1}]}");
}
// ep.Stop();
}
hope this helps a bit..
Greetz, Benjamin
Von: tomidix [mailto:[email protected]]
Gesendet: Samstag, 25. November 2017 16:12
An: Com-AugustCellars/CoAP-CSharp <[email protected]>
Cc: bmachuletz <[email protected]>; Mention <[email protected]>
Betreff: Re: [Com-AugustCellars/CoAP-CSharp] Ikea Tradfri - Client Put is not working after a period of time (#43)
@bmachuletz <https://github.com/bmachuletz> I'm looking to do the same thing. Sort of a .net library which would communicate with TradFri gateway. I have a problem with dtls - I haven't found any example of how the package request should look. Can you help with the handshake, how to send the sn and secret to the gateway in coap request?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub <#43 (comment)> , or mute the thread <https://github.com/notifications/unsubscribe-auth/Af2Myb-qC1hMa_DscEgTi1S6EcCAGgvBks5s6C5YgaJpZM4QnSoC> . <https://github.com/notifications/beacon/Af2MyZ0CCbRch_mV6hRAtiU2-OIKmemrks5s6C5YgaJpZM4QnSoC.gif>
|
@bmachuletz I have copied your code and finally managed to get some info back.. could you share your Tradfri device class, as I am unsure how you are using json serialiser to get the data ? Thanks David |
@bmachuletz First of all I want to thank you. I managed to connect successfully to tradfri gateway using your sample code. @davidwallis3101 you can use these python classes to get an idea about whats happening in the background - https://github.com/ggravlingen/pytradfri/tree/master/pytradfri |
I'm happy to share the repo I have - I am trying to make this a class library dll that I can then consume in the home automation system that I am using (also in c#) |
Hi David,
i have generated this class with json2csharp.com. Hope it helps… I’ll share my code on github after some houskeeping 😊
using System;
using System.Collections.Generic;
using Newtonsoft.Json;
using HomeMagic.Shared;
namespace HomeMagic.Tradfri
{
public partial class TradfriDevice : Device
{
public bool IsTradfriGroup = false;
private GroupDefinition internalGroupDefinition;
public string Path { get; set; }
[JsonProperty("9001")]
public string TradfriDeviceName { get; set; }
[JsonProperty("3311")]
public TradfriLamp[] TradfriLamp { get; set; }
[JsonProperty("3")]
public DeviceInformation Information { get; set; }
[JsonProperty("5750")]
public long Unknown5750 { get; set; }
[JsonProperty("9003")]
public long Id { get; set; }
[JsonProperty("9020")]
public long Lastseen { get; set; }
[JsonProperty("9002")]
public long CreatedAt { get; set; }
[JsonProperty("9019")]
public long ReachableState { get; set; }
[JsonProperty("9054")]
public long OtaUpdatState { get; set; }
[JsonProperty("9018")]
public GroupDefinition GroupDefinition { get { return internalGroupDefinition; } set { IsTradfriGroup = true; internalGroupDefinition = value; } }
}
public partial class TradfriLamp
{
[JsonProperty("5851")]
public long Brightness { get; set; }
[JsonProperty("5850")]
public long State { get; set; }
[JsonProperty("9003")]
public long Id { get; set; }
}
public partial class DeviceInformation
{
[JsonProperty("1")]
public string Type { get; set; }
[JsonProperty("3")]
public string Version { get; set; }
[JsonProperty("0")]
public string Vendor { get; set; }
[JsonProperty("2")]
public string Unknown2 { get; set; }
[JsonProperty("6")]
public long Unknown6 { get; set; }
}
public partial class GroupDefinition
{
[JsonProperty("15002")]
public DeviceList DeviceList { get; set; }
}
public partial class DeviceList
{
[JsonProperty("9003")]
public List<long> DevicesIds { get; set; }
}
public partial class TradfriDevice
{
public static TradfriDevice FromJson(string json)
{
return JsonConvert.DeserializeObject<TradfriDevice>(json, Converter.Settings);
}
}
public static class Serialize
{
public static string ToJson(this TradfriDevice self)
{
return JsonConvert.SerializeObject(self, Converter.Settings);
}
}
public class Converter
{
public static readonly JsonSerializerSettings Settings = new JsonSerializerSettings
{
MetadataPropertyHandling = MetadataPropertyHandling.Ignore,
DateParseHandling = DateParseHandling.None,
};
}
// public TradfriDevice()
// {
// }
}
Greetz,
Benjamin
Von: David Wallis [mailto:[email protected]]
Gesendet: Montag, 27. November 2017 22:56
An: Com-AugustCellars/CoAP-CSharp <[email protected]>
Cc: bmachuletz <[email protected]>; Mention <[email protected]>
Betreff: Re: [Com-AugustCellars/CoAP-CSharp] Ikea Tradfri - Client Put is not working after a period of time (#43)
@bmachuletz <https://github.com/bmachuletz> I have copied your code and finally managed to get some info back.. could you share your Tradfri device class, as I am unsure how you are using json serialiser to get the data ?
Thanks
David
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub <#43 (comment)> , or mute the thread <https://github.com/notifications/unsubscribe-auth/Af2MyfwB_HRcTmDh7oeM3c6qtvUhDL4pks5s6y_-gaJpZM4QnSoC> . <https://github.com/notifications/beacon/Af2MyWUIR4ry_20Vh34Xf2Z-7aL6tsKyks5s6y_-gaJpZM4QnSoC.gif>
|
I am also happy to share code with you. As soon my code is ready to go public I will share it on github.
Did anyone get the subscription to the events working so far?
Greetz,
Benjamin
Outlook for Android herunterladen
On Tue, Nov 28, 2017 at 10:55 AM +0100, "David Wallis" <[email protected]> wrote:
I'm happy to share the repo I have - I am trying to make this a class library dll that I can then consume in the home automation system that I am using (also in c#)
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or mute the thread.
|
@bmachuletz P.S. I also used json2csharp although the visual studio has the same possibility, LOL |
interesting! I might need a lower framework version as mine is used on a Rpi under mono.. but shouldnt be an issue.. had a quick play and looks good.. I did not know you could do a JSON property like that hence why I couldn't get my head around how to do the class and mapping 👍 Just working out a way of storing the encryption key without commiting it to github then I'll mark my repo as public too :) Then will look to add some unit tests too |
@bmachuletz , @davidwallis3101 |
Thanks, happy to help where I can |
incidently I now have your code working here and changing the bulb brightness, can you do the colour temp for the white bulbs? |
Very nice work. Currently I am porting my Alexa smart home Skill from v2 to v3. After that I will check your code more in depth. I have to backport it to .net 4.5 to replace my code with yours in order to get it work with mono on my raspberry.
Outlook for Android herunterladen
On Wed, Nov 29, 2017 at 10:53 PM +0100, "David Wallis" <[email protected]> wrote:
incidently I now have your code working here and changing the bulb brightness, can you do the colour temp for the white bulbs?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or mute the thread.
|
@bmachuletz Ok, no problem take your time. Regarding backporting, I think we can do all that on my solution, I just started with the default (.net 4.7) and it worked straight away so I didn't mess with it.. I need it on a normal pc so I didn't bothered, but I don't have anything against using .net 4.5 and adding rpi support along with that. @both |
I can make the colour temp changes with the app and remote so must be possible, just need to see how.. will make a test app that polls the bulb to test if I can see any param's change, if not I will see if I can get wireshark to sniff and decode dtls encypted coap as people have said it is possible |
@davidwallis3101 @bmachuletz Do you maybe have an example code of eventListener (observer).. I've implemented color changes, moods, etc but I need eventListener to complete the feature branch and to merge it into the master.. Also there is a nuget available for you to use now, and it will be built automatically on very completed pull request to master.. https://www.nuget.org/packages/Tomidix.CSharpTradFriLibrary/ |
@bmachuletz I try your code to connect to my gateway but it didn't work when I use IEnumerable resources = client.Discover(); |
Hi Hydro8,
I dont't know you are doing wrong. As far as I know from the past I could break my code if I changed the order the commands. Please be sure that your Code has the same order.
Outlook for Android herunterladen
On Sun, Jan 14, 2018 at 8:53 PM +0100, "Hydro8" <[email protected]> wrote:
@bmachuletz I try your code to connect to my gateway but it didn't work when I use IEnumerable resources = client.Discover();
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or mute the thread.
|
Hi,
i am using this library to control IKEA Tradfri lamps. But after period of time the connection to my gateway seems to be broken. After restart of my application all is running fine. Maybe anyone has a good starting point to look at for investigating the problem?
Thanx
Benjamin
The text was updated successfully, but these errors were encountered: