LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Using HTTP GET to display data from a cloud platform to LabVIEW via API key

Solved!
Go to solution

I am acquiring data using the BOSCH XDK110 sensor and sending the collected data over MQTT to an IoT platform (https://akenza.io/). I want to now display the data onto LabVIEW from (https://akenza.io/).

 

I am using HTTP GET method but unsure how to use the API with the header to display the data. 

 

I cant find any examples that use HTTP GET with an API. The examples are directed for HTTP GET basics.  - I have tried the basic examples to display data to LabVIEW by connecting to platforms that require no further inputs other than a URL. 

 

Has anyone managed to achieve something similar?

- Open to suggestions on how to retrieve the data (if there are other easier methods)

- Hoping for any example .vi's

 

Any advice towards achieving this is much appreciated 

Download All
0 Kudos
Message 1 of 7
(2,359 Views)

You are not setting the header correctly, check this edited version. You should probably create a new API key.

0 Kudos
Message 2 of 7
(2,327 Views)

Thank you for tour response. 

 

Unfortunately, this does not work either. I have tried this with a newly generated API

 

jephin27_0-1683105921584.png

 

0 Kudos
Message 3 of 7
(2,285 Views)

Ah, sorry, I should have paid more attentions to your error message, I just got an "unauthorized" message.

 

Have you seen this KB article: Error 363507 When Using the HTTP Client API in LabVIEW? I see that you are on LabVIEW 2015. Your certificates are probably outdated. You can either disable server verification, add the certificate to your ca store or update the ca store. This post has more details: https://lavag.org/topic/16601-labview-could-not-verify-the-authenticity-of-the-server/?do=findCommen...

 

My remark about the api key was because if you do not want others to access the data, you must revoke the api keys.

0 Kudos
Message 4 of 7
(2,278 Views)

Yes I am using 2015. I have worked around this by using a newer version from a different PC but would like to get this resolved on the 2015 version. 

 

- I tried to disable verification. This does not work either.

- what I would ideally like to do is 'update the ca store' as mentioned, however following the steps I have found I am not able to complete this. The links attached are what I tried to use:

 

https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z0000019P6VSAU&l=en-GB

https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z0000019YHDSA2&l=en-GB

 

This is where i am having the issues when following these steps:

 

4.Enter the following commands to generate an RSA self-signed certificate:

  1. openssl x509 -req -in mydevice.csr -out mydevice.crt -CA testcacert.pem - Cakey privkey.pem -Cacreateserial
  2. openssl genrsa -out privkey.pem 1024 

 

 

- with regards to the API key, yes I will revoke the key.

0 Kudos
Message 5 of 7
(2,244 Views)
Solution
Accepted by jephin27

That does not apply in this case, since you are not connecting to a server for which you have a private key.

 

Since api.akenza.io uses a Let's Encrypt certificate, you should be able to download the ISRG Root X1 certificate from https://letsencrypt.org/certificates/ and point ConfigSSL.vi to that CA certificate file. You can also append the contents of that file to your ca-bundle.crt.

 

Edit: You may also want to look at this site on how to get an update version of the ca bundle: https://curl.se/docs/caextract.html

 

Custom CA file with ConfigSSL.png

0 Kudos
Message 6 of 7
(2,237 Views)

In my experience just updating the CA bundle is sometimes not enough. That NI HTTPS Client library uses under the hood a NI build of libcurl and that then uses an NI Build of OpenSSL. 

This is actually necessary since both projects and especially OpenSSL do not only not guarantee ABI compatibility, but very regularly break it.

 

The OpenSSL version used in the ni-OpenSSL 2015 library is however at best at version 1.0.2 but more likely 1.0.1, since 1.0.2 was released in January 2015. That is a very ancient version for an SSL implementation and most modern web servers will not really care to try to support it, freely after the motto: if it works it works, if it doesn’t it’s really the webclients problem!

 

Now there is a solution for this by installing a newer version of these components. The binary libraries are actually a shared component between National Instruments software products. Installing a new version of LabVIEW will actually make other versions of LabVIEW use those components too. If you have some installation of a newer LabVIEW Professional version laying around somewhere, you can relatively easily create a mini installer for these components by creating a project and in there an installer that selects the according NI Curl and NI Open SSL components as additional installs. I had very good results for an application build in LabVIEW 2013 that used those components from LabVIEW  2020 to communicate with REST servers that were secured with fairly recent SSL protocol settings.

Rolf Kalbermatter
My Blog
0 Kudos
Message 7 of 7
(2,206 Views)