Tips How to change the color of a Fibaro Wall Plug using Z-Wave PC Controller

I have been searching for an easy way to change the color of my Fibaro Wall Plugs without coding/scripting/configuring anything... The solution is to use the "Z-Wave PC Controller" from Sigma on a Windows PC!

Click to Read More

I have the Fibaro FGWPef-102, documented here. As per that documentation, to set the color of the plug when it's ON or OFF, one has to send the color code to respectively the parameter 41 or 42 (a parameter of size 1 byte):

Here is how to do it with Z-Wave PC Controller (version 5 here under). Run the application on your PC, once the controller is plugged into it (I am using a Sigma ACC-UZB3). Click on the gear icon to select the port of your controller and click "OK".


  1. Select a node representing one of your Fibaro Wall Plugs in the top left frame and press Enter (or click the "Node Info" button) to fetch the available commands
  2. Select the Command Class "CONFIGURATION" in the bottom left frame 
  3. Select the Command "CONFIGURATION_SET" to set a new value
  4. Set the Parameter Number to 41 or 42 as documented above. Set the Size to 1 and the Configuration Value to the desired color. Ex.: 08 for Cyan.
  5. Click on Send

To be sure it works, look the color of your Wall Plugs :D 

Or, you can now

  1. Select the Command "CONFIGURATION_GET" to read the value
  2. Put 41 or 42 as Parameter Number
  3. Open the Log file to see the output which will be returned by the Command
  4. Click on Send. You should see in the log a Configuration report with the value set previously. Here "08" (Cyan)


"Z-wave PC Controller" is available inside the free "Simplicity Studio" of SiLabs, as explained here. You only have to subscribe to get it ! (As an alternative, if you have already an SiLabs account, click here to download it directly). The user manual is available here.

Et voilà.

Tips How to identify the Philips Hue sensors in OpenHab ?

When looking at the Things within OpenHab, each "Hue Motion Sensor" device appears as multiple things: the "Motion sensor xyz" itself but also a "Hue ambient light sensor i" and a "Hue temperature sensor i". "Motion sensor xyz" is the name you gave to the device via the Philips Hue App and "i" is a sequential id which can't be easily linked to the related "Motion sensor" device... The App Hue Essentials can help you !

Click to Read More

On the screenshot bellow, one can see that I have renamed the Motion Sensors into "Motion sensor Door" and "Motion sensors Entry", within the Philips Hue App. NB.: Only the Motion sensors appears in the Philips Hue App. One doesn't see the Temperature and Ambient Light sensors...

In OpenHab, we see all the sensors, but the Ambient Light and Temperature sensors are not named accordingly to the related Motion sensors. Instead, the are named "Hue ambient light sensor i" and a "Hue temperature sensor i" and one has no idea which one is part of the "Motion sensor Door" or "Motion sensor Entry":


The App Hue Essentials is not free but is really great (opposite to Philips Hue, you can for example control devices from multiples Bridges without switching from one to the other all the time). It's the first App I found, made for end users (and not for developers), which give access to the internal sensors of a selected device. I.e.: the other Apps list all the sensors but does not tell which sensors belongs to which device.

One way to identify which sensor belongs to which device is to go to the Devices (1) within the App Hue Essentials, select the device (2).

Next , select, the menu Details (1 then 2):

In these details, you see the Identifier of the device. Here, the identifier is 13. 

Back into OpenHab, you can now filter the list of Things on ':13' and find the device. 

That was quite useless as the name of the device is the same in OpenHab and Philips Hue... but you can see that, obviously, the "Unique ID" displayed in Hue Essentials (00:17:88:01:06:44:42:35) is not the full id displayed (0107:ecb5fa857069)..

One can do the same to find the id of the other sensors of this device: instead of the menu "Details", select now the menu "Temperature" or "Light Level". One can see immediatly the name of the related sensor (Here under "Hue light sensor 1"). One can also take the menu "Detail" (1) to take note of the identifier (here under "14") to filter for it in OpenHab's Things list.

