Sunday, January 12, 2025

How to configure a Tuya compatible smart switch with Home Assistant

Prepare Raspberry Pi 4 with Home Assistant OS 

I used my Raspberry Pi 4 to install Home Assistant. The OS versions mentioned below may not be as yours. 

Use Raspberry Pi Imager to prepare the SD card. Select "Other specific-purpose OS" when you select the operation system and then select "Home assistants and home automation" and then "Home Assistant" and finally select "Home Assistant OS 14.1 (RPI 4/400)"






Log in to home assistant web portal when everything is ready.

Install HACS

Go to settings, click on Add-ons and then click on ADD-ON STORE button located in the right hand corner at the bottom. 



Then click on Repositories from the menu you get clicking on the three dots at top right hand corner.
Enter https://github.com/hacs/addons as the repository 


Then go back to settings, select Add-ons and click on 
ADD-ON STORE button. Then search for hacs. You will see the "Get HACS" repository. 


click on it and hit INSTALL button to get HACS installed. click on Start once the installation is done. 
Then restart Home Assistant. 

Once restarted, go to settings, click on Devices & Services.Click on ADD INTEGRATION button and search for HACS. select HACS and proceed with the instructions provided. once the github authorization is completed, HACS will be appeared in the Integrations list.



Open HACS by clicking on HACS in the left hand side menu. Since the default Local Tuya available with HACS was not working with protocol 3.5, I had to use a forked version of the original Local Tuya repository. Click on the 3 dots at top right hand side and select Custom Repositories.
 


Enter 
https://github.com/xZetsubou/localtuya as Repository and Integration as Type. Once that is added, the forked version of Local Tuya will be appeared in HACS. 


Install Tuya Local

Click on the three dots of the new Local Tuya appeared and hit Download.


Restart Home Assistant to complete the installation.

Configure Tuya Local

Go to Settings, select Devices & Services. Click on ADD INTEGRATION button and select Local Tuya. I didn't enter any details for Cloud API account configuration as I selected Disable Cloud API.
Now Local Tuya is appeared in the Integrations. 


 Click on Local Tuya and click Configure. Select Add new device. As it does not automatically detect the device, go ahead with Add Device Manually option. 

Notes: You need several information to proceed from here. However make sure you have configured your devices in your mobile app, either Smart Life or Tuya Smart.

1. Device ID

You can find out the Device ID from the application installed in your mobile (Smart Life or Tuya Smart).  Open the App, Select the device, click on the pencil icon at the top right hand corner and click on Device Information to find out the device ID. 


2. Local Key. 

You can find out the Local Key from https://auth.tuya.com/. Create an account there if you don't have a login already. 
Log in to Tuya account.  Click on Cloud and click on Create Cloud Project.



Make sure you select the correct Data Center. Otherwise it won't work. This document has the data center mapping. Select the data center based on the country you selected when you configured the mobile App. 
https://developer.tuya.com/en/docs/iot/oem-app-data-center-distributed?id=Kafi0ku9l07qb

In my case, it's Central Europe data center.


Then proceed with the default options provided.
Once the project is set up, go to Cloud again and Open the project. Select Devices and then Link App Account. Then click on Add App Account. A QR code will appear. 


Open your mobile App and scan it and confirm Login. Now the device(s) will be added to the project.



Open API Explorer from Cloud.

Expand Device Management and select Query Device Details. Enter the Device you found out in the step 1 and hit Submit Request button. 



It will provide a JSON response. You should be able to find the value for local_key in the JSON.

Now you have the Device ID and Local Key to proceed. Make sure to add a scan interval, otherwise the information will not get updated in Home Assistant portal. 



Once Submit, another window will appear. Select Configure device entities manually. Choose entity as Switch and proceed. To proceed further you need to know about DP IDs. You can find out the DP IDs from https://auth.tuya.com portal. 

