Note! The following instruction is dedicated for the second generation HTTP Gate module!
The following instruction for integration with Tedee lock is based on the information provided on:
https://tedee-tedee-api-doc.readthedocs-hosted.com/en/latest/index.html.
To integrate Grenton system with Tedee lock, please follow the steps described below:
1. Create following User features on Gate_HTTP.
data:image/s3,"s3://crabby-images/add05/add055af1c8e6273ff76785cec97ea984b5476dc" alt=""
Note! The value of the tedee_lock_sn feature is the serial number of your lock. This information is available in the dedicated application: My devices-> Door Lock -> Lock -> Settings -> Information.
2. Create a HttpRequest virtual object.
data:image/s3,"s3://crabby-images/d1ae3/d1ae3a48848bd62b1c0baf9cb6655ce8cf8cf802" alt=""
3. Set the TedeeLock_AuthorizationKey virtual object’s properties as follows. This configuration allows retrieving basic information about the lock (i.a. access key).
data:image/s3,"s3://crabby-images/adc09/adc09db9ae7dcc753ccf354c00c76f94630aedc3" alt=""
Where:
Host: https://tedee.b2clogin.com
Path: /tedee.onmicrosoft.com/B2C_1_SignIn_Ropc/oauth2/v2.0/token
QueryStringParams: \z
4. Create a Tedee_AuthorizationKey_req script.
data:image/s3,"s3://crabby-images/13733/1373309494cc26454355320e57d184e0640be321" alt=""
Note! The username (MAIL) and password (PASSWORD) must be replaced with the data used to log in to the dedicated application (according to URL encoding).
Note! The @ sign in the email address should be replaced by %40.
local get_key = {"&grant_type=password&client_id=02106b82-0524-4fd3-ac57-af774f340979&scope=openid+02106b82-0524-4fd3-ac57-af774f340979&response_type=token&username=MAIL&password=PASSWORD"}
Gate_HTTP->TedeeLock_AuthorizationKey->SetRequestBody(get_key)
Gate_HTTP->TedeeLock_AuthorizationKey->SendRequest()
5. Create a Tedee_AuthorizationKey_resp script.
data:image/s3,"s3://crabby-images/8de73/8de7388dd25698688b73a663613b1dc46e599d4d" alt=""
if(Gate_HTTP->TedeeLock_AuthorizationKey->StatusCode==200) then
local resp = Gate_HTTP->TedeeLock_AuthorizationKey->ResponseBody
Gate_HTTP->tedee_access_token = resp.access_token
Gate_HTTP->tedee_token_type = resp.token_type
Gate_HTTP->tedee_token_expires = resp.expires_in
end
6. Assign this script to OnResponse event of the TedeeLock_AuthorizationKey virtual object.
data:image/s3,"s3://crabby-images/1ba5e/1ba5e4324b0466af2571b09c42e2086637edb68d" alt=""
7. Send the configuration to CLU and run the Tedee_AuthorizationKey_req script. User features will take appropriate values.
data:image/s3,"s3://crabby-images/221c0/221c08b5fdb47459a239c9a8e4bd06cd6d118b9a" alt=""
8. Create a HttpRequest virtual object - TedeeLock_DeviceID – which allows retrieving the lock’s ID.
data:image/s3,"s3://crabby-images/b9355/b9355a07786ef2044e842727b54859d9b4cb9467" alt=""
Where:
Host: https://api.tedee.com
Path: /api/v1.15/my/lock
QueryStringParams: \z
9. Create a Tedee_DeviceID_req script.
data:image/s3,"s3://crabby-images/9742f/9742f438a2397654e2d54d66aa9f31ac266f36ee" alt=""
local key = "Authorization: Bearer " .. Gate_HTTP->tedee_access_token .. "\r\n"
Gate_HTTP->TedeeLock_DeviceID->SetRequestHeaders(key)
Gate_HTTP->TedeeLock_DeviceID->SendRequest()
10. Create a Tedee_DeviceID_resp script.
data:image/s3,"s3://crabby-images/36731/36731238396a2b79b94c89b08508cbaef6a88042" alt=""
if(Gate_HTTP->TedeeLock_DeviceID->StatusCode==200) then
local resp = Gate_HTTP->TedeeLock_DeviceID->ResponseBody
Gate_HTTP->tedee_lock_sn_get=resp.result[num].serialNumber
if(Gate_HTTP->tedee_lock_sn==Gate_HTTP->tedee_lock_sn_get) then
Gate_HTTP->tedee_lock_id = resp.result[num].id
else
Gate_HTTP->Tedee_DeviceID_resp(num+1)
end
end
Where num feature is a parameter of this script.
Note! One Bridge and one Tedee lock were used in the example shown.
11. Assign Tedee_DeviceID_resp script with num parameter equal 1 to OnResponse event of the TedeeLock_DeviceID virtual object.
data:image/s3,"s3://crabby-images/f33e3/f33e309997fbfa13ff7aa032275d48a3b9713457" alt=""
12. Send the configuration to CLU and run the Tedee_AuthorizationKey_req and Tedee_DeviceID_req scripts. User features will take appropriate values.
data:image/s3,"s3://crabby-images/b00c8/b00c8f360f0f867bd45a6bb2a615e4d6168b0188" alt=""
13. Create a HttpRequest virtual object - TedeeLock_LockID – which allows retrieving information about the lock (i.a. lock battery level).
data:image/s3,"s3://crabby-images/01d80/01d80e587fe50056365f424b903a6d3f9ca20773" alt=""
Where:
Host: https://api.tedee.com
Path: /api/v1.15/my/lock/
QueryStringParams: \z
14. Create a Tedee_LockID_req script.
data:image/s3,"s3://crabby-images/3f142/3f14240aa2bbe2bfa42c8a1db90a4c52ca4a34c3" alt=""
local path_1 = "/api/v1.15/my/lock/" .. Gate_HTTP->tedee_lock_id .. "/sync"
Gate_HTTP->TedeeLock_LockID->SetPath(path_1)
local key = "Authorization: Bearer " .. Gate_HTTP->tedee_access_token .. "\r\n"
Gate_HTTP->TedeeLock_LockID->SetRequestHeaders(key)
Gate_HTTP->TedeeLock_LockID->SendRequest()
15. Create a Tedee_LockID_resp script.
data:image/s3,"s3://crabby-images/b43c7/b43c79e485a32610acb25fa8ea5e08c754f54693" alt=""
if(Gate_HTTP->TedeeLock_LockID->StatusCode==200) then
local resp = Gate_HTTP->TedeeLock_LockID->ResponseBody
Gate_HTTP->tedee_lock_state = resp.result.lockProperties.state
Gate_HTTP->tedee_lock_charging = resp.result.lockProperties.isCharging
Gate_HTTP->tedee_lock_battery = resp.result.lockProperties.batteryLevel
end
16. Assign this script to OnResponse event of the TedeeLock_ LockID virtual object.
data:image/s3,"s3://crabby-images/9eec7/9eec724a5cecb6bbd6f5cb6036c8a576ba29f2be" alt=""
17. Send the configuration to CLU and run the Tedee_AuthorizationKey_req and Tedee_DeviceID_req and Tedee_LockID_req scripts. User features will take appropriate values.
data:image/s3,"s3://crabby-images/56d20/56d20d0ad71e4b9dd9d6e0436739ba158f12f792" alt=""
18. Create a HttpRequest virtual object - TedeeLock_Open – which allows to open the lock.
data:image/s3,"s3://crabby-images/fb4e3/fb4e3ac5cfb8c0f6d7e09d88761a98cfd0fda4ac" alt=""
Where:
Host: https://api.tedee.com
Path: /api/v1.15/my/lock/open
QueryStringParams: \z
19. Create a Tedee_ Open_req script. After sending configuration to CLU, this script will open the lock.
data:image/s3,"s3://crabby-images/e80ef/e80efc69b471c1fdecd3a29bf439f00cf07c0f69" alt=""
local body_1 = {deviceId = Gate_HTTP->tedee_lock_id}
Gate_HTTP->TedeeLock_Open->SetRequestBody(body_1)
local key = "Authorization: Bearer " .. Gate_HTTP->tedee_access_token .. "\r\n"
Gate_HTTP->TedeeLock_Open->SetRequestHeaders(key)
Gate_HTTP->TedeeLock_Open->SendRequest()
20. Create a HttpRequest virtual object - TedeeLock_Close – which allows to close the lock.
data:image/s3,"s3://crabby-images/3ca69/3ca693cd63baa2e893ade7ec3e48d4260d3e4fe0" alt=""
Where:
Host: https://api.tedee.com
Path: /api/v1.15/my/lock/close
QueryStringParams: \z
21. Create a Tedee_Close_req script. After sending configuration to CLU, this script will lock the lock.
data:image/s3,"s3://crabby-images/83742/837427976bcc87a2d7f1812d5a8790cefc68709d" alt=""
local body_1 = {deviceId = Gate_HTTP->tedee_lock_id}
Gate_HTTP->TedeeLock_Close->SetRequestBody(body_1)
local key = "Authorization: Bearer " .. Gate_HTTP->tedee_access_token .. "\r\n"
Gate_HTTP->TedeeLock_Close->SetRequestHeaders(key)
Gate_HTTP->TedeeLock_Close->SendRequest()
22. Create a HttpRequest virtual object - TedeeLock_ PullSpring – which allows to pull the spring.
data:image/s3,"s3://crabby-images/9f3c9/9f3c9266716667c3c336bcdf2f77b1455f2cd547" alt=""
Where:
Host: https://api.tedee.com
Path: /api/v1.15/my/lock/pull-spring
QueryStringParams: \z
23. Create a Tedee_ PullSpring_req script. After sending configuration to CLU, this script will pull the spring.
data:image/s3,"s3://crabby-images/912d1/912d1e5620ab9e1df96a9cb33a2d07203185d77d" alt=""
local body_1 = {deviceId = Gate_HTTP->tedee_lock_id}
Gate_HTTP->TedeeLock_PullSpring->SetRequestBody(body_1)
local key = "Authorization: Bearer " .. Gate_HTTP->tedee_access_token .. "\r\n"
Gate_HTTP->TedeeLock_PullSpring->SetRequestHeaders(key)
Gate_HTTP->TedeeLock_PullSpring->SendRequest()
24. At the end, the call of Tedee_AuthorizationKey_req script assign to OnInit event on Gate_HTTP.
data:image/s3,"s3://crabby-images/803fe/803fe80446a8307424aa4325fa3c239c212ca866" alt=""
Note! The token expires after defined time (tedee_token_expires user feature), thus the Tedee_AuthorizationKey_req script requires to be called cyclically, for example by using a Calendar virtual object.
25. The call of Tedee_DeviceID_req script add in Tedee_AuthorizationKey_resp script.
data:image/s3,"s3://crabby-images/e3465/e346531b58f0f018d64482a2605acc13c91515d3" alt=""
26. The call of Tedee_LockID_req script add in Tedee_DeviceID_resp script.
data:image/s3,"s3://crabby-images/19dbb/19dbbbd1e690bd8f36bc92be6159169e5e51cfc7" alt=""
27. The configuration prepared in that way, send to Gate_HTTP module.
The way to control a Tedee lock using the myGrenton app is presented in the following article: Control with Tedee Lock.
data:image/s3,"s3://crabby-images/8cec8/8cec8eb1046cc1a6be67105aa63b173e7bdc7299" alt=""