The best is however to rename these sensors according to their device (The "Hue light sensor 1" could be renamed "Hue light sensor Door"), remove all of them (especially the "Motion Sensors" which were properly named otherwise,  the other sensors won't be re-detected) and rescan for Hue's Things in OpenHab.

Et voilà.

Raspberry Pi Install Z-Stick & ConBee II on RPI/Openhabian

Here is how to configure properly an Aeotec Z-Stick Gen5 and a Conbee II stick on a RPI 4 installed with Openhabian (running OpenHab 3)

Click to Read More

First, be sure that openhabian can access the serial ports. The easiest is to configure that via openhabian-config > System Settings > Serial Port:

sudo openhabian-config 

You can also do it with raspi-config > Interfacing Options > Serial :

sudo apt-get install raspi-config
sudo raspi-config

> Would you like a login shell accessible over serial? → No
> Would you like the serial port hardware to be enabled? → Yes


Next, check that the sticks are well plugged with the command:


You should see something like

Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub
Bus 001 Device 011: ID 1cf1:0030 Dresden Elektronik ZigBee gateway [ConBee II]
Bus 001 Device 005: ID 0658:0200 Sigma Designs, Inc. Aeotec Z-Stick Gen5 (ZW090) - UZB
Bus 001 Device 002: ID 2109:3431 VIA Labs, Inc. Hub
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub

In order to always have the USB sticks mounted on the same "port", instead of being assigned once on /dev/ttyACM0, once on /dev/ttyACM1, ... create a UDEV Rule file:

sudo nano /etc/udev/rules.d/99-usb-serial.rules

Type the following, using the ID of the USB sticks found above, in this file:

SUBSYSTEM=="tty", ATTRS{idVendor}=="0658", ATTRS{idProduct}=="0200", SYMLINK+="ttyUSB-ZWave", GROUP="dialout", MODE="0666"
SUBSYSTEM=="tty", ATTRS{idVendor}=="1cf1", ATTRS{idProduct}=="0030", SYMLINK+="ttyUSB-ZigBee", GROUP="dialout", MODE="0666"

If you didn't prepare openhabian for ZigBee via sudo openhabian-config > System Settings > Serial Port, grant the following access for openhab :

sudo adduser openhab dialout
sudo adduser openhab tty

Now, reboot (sudo reboot) and test if symlink was created with the command :

ls /dev/tty*

You should see


Add edit openhab config file to add the symlinks to the PATH variable for Java (NB: for openhab 2, the file is namge openhab2 !!):

sudo nano /etc/default/openhab

Search the line with EXTRA_JAVE_OPTS and modify accordingly to complete the parameter '':

EXTRA_JAVA_OPTS="-Xms192m -Xmx320m"

Now, reboot again (sudo reboot) and install Phoscon, the application to manage the ZigBee devices. The easiest is to install it (on port 8081 as recommended) via openhabian-config > Optional Components > deCONZ:

sudo openhabian-config

You can also look here on the phoscon website for a manual setup

If you have a RPI 4B, also update the WiringPI like this:

cd /tmp
sudo dpkg -i wiringpi-latest.deb

You can now open phoscon to login and search for ZigBee devices on http://<your RPI IP>:8081

If after a reboot, this UI is not available, then enable manually the service:

sudo systemctl enable deconz

If you want to change the port of Phoscon, edit the parameter 'http-port' in this file:

sudo nano /lib/systemd/system/deconz.service


Finally, install the following addons (Bindings) in OpenHab :

  • "Dresden Elektronik deCONZ Binding"
  • "Z-Wave Binding"

The ConBee gateway will be detected automatically by OpenHab and appear twice in the 'Inbox': once as Deconz and once as Hue (indeed, it emulates a Philips Hue Bridge). If it was not detected automatically, open the Phoscon UI > Gateway > Advanced (Gear Icon at the bottom of the page) and CLick on "Authenticat App". Then add the Thing manually into OpenHab using the Scan button of:

OpenHab UI > Administration > Parameters > Things > + (Add Thing) > Dresden Elektronik deCONZ Binding


The Zwave gateway will only appear if you add it explicitly into OpenHab:

OpenHab UI > Administration > Parameters > Things > + (Add Thing) > Z-Wave Binding > Z-Wave Serial Controller

In the field Serial Port, type manually '/dev/ttyUSB-ZWave' (without the quotes) and click 'Create Thing'

Wait for about 10 seconds and the gateway will soon become online.

Et voilà.

Raspberry Pi RPI 4/Openhabian into an Argon One Case


If you installed Openhabian onto an RPI hosted into an Argon Once Case, here is how to configure the Argon One.

Click to Read More

Install the scripts to manage to Argon One's features:

sudo curl | bash

Configure the fan cooler, for example depending on the temperature, with the command:

sudo argonone-config

Select the option 2 and type 10 for 55 °C, 55 for 60 °C and 100 for 65 °C, meaning that the fan speed will by 10% at 55 °C, etc...


In order to configure the Argon One to turn on automatically after a power failure, you have first to enable the i2C. The easiest is to do it with the raspi-config command, which can be installed with:

sudo apt-get install raspi-config

Then run it:

sudo raspi-config

And go to the menu "Interface option", and select the entry "I2C" to enable the loading of the I2C kernel module.

Now you can check that it works with the command:

i2cdetect -y 1

And finally set the Power-On feature with the command:

i2cset -y 1 0x01a 0xfe


Now, you can press the power button of the Argon One :

  • twice to reboot
  • +3 sec to shutdown and power off
  • +5 sec to force the shutdown


Et voilà

Tips Use Android Tablet as additionnel screen

A Galaxy Tab S7 can be used out-of-the-box as second screen for a Windows 10 laptop or PC connected on the same Wifi. But what about using this tablet as additionnel screen for a PC connect via ethernet ? The solution is SuperDisplay. And it works for most Android Tablets...

Click to Read More

You won't be able to connect your Galaxy Tablet S7 as second screen with your windows PC, as explained here, if this one is not connected via Wifi. 

It's a pitty as using a tablet with a pen to do photo editing for example is really great.

The solution is simply to use an alternative "wireless display" solution such as "SuperDisplay"; install the App on your tablet and the related drivers on your PC, et voilà !

Tips EdgeRouter X - Speed limited to 250Mbps instead of 1Gbps

I have upgraded my Internet abonnement from 100Mbps to 1000Mbps but couldn't get more than 250Mbps. The reason was not an issue with the fiber or the modem but a limitation on my EdgeRouter X.

Click to Read More

I bought this Ubiquiti router to have the capability to view the bandwidth on each port as well as to fine-tune the configuration if required. Its OS "EdgeMAX" is indeed very flexible and powerful. Obviously, I did check that it was capable to deliver 1Gbps. 

It was clear for me that it would be "1Gbps for all ports" (4 ports). But as the Router is connected on a Switch "1Gbps per port", that was not an issue for my LAN (And it was much cheaper).

Nevertheless, having max 250Mbps was disappointing.


This throughput was reached with defaults settings, as I didn't fine tune anything so far.

The solution was to disable the "hardware offload" as well as the "flow-accounting (NetFlow)" (NB.: QoS may also not be used, but it was the case).

To disable these features, click on 'CLI' in the upper-right corner to open a console and login with your administrator account. Then type:

set system offload hwnat enable
delete system flow-accounting

Once the router as completed the reboot, you get the maximum bandwidth !

Et voilà.

Tips PC Windows 10 is very slow although CPU, RAM, GPU and Disk usage is low

There are many many reasons why a PC can be lagging and very slow. But the worst was is when you look at the Task Manager and you see that both CPU and GPU are low, there are still plenty of free RAM and there is no high disk activity. In my case the problem was due to CPU Frequency being reduced.

Click to Read More

First thing to check, the CPU/GPU/Ram and Disk Usage. Press CTRL-SHIFT-ESC to open the Task Manager.

You see that everything is low. So what ?

Run now the Resource Monitor by pressing Windows-R and typing: resmon

Very interesting. We see that the CPU runs at 19% of its maximum Frequency. So, something has reduced the CPU frequency. Indeed, with Intel speedstep, power saving and everything else disabled, this should always read 100%.

So, the problem can be the "power plan" or some "failed" overclocking...

You can test this by adding some load on the CPU with "CPU Grab" or "CPU Stres". Here under, using CPU Grab to load the CPU at 100%, we can see that the CPU is still limited to ~20%:

NB.: You can also give a try to Intel® Extreme Tuning Utility

Regarding SpeedStep and Power Saving, you can edit your Power Plan Option. Press Windows-R and enter: powercfg.cpl, then click "Change plan settings" > "Change advanced power settings". Set all limits to 100%.

NB.: For laptop, there are distinct settings "On Battery" or "Plugged in"...

NB.: Keep the "System cooling policy" on "Active" to avoid your PV to burn :)

