@jhlink You can also likely interface with him & the code directly on github.
Thanks @dougM!! Iāll be sure shoot him an email!!
@ericso, Iām actually working a lot with AWS. If you need some help, give me a holler.
The API Gateway is actually quite nice to access most if not all of the AWS features.
@josec, The Red Flash of Death⦠an embedded systems developerās worst nightmareā¦
Iāve got a photon, and despite it having a huge amount of memory, itās running out of memory.
Iām going to try and get on this tonight to see if thereās any way to recycle previously used memory.
Iāve found that the library induces āSOSā mode.
Currently, Iāve posted the issue on the Github repo [here].
If thereās anyone that can lend a helping hand or any useful advice in debugging this, please do post!!
Iād love to hear any kind of input!
Iām going to try my best digging through this!
Thanks for making this.
@michaelT / @josec, Iāve been playing with this for a while and canāt figure out how to just make a GET request and output the response/body of the response. The timeapi example is good and I can see the response body when debugging but canāt figure out how to actually output that myself.
Any examples?
Thanks
Thanks for that info @jhlink, Iām starting to look at AWS API gateway as well as a front gate into Lambda and like the UX so far. Are there any tips or tech resources that you can give for hooking up from Particle cloud to API gateway to Lambda?
Can I PM you for more info?
The link doesn't go anywhere.
Sorry!!
Hereās the full link!
Hey @MarkyD,
The biggest problem isnāt AWS, but rather https protocols for Particle.
The HTTPS Client library unfortunately isnāt able to handle this reliably, and it does require a bit of debugging.
The best way Iāve found to handle data requests (POST/GET/etc) is through Particle webhooks. The Itās great because you can make https calls very easily, but it sucks because you have a very limited number of requests/webhooks per minute. (Unless of course you email Particle directly to raise the limits of these requests/webhooks for a certain cost.)
Go ahead and PM me if you have any more questions!!
James
Thanks @jhlink!
@markyd, @jhlink, @dougM, @bryceadams, @ericso, @fbt
Sorry about my hiatus. Just wanted to check in to see if there is still any interest for the library. I made a small tweak that should avoid the RED blinking LED 
The main reason this happens is when the request reply timeout occurs. This basically causes all the MatrixSSL buffers to be re-allocated. This can be prevented by implementing some sort of an algorithm to allocate within a single memory pool to prevent the overrun. But obviously, itās a lot more work and is going to take up some time.
@jhlink I donāt think the https protocols are being handled unreliably per se. It does what itās intended to for the examples that are in there. Let me know if you got to spend any more time with the library by chance. I am curious to hear, and maybe solve a problem or two.
If I hear back from here, I intend to set a small roadmap and see where we go from there.
jersey99
@jersey99
I think thereās immense interest for the library. AWS especially ties in really nicely with scalable IoT tech, but requires at the very minimum HTTPS, assuming youāre using API Gateway. (You could try making direct requests with AWS services, but that involves some crazy complex implementation of their authentication protocol.)
I tried looking into debugging the problem myself, but I got lost in the immense amount of MatrixSSL code. (The goto statements are especially confusing.)
The Photon has HTTPS protocol in its firmware documentation, but it actually goes through Particle Cloud before reaching a web endpoint, which sounds great but thatās until you read about the webhook, request, and host limits. For hobbyists, not really that big of a problem, but it is a bit of an obstacle if you have larger demands per Photon device.
I sort of gave up debugging this library, so I thought of developing a more lean HTTPS library using a different TLS/SSL library instead of MatrixSSL, like NanoSSL, PolarSSL, or maybe Cyassl. But this is a project way down the road. Iāve had to switch to the Arduino Yunās due to project deadlines and such.
yes! ⦠
Yes, totally! The SAP HANA Cloud Platform (HCP) requires HTTPS connections (if you try HTTP, you get redirected to HTTPS), and since getting stuff into HCP is my day job, itās quite important to me.
Thanks for your efforts!!!
I really like PolarSSL.
@Butch  @jhlink @fbt
If possible can we have quick list of problems you having with using httpsclient-particle? So that we prioritize?
Thanks!
Sure!!
ā Memory⦠Problems?
The biggest problem is the frequent red SOS lights. If I donāt receive any response, this light appears. Now, the photon does reset automatically and executes the sketch again, but the same error repeats. A cycle results, really.
I think increasing the timeout is a good solution, but I donāt think it solves the underlying problem. There could still be future SOSās that could occur.
@jersey99, thanks for the correction! Youāre right! HTTPS protocols are being handled correctly; itās really just an issue of memory allocation.
The best fix, I think, would be to shift from dynamic to static memory usage, or rather dynamic restricted to a pool of statically allocated memory. However, this is such a challenge.
The code is a bit⦠wild to debug. Maybe some refactoring or code optimization could be considered?
Some other thoughtsā¦
ā Reducing the code base. I really think that the library could be a lot smaller. TLS/SSL is critical, of course, but something very intensive like 4096 RSA is a bit overkill. If anything, I think a separate branch just for HTTPS related code would be ideal. There would be a smaller code footprint with lots of room for other cool things like more libraries, maybe a song or picture or two for the YOLO inclined. Or if anything, moving all the high level cryptographic functions to a new library entirely and call it āCryptography-Particle.ā
In list formā¦
- Reducing code footprint
- A little bit of code refactoring. (Getting rid of nightmarish go-to statements, specifically.)
- Moving from dynamic memory allocation to using only statically allocated memory and proper constraints, checks, and safeguards for it.
I need to run in an āinsecureā mode where it will ignore certificate warnings for the url Iām hitting. Is this an option buried somewhere that I canāt find?
Hey dougM, Iām not sure if this might be possible.
If you need to run in an āinsecureā mode, could you try and use HTTP instead?
Those arenāt the same thing. I need to use HTTPS but need an exception for the cert. Basically āNET::ERR_CERT_AUTHORITY_INVALIDā is the error Iām trying to work around be the cert is for xxx.domain.com but I have to access it via 192.168.1.1. so it becomes invalid.
Hi @jersey99 ,
any progress on the red flashing interdeath of things ?
Iām also having the same issue. First time request -> response goes ok -> but keeps on until timeout and next time i get the
matrixSslNewClientSession:-10
New Client Session Failed: Exiting
And then red sos + 1 blink which is told to be a hard fault by the manual.