Make sure you select Smart Home Basic Service and expand Smart Home Device Control section. Select Get Device Specification Attribute. Then enter your device ID and hit Submit Request button. 
A JSON response will appear with the DP ID mapping. This will be useful when the device is added to Home Assistant. 


I configured below values for the smart plug,



The device will be appeared in Local Tuya now,





Prepare a Dashboard

To plot the current, power utilization and voltage, I have added those attributes as entities. 
Go to Local Tuya, select Configure and select Reconfigure existing device.


Select Add new entity(s)


Select Sensor for the entity. Repeat the same for Power and Voltage. 









Saturday, February 15, 2020

High CPU utilization just after display sleep in Hackintosh

I noticed that after a few seconds the monitors went sleep, the CPU utilization and iGPU utilization of my hackintosh went significantly high. This was clearly noticed in the Intel Power Gadget as well,




I kept a terminal session open redirecting the output of top command in terminal (top -o cpu > bla.txt). From the output I was able to find out that mediaanalysisd process was utilizing the CPU and iGPU.

After unloading mediaanalysisd, the issue went away.

Uload command I used,
launchctl unload -w /System/Library/LaunchAgents/com.apple.mediaanalysisd.plist

Monday, February 10, 2020

Restore Google Chrome and Firefox Bookmarks from a backup

I had an issue with my Hackintosh, so that it wouldn't boot anymore. However I was able to mount the disk of the machine to another newly built Hackintosh which helped me to access the files of the troubled Hackintosh.

First I plugged the disk to the new Hackintosh

For Google Chrome,


1. Navigate to below location of the disk,

/Volumes/<volume name> - Data/Users/<username>/Library/Application Support/Google/Chrome/Default

2. There should be two Bookmark files in the directory:'Bookmarks' and 'Bookmarks.bak'

3. Check the latest by executing diff command

4. Copy the latest to below location of your new machine

/Users/<username>/Library/Application Support/Google/Chrome/Default


For Firefox,


1. Navigate to below location of the disk,

/Volumes/<volume name> - Data/Users/<username>/Library/Application Support/Firefox/Profiles/wzghbr3j.default/bookmarkbackups


2. There should be multiple files in the directory.
e.g.:

bookmarks-2020-02-08_744_<some-encoded-values>.jsonlz4
bookmarks-2020-02-09_744_<some-encoded-values>.jsonlz4


3. Pick the latest file and copy it to the desktop


4. Open Firefox, Select Bookmark and then Show All BookMarks


5. Click on Restore and then select choose file


6. Select the file from the Desktop

How to disable parsec-fbf which prevents Catalina Sleep functionality

1. Execute below command to find out which processes block sleep,

pmset -g assertions

2. Execute below command to disable parsec-fbf

launchctl unload -w /System/Library/LaunchAgents/com.apple.parsec-fbf.plist

Tuesday, December 25, 2018

ext4 ext4lazyinit

Today I formatted a 3TB hard disk and mounted it with default options. However after mounting it I noticed that it periodically writes about 2 MB data. Initially I thought it was some journal information writing for the files I copied to the disk, but this 2MB data writing was not stopped when I mounted the disk after removing the journal.

Therefore I installed iotop to see what's going on. Aha, I was able to find the culprit immediately.
It was a process called ext4lazyinit.

Apparently when a partition is formatted with ext4, it does not initialize all inode tables in the file system during the file system creation time in order to speed up the process.  When the new file system is mounted, it starts ext4lazyinit process to initialize the inode tables leisurely.
Needless to say, it's really annoying to hear the sound of the disk is being accessed in every second indefinitely.

After searching about this ext4lazyinit process, I found out that all the inode tables can be initialized  passing lazy_itable_init=0 with the -E option when the  filesystem is created. Since I have already copied some files to the disk, I didn't want to reformat it. Therefore I followed another mechanism described in the articles I read. That is mount the partition with init_itable=0 mount option. This will speed up the inode table initialization. (https://www.kernel.org/doc/Documentation/filesystems/ext4.txt)