If this does not help, then give a try to Throttle Stop (Basically, uncheck the BD PROCHOT checkbox an click Save)


Possibly, disable manually the Intel Processor Power Management feature (ippm). Run a cmd prompt as Administrator and execute this command before restarting your PC :

sc config intelppm start=disabled

NB.: To to re-enable "intelppm", execute the command

sc config intelppm start=demand

Possible values are : {boot | system | auto | demand | disabled | delayed-auto}.


Also look here for disabling DPTF ( "Intel(R) Dynamic Platform and Thermal Framework"). Windows has it's own built-in processor speed and thermal management already, which is sufficient on its own.

Update the drivers of your Processor, pressing Windows-R and typing: devmgmt.msc


Check the settings in your Bios. If you have an option "CPU Power Management" set on "ENABLED", Windows will ignore the minimum CPU power setting and clock down to the default frequency but clock up when required. If you have an option "Intel Speed Step Technology" set on "DISABLED" at the same time, the maximum frequency will be that of what it is advertised for your CPU, instead of maximum turbo boost.

Finally, you can also check your RAM just in case, by pressing Windows+R then and typing in mdsched.exe. Then restart the PC.

Finally, you should have solved the maximum Frequency:

NB.: here above, my CPU been overclocked, you see more than 100% CPU available

