Licenses¶
SDK EULA¶
MICROEJ SDK is licensed under the SDK End User License Agreement (EULA). The following figure shows a detailed view of the elements.
License Manager Overview¶
Architectures are distributed in two different versions:
- Evaluation Architectures, associated with a software license key. They can be downloaded at https://repository.microej.com/modules/com/microej/architecture/.
- Production Architectures, associated with a hardware license key stored on a USB dongle. They can be requested to our support team.
The license manager is provided with Architectures and then integrated into VEE Ports.
License Check¶
The table below summarizes where the license is checked.
Application | Run on Simulator (Virtual Device) | Build on Device | Documentation Link |
Application containing a Java main class | NO | YES | Run on Device |
Application containing a Feature class | NO | NO | Application Linking |
SDK EULA Acceptation¶
The use of MICROEJ SDK 6 requires to accept the SDK EULA. If the license is not accepted, the following message is displayed when executing a Gradle task:
> The MICROEJ SDK End-User License Agreement (EULA) must be accepted before it can start.
The license terms for this product can be downloaded from
https://repository.microej.com/licenses/sdk/LAW-0011-LCS-MicroEJ_SDK-EULA-v3.1B.txt
You can accept the EULA by specifying the -Daccept-microej-sdk-eula-v3-1b=YES command line option,
or setting the system property systemProp.accept-microej-sdk-eula-v3-1b=YES in a gradle.properties file,
or setting the ACCEPT_MICROEJ_SDK_EULA_V3_1B=YES environment variable.
As mentioned in the message, there are several ways to accept the EULA:
define the
accept-microej-sdk-eula-v3-1b
system property in the command line:./gradlew build -Daccept-microej-sdk-eula-v3-1b=YES
define the
accept-microej-sdk-eula-v3-1b
system property in agradle.properties
file with thesystemProp.
prefix:systemProp.accept-microej-sdk-eula-v3-1b=YES
This can be in the
gradle.properties
of your Gradle User Home folder (located by default at$USER_HOME/.gradle/gradle.properties
), or in thegradle.properties
file at the root of your project for example.set the
ACCEPT_MICROEJ_SDK_EULA_V3_1B
environment variable toYES
.
Evaluation Licenses¶
This section should be considered when using Evaluation Architectures, which use software license keys. A machine UID needs to be provided to activate an Evaluation license on the MicroEJ Licenses Server. The machine UID is a 16 hexadecimal digits number.
Get your Machine UID¶
If your VEE Port is defined in the build.gradle.kts
of your project,
the machine UID will be displayed when building an Executable.
[INFO ] Launching in Evaluation mode. Your UID is XXXXXXXXXXXXXXXX.
[ERROR] Invalid license check (No license found).
Request your Activation Key¶
- Go to MicroEJ Licenses Server https://license.microej.com.
- Click on Create a new account link.
- Create your account with a valid email address. You will receive a confirmation email a few minutes after. Click on the confirmation link in the email and log in with your new account.
- Click on Activate a License.
- Set Product P/N: to
9PEVNLDBU6IJ
. - Set UID: to the machine UID you copied before.
- Click on Activate.
- The license is being activated. You should receive your activation by email in less than 5 minutes. If not, please contact our support team.
- Once received by email, save the attached zip file that contains your activation key.
Install the License Key¶
The license key zip file must be simply dropped to the ~/.microej/licenses/
directory (create it if it doesn’t exist).
Production Licenses¶
This section should be considered when using Production Architectures, which use hardware license keys stored on a USB dongle.
Note
If your USB dongle has been provided to you by your sales representative and you don’t have received an activation certificate by email, it may be a pre-activated dongle. Then you can skip the activation steps and directly jump to the Check Activation section.
Request your Activation Key¶
- Go to license.microej.com.
- Click on Create a new account link.
- Create your account with a valid email address. You will receive a confirmation email a few minutes after. Click on the confirmation link in the email and login with your new account.
- Click on Activate a License.
- Set Product P/N: to The P/N on the activation certificate.
- Enter your UID: serial number printed on the USB dongle label (8 alphanumeric char.).
- Click on Activate and check the confirmation message.
- Click on Confirm your registration.
- Enter the Registration Code provided on the activation certificate.
- Click on Submit.
- Your Activation Key will be sent to you by email as soon as it is available (12 business hours max.).
Note
You can check the My Products page to verify your product registration status, the Activation Key availability, and download the Activation Key when available.
Once the Activation Key is available, download and save the Activation Key ZIP file to a local directory.
Activate your USB Dongle¶
This section contains instructions that will allow you to flash your USB dongle with the proper activation key.
You shall ensure that the following prerequisites are met :
- Your operating system is Windows
- The USB dongle is plugged and recognized by your operating system (see Troubleshooting section)
- No more than one USB dongle is plugged into the computer while running the update tool
- The update tool is not launched from a network drive or a USB key
- The activation key you downloaded is the one for the dongle UID on the sticker attached to the dongle (each activation key is tied to the unique hardware ID of the dongle).
You can then proceed to the USB dongle update:
Unzip the
Activation Key
file to a local directoryEnter the directory just created by your ZIP extraction tool.
Launch the executable program.
Accept running the unsigned software if requested (Windows 10/11)
Click on the Update button (no password needed)
On success, an
Update successfully
message shall appear. On failure, anError key or no proper rockey
message may appear.
Check Activation¶
This section contains instructions that will allow you to verify that your USB dongle has been properly activated.
To get more details on connected USB dongle(s), run the debug tool as following:
Open a terminal.
Change directory to a Production VEE Port.
Execute the command:
java -Djava.library.path=resources/os/[OS_NAME] -jar licenseManager/licenseManagerUsbDongle.jar
with
OS_NAME
set toWindows64
for Windows OS,Linux64
for Linux OS,Mac
for macOS x86_64 (Intel chip) orMacA64
for macOS aarch64 (M1 chip).
If your USB dongle has been properly activated, you should get the following output:
[DEBUG] ===== MicroEJ Dongle Debug Tool ===== [DEBUG] => Detected dongle UID: XXXXXXXX. [DEBUG] => Dongle UID has valid MicroEJ data: XXXXXXXX (only the first one is listed). [DEBUG] => Detected MicroEJ License XXXXX-XXXXX-XXXXX-XXXXX - valid until YYYY-MM-DD. [DEBUG] ===== SUCCESS =====
USB Dongle on GNU/Linux¶
For GNU/Linux Users (Ubuntu at least), by default, the dongle access has not been granted to the user, you have to modify udev rules.
Please create a /etc/udev/rules.d/91-usbdongle.rules
file with the following contents:
ACTION!="add", GOTO="usbdongle_end"
SUBSYSTEM=="usb", GOTO="usbdongle_start"
SUBSYSTEMS=="usb", GOTO="usbdongle_start"
GOTO="usbdongle_end"
LABEL="usbdongle_start"
ATTRS{idVendor}=="096e" , ATTRS{idProduct}=="0006" , MODE="0666"
LABEL="usbdongle_end"
Then, restart udev: sudo /etc/init.d/udev restart
You can check that the device is recognized by running the lsusb
command.
The output of the command should contain a line similar to the one below for each dongle:
Bus 002 Device 003: ID 096e:0006 Feitian Technologies, Inc.
USB Dongle with Docker on Linux¶
If you use the SDK Docker image on a Linux host to build an Executable,
the dongle must be mapped to the Docker container.
First, it requires to add a symlink on the dongle by following the instructions of the USB Dongle on GNU/Linux section but
with this /etc/udev/rules.d/91-usbdongle.rules
file:
ACTION!="add", GOTO="usbdongle_end"
SUBSYSTEM=="usb", GOTO="usbdongle_start"
SUBSYSTEMS=="usb", GOTO="usbdongle_start"
GOTO="usbdongle_end"
LABEL="usbdongle_start"
ATTRS{idVendor}=="096e" , ATTRS{idProduct}=="0006" , MODE="0666" , SYMLINK+="microej_dongle"
LABEL="usbdongle_end"
Then the symlink has to be mapped in the Docker container by adding the following option in the Docker container creation command line:
--device /dev/microej_dongle:/dev/bus/usb/999/microej_dongle
The /dev/microej_dongle
symlink can be mapped to any device path as long as it is in /dev/bus/usb
.
USB Dongle with WSL¶
Note
The following steps have been tested on WSL2 with Ubuntu 22.04.2 LTS.
To use a USB dongle with WSL, you first need to install usbipd following the steps described in Microsoft WSL documentation:
First, check that WSL2 is installed on your system. If not, install it or update it following Microsoft Documentation
Then, you need install usbipd-win on Windows from usbipd-win Github repository.
And then, install usbipd and update hardware database inside you WSL installation:
sudo apt install linux-tools-generic hwdata sudo update-alternatives --install /usr/local/bin/usbip usbip /usr/lib/linux-tools/*-generic/usbip 20
Add the udev rule described in USB Dongle on GNU/Linux, and restart udev:
/etc/init.d/udev restart
You then need to unplug and plug your dongle again before attaching the dongle to WSL from powershell:
usbipd.exe wsl attach --busid <BUSID>
The <BUSID>
can be obtainted with the following powershell command:
usbipd wsl list
Note
You’ll need to follow these steps each time you system is rebooted or the dongle is plugged/unplugged.
Troubleshooting¶
This section contains instructions to check that your operating system correctly recognizes your USB dongle.
Windows Troubleshooting¶
If the dongle activation failed with
No rockey
message, check there is one and only one dongle recognized with the following hardware ID :HID\VID_096E&PID_0006&REV_0201
Go to the Device Manager > Human Interface Devices and check among the USB Input Device entries that the Details > Hardware Ids property match the ID mentioned before.
If the dongle activation was successful with
Update successfully
message but the license does not appear in the SDK or is not updated, try to activate again by starting the executable with administrator privileges:If the following error message is thrown when building an Executable, either the dongle plugged is a verbatim dongle or it has not been successfully activated:
Invalid license check (Dongle found is not compatible).
VirtualBox Troubleshooting¶
In a VirtualBox virtual machine, USB drives must be enabled to be recognized correctly. Make sure to enable the USB dongle by clicking on it in the VirtualBox menu Devices > USB.
To make this setting persistent, go to Devices > USB > USB Settings… and add the USB dongle in the USB Devices Filters list.
WSL Troubleshooting¶
Check that your dongle is attached to WSL from Powershell:
usbipd wsl list
You should have a line saying Attached - Ubuntu
:
PS C:\Users\sdkuser> usbipd.exe wsl list BUSID VID:PID DEVICE STATE 2-1 096e:0006 USB Input Device Attached - Ubuntu 2-6 0c45:6a10 Integrated Webcam Not attached 2-10 8087:0026 Intel(R) Wireless Bluetooth(R) Not attached 3-1 045e:0823 USB Input Device Not attached 3-4 046d:c31c USB Input Device Not attached
In you WSL console, the dongle must also be recognized. Ckeck by using lsusb`
:
skduser@host:~/workspaces/docs$ lsusb Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub Bus 001 Device 003: ID 096e:0006 Feitian Technologies, Inc. HID Dongle (for OEMs - manufacturer string is "OEM") Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
This might not be sufficient. If you’re still facing license issues, restart udev, abd attach your dongle to WSL once again.
Note
Hibernation may have unattached your dongle. Reload udev, unplug/plug your dongle and attach it from powershell.
Remote USB Dongle Connection¶
When the dongle cannot be physically plugged to the machine running the SDK (cloud builds, virtualization, missing permissions, …), it can be configured using USB redirection over IP network.
There are many hardware and software solutions available on the market. Among others, this has been tested with https://www.net-usb.com/ and https://www.virtualhere.com/. Please contact our support team for more details.