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.

SDK Detailed View

SDK Detailed View

License Manager Overview

Architectures are distributed in two different versions:

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.1C.txt
  You can accept the EULA by setting the system property systemProp.accept-microej-sdk-eula-v3-1c=YES in a gradle.properties file
        - in your Gradle User Home folder ($USER_HOME/.gradle/),
        - or in the root folder of your project,
  or specifying the -Daccept-microej-sdk-eula-v3-1c=YES command line option,
  or setting the ACCEPT_MICROEJ_SDK_EULA_V3_1C=YES environment variable.

As mentioned in the message, there are several ways to accept the EULA:

  • define the accept-microej-sdk-eula-v3-1c system property in a gradle.properties file with the systemProp. prefix:

    systemProp.accept-microej-sdk-eula-v3-1c=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 the gradle.properties file at the root of your project for example.

  • define the accept-microej-sdk-eula-v3-1c system property in the command line:

    ./gradlew build -Daccept-microej-sdk-eula-v3-1c=YES
    
  • set the ACCEPT_MICROEJ_SDK_EULA_V3_1C environment variable to YES.

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).

MicroEJ Shared Licenses Directory

MicroEJ Shared Licenses Directory

Check Activation

This section contains instructions that will allow you to verify that your Evaluation license has been properly installed.

Note

The command line tool requires Architecture 8.3.0 or higher.

To get more details on installed Evaluation licenses, proceed with the following steps:

  1. Open a terminal.

  2. Change directory to an Evaluation VEE Port.

  3. Execute the command:

    java -Djava.library.path=resources/os/[OS_NAME] -jar licenseManager/licenseManagerKeyHardware.jar
    

    with OS_NAME set to Windows64 for Windows OS, Linux64 for Linux OS, Mac for macOS x86_64 (Intel chip) or MacA64 for macOS aarch64 (M1 chip).

    You should get something similar to the following output:

    [DEBUG] ===== MicroEJ Evaluation License Debug Tool =====
    [DEBUG] => UID: 39B7C108972A5C36.
    [DEBUG] => Please specify a license directory containing 'keysHardware.txt'
    

    This step is sufficient if you want to check the machine’s UID. For an analysis of the available licenses, proceed with the following steps.

  4. Build your Executable with verbose mode enabled.

  5. Retrieve in the logs the path to the licenses directory by searching for -Dlicenses.working.dir=[path_to_license_dir].

  6. Execute the same command than before with the path to the licenses directory as argument:

    java -Djava.library.path=resources/os/[OS_NAME] -jar licenseManager/licenseManagerKeyHardware.jar [path_to_license_dir]
    

    You should get something similar to the following output:

    [DEBUG] ===== MicroEJ Evaluation License Debug Tool =====
    [DEBUG] => UID: 39B7C108972A5C36.
    [DEBUG] => Detected MicroEJ License HQB48-VCQDQ-I7QDL-IAZUF - valid until YYYY-MM-DD.
    [DEBUG] ===== SUCCESS =====
    

    Now the list of detected licenses and their validity are dumped.

Troubleshooting

Machine UID has changed

This can occur when the hardware configuration of the machine is changed (especially when the network interfaces have changed).

In this case, you can either request a new activation key for this new UID or go back to the previous hardware configuration.

Production Licenses

This section should be considered when using Production Architectures, which use hardware license keys stored on a USB dongle.

MicroEJ USB Dongle

MicroEJ 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 directory

  • Enter the directory just created by your ZIP extraction tool.

  • Launch the executable program.

  • Accept running the unsigned software if requested (Windows 10/11)

    ../_images/updateWarningUnknownPublisher.png
  • Click on the Update button (no password needed)

    Dongle Update Tool

    Dongle Update Tool

  • On success, an Update successfully message shall appear. On failure, an Error key or no proper rockey message may appear.

    Successful dongle update

    Successful Dongle Update

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:

  1. Open a terminal.

  2. Change directory to a Production VEE Port.

  3. Execute the command:

    java -Djava.library.path=resources/os/[OS_NAME] -jar licenseManager/licenseManagerUsbDongle.jar
    

    with OS_NAME set to Windows64 for Windows OS, Linux64 for Linux OS, Mac for macOS x86_64 (Intel chip) or MacA64 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:

    ../_images/runAsAdministrator.png
  • 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.