SynologyTips How to download playlists from YouTube using Synology

It's really easy to download playlists from YouTube with the Download Station of Synology. I do this to get locally new "No Copyright Music's", to be used later within my video's.

Click to Read More

I am using the "Download Station" as it simply works, opposite to many free or paid software's which pretend to work but usually fail (and are full of advertisements...)

Bref... Assume that you want to get all the free music's from the excellent YouTube Channel "VLOG No Copyright":

  • Visit their "PLAYLISTS" in your Browser (All such channels have a tab "PLAYLISTS" as you can see in the screenshot bellow).
  • Right-click on the link "VIEW FULL PLAYLIST" of the desired playlist.
    • This is important: don't use any URL from the "HOME" tab or from any tail representing a playlist (with the "PLAY ALL"). It would only download one video and not all the playlist. 
  • Select the menu "Copy link address"
    • The copied url should be like this : ""


Now, go to your "Synology Download Station" and:

  • Click on the large blue sign "+". It opens a window to create new download tasks.
  • Go to the tab "Enter URL".
  • Paste there the URL of the playlist copied previously.
    • A subfolder with the name of the playlist will automatically  be created under the destination folder and the video will be saved in that subfolder
  • Select the option "Show Dialog to select..." if you when to download only some of the video's. Otherwise you can unselect that option.
  • Click "Ok".


You should now see a line as illustrated here below, "waiting" to start:


You have to wait until the Download Station has crawled across the whole playlist and found all the files to be downloaded... Then, you will see the list of music's:


During the download, you could see some failed tasks, with a status "Error". It happens from time to time, but this is usually a temporary issue. Sort the list within the Download Station on the "Status" column and select all the "Error" . Then, right-click the list and select the menu "Resume".


Personally, as soon as the "music video's" are downloaded, I extract the sound tracks and keep only those. There are many software to do this. But one of my favorite option is to use ffmpeg directly on the Synology (you have to install that package). Simply type this command in a console, in the download path were are saved the video's: 

for i in *.mp4; do ffmpeg -i "$i" -codec:a libmp3lame -q:a 0 -map a "${i%.*}.mp3"; done

To process mp4 in all subfolders in the download path, I use the command:

for d in *; do cd "$PWD/$d/"; for i in *.mp4; do ffmpeg -i "$i" -codec:a libmp3lame -q:a 0 -map a "${i%.*}.mp3"; done; cd ..; done


If you are using Chrome, I can suggest some extensions to help in downloading Playlists..

1. The extension "Copy Selected Links". Using that one, you can copy the URL's of all the playlists of a Channel, at once. Select the whole text under the tab PLAYLISTS (it will then appear highlighted in blue as illustrated on the screenshot here under). Next, right-click in an empty area and select the menu "Copy selected Links".

Now go into Notepad++, as we have to keep only the playlists. Paste the Clipboard into a new tab of Notepad++. Press CTRL-Home to come back to the top. Press CTRL-H to open the "Replace" window. Select "Regular Expression" at the bottom of that window and click the "Replace All" button once you have entered this into the field "Find What":  .*watch.*\n (or .*watch.*\r\n if it does not work properly)

Now, you have two options. If you have no more than 50 playlists, you can paste them directly into the Download Station via the button "+" and the tab "Enter URL" as explained previously. Otherwise, you have to save with all your URL's into a .txt file (with Notepad++) and upload that file via the tab "Open a file" instead of the tab "Enter URL". 


2. The extension "Download Station" (or this version in Chrome Web Store) to more easily download the playlists. Same principle as above, but instead of right-clicking "View Full PlayList" to copy the playlist URL, you now have a extra menu "Synology download Station" (or Download with "Download Station").


Another trick, when available in the PLAYLISTS tab of a Channel: select and download the Playlists "Sorted by Mood" or "Sorted by Genre". This will help you when you search for a particular type of music for your video. Ex.: with the Channel "Audio Library":


Adive: each time you add a playlist in the Download Station, check that the amount of new download tasks match with the amount of tracks in the playlist. Indeed, it happens that not all the video's are added into the Download Station as it has limits(a total of max 2048 download tasks <= reason why you have to clean-up all downloaded tasks before downloading new long playlists. There is also a limit of 256 links per "file" uploaded and a limit for a playlist of "2048 - amount of current download tasks").

Don't forget that for most "No Copyright Music's", you have to mention the author in your video's or posts. Often, in YouTube, you have to click on "Show More" under the video to see the details of the license:

The License is usually clear. Ex.:

To find again later the video's on YouTube and check the type of license, it's important to keep:

  • The original name of the video when converting into mp3
  • The name of the playlist
  • The name of the channel

To do so, the easiest is to add some metadata into the mp3 extracted with ffmpeg. Once downloaded by the "Download Station", your video's should be in subfolders which have the name of their playlists. And the filenames usually contain the Author, the name of the song and the name of the YouTube Channel. So, it's easy to create the metadata. Ex.: the playlist "Dance & Electronic Music | Vlog No Copyright Music" of Vlog has been downloaded into a subfolder named "Dance & Electronic Music _ Vlog No Copyright Music" and the video's are all named like "Artist- Title (Vlog No Copyright Music).mp4"

So, to process that subfolder, I will use the command:

for i in *.mp4; do playlist=${PWD##*/}; artist=${i% - *}; other=${i##* - }; title=${other% (Vlog*}; ffmpeg -i "$i" -codec:a libmp3lame -q:a 0 -map a -metadata artist="${artist}" -metadata title="${title}" -metadata album="Playlist: ${playlist}"  -metadata Publisher="From YouTube Channel: Vlog No Copyright" "${artist} - ${title}.mp3"; done

As you can see, I am using the "Publisher" to store the Channels and the "album" for the playlist... This is a personal choice! (More details on ID3 tags and ffmpeg here)

Regarding the pattern matching used in shell, it's not always that simple and you will have to be creative... Just about the pattern matching:

  • variable2=${variable1%xyz*} => variable2 is the shortest left part of variable1 before a substring xyz.
  • variable2=${variable1%%xyz*} => variable2 is the longest left part of variable1 before a substring xyz.
  • variable2=${variable1#*xyz} => variable2 is the shortest right part of variable1 after a substring xyz.
  • variable2=${variable1##*xyz} => variable2 is the longest right part of variable1 after a substring xyz.
  • in xyz, x and z may be blanks (in my case, "xyz" was " - ")

As there are many duplicates in those playlists, I have written my own script to replace such duplicates by hardlinks (on my Synology). I can't use jdupes or rmlint as those are doing "binary comparisons" and due to the conversion via ffmpeg, it doesn't work. Instead, I search for duplicates based on the filename and size only (per channel, they are usually unique anyway). Here is my script for illustration purpose. It must be stored in an ANSI file (ex.: and run with: sh go

echo "Start looking for duplicates"

find . -iname "*.mp3" -printf "%p ~ %f\n" | sort -f -k2 | uniq -Di -f1 > list.dup

echo "Duplicates found"

while read p; do
mp3name="${p#* ~ }"
mp3path="${p%% ~ *}"
if [[ "$mp3name" == "$previous" ]]; then
node=$(ls -l "$mp3path" | grep -Po '^.{11}\s1\s.*$')
if [[ "$node" == "" ]]; then
echo " $mp3path is already a hardlink"
if [[ "$test" == "go" || "$test" == "test" ]]; then
SIZE1=$(stat -c%s "$mp3path")
SIZE2=$(stat -c%s "$previouspath")
#Delta=$(awk "BEGIN{ printf \"%d\n\", sqrt((100 * ($SIZE2 - $SIZE1) / $SIZE1)^2)}")
#if [[ $Delta > 1 ]]; then
Delta=$(awk "BEGIN{ printf \"%d\n\", ($SIZE2 - $SIZE1)}")
if [[ "$Delta" == "0" ]]; then
mv "$mp3path" "$mp3new.old"
ln "$previouspath" "$mp3path"
echo " $mp3path now linked to original"
echo " $mp3path seems different from $previouspath"
echo " mv $mp3path $mp3new.old"
echo " ln $previouspath $mp3path"
if [[ "$test" != "test" ]] || [[ "$skip" = true ]]; then
echo "$mp3name has duplicate(s) (original in $mp3path)"
done <list.dup


Note: Facebook will possibly remove the audio from your video even if they is a "No Copyright Music". When you get such a notification from FB, you can simply click to restore the audio if you did mention the Author in your post or video.

Some YouTube Channels with "No Copyright Music's":


Tips How to download Adobe Pro X

I bought the version X which is now obsolete and would like to reinstall it using my license. Problem: I don't have the setup anymore... Where to download this version ?

Click to Read More

There is no link anymore on the web or on Adobe Web Site to download that version.

The trick:

  1. Log in into Adobe Web Site:
  2. Paste this url in your browser: 
  3. Run this web downloader and let it install Acrobat Pro 10

Some other obsolete stuff can be found on Adbe's FTP :


SmartHome How to create a recursive Timer in OpenHab3's DSL Rule

I wanted a DSL Script to send a notification email if a door was still opened after several checks.

There are various options to achieve this purpose.

Click to Read More

A simple option could have been to use a Switch Item with an Expire Property. When the door opens, set that Switch Item to 'ON' and initialize a Number Item to be count how many checks will be done. When the Switch Item expires, execute a script which checks if the door is still opened. If it is not, that script ends. Otherwise, it increases the Item Number. If that Item Number is lower than the maximum checks to be done (your threshold), Set back the Switch Item to 'ON'. Otherwise, send the notification email.

Another option (just for fun) relies on a DSL Script with a lamdba expression which creates a Timer calling itself recursively until the door is closed or your threshold is reached. That DLS Script must be called when the Door opens.

Here after a Number Item SensorGarageDoor_Duration is used to count the number of checks: The Item SensorGarageDoor_OpenClose is the state of the Sensor on the Door.

val int treshold = 3
var int attempt = 0

// Define a Lambda Expression to check if the Door is open and if not,
// call itself after 15 minutes to check again until a treshold of calls is reached
val Functions$Function1 Monitor = [	Functions$Function1 recursive |
	if (SensorGarageDoor_OpenClose.state == OPEN) {
		logInfo("default.rules", "Monitor Opened Door")
		createTimerWithArgument(now.plusMinutes(15), recursive, [ Functions$Function1 callMonitor |
				var int duration = (SensorGarageDoor_Duration.state as Number).intValue + 1
				logInfo("default.rules", "Garage Opened since " + duration.toString + " cycle(s)")
				if (duration == treshold) {
					logInfo("default.rules", "Notify by email that Garage still Opened after " + duration.toString + " cycles")
					val mailActions = getActions("mail", "your smtp binding")
					val success = mailActions.sendMail("your from", "your subject", "your message")
				} else if (duration < treshold) {
	} else {
		logInfo("default.rules", "Stop monitoring Door")
if (SensorGarageDoor_Duration.state != NULL) {
	attempt = (SensorGarageDoor_Duration.state as Number).intValue
} else {
	attempt = treshold

if (attempt >= treshold) {
	logInfo("default.rules", "Request for monitoring Opened Door")
} else {
	logInfo("default.rules", "New request for monitoring Opened Door ignored")

One of the trick is to pass the Lambda Expression as parameter to the Timer (Created with createTimerWithArgument). Indeed, a Timer may not call a "Global" Lambda Expression. To get a Lambda Expression as parameter, this parameter must be defined as Functions$FunctionX (where X is the amount of parameters of the Lambda Expression). In my sample above, my Lambda as one parameter which is itself, to be passed to the Trigger (So, it is typed Functions$Function1).

You must type explicitly the parameters as Functions$Function1 to be able to use the method "apply()".