A license template acts as a blueprint for the licenses you create for your customers. Before you start creating licenses, you need to create a license template that contains the default values for the license fields.
While creating a license from any license template, you can override all the properties of the license template. The license template provides you with default values for all the properties of a license, so you don't have to provide them every time you create a new license.
You can easily create a license template through the admin portal. Go to the license templates section in the admin portal and click the create button. A license template form with the following fields will popup:
The name of the license template.
The duration (in seconds) after which the license will expire.
{% hint style="info" %} To create a perpetual license set the validity to zero and for subscriptions set it to any value greater than zero. {% endhint %}
There are three types of licenses:
- Node-locked: This is the default type that locks the license to the machine.
- Hosted Floating: This type is used for creating a hosted floating license.
- On-Premise floating: This type is used for creating an on-premise floating license.
This option is valid for hosted-floating and on-premise-floating license types only. It sets the duration for which you want to lease the floating license.
{% hint style="info" %} In case of hosted-floating license type, if you want the license lease to auto-renew then ensure that the server sync interval is less than lease duration by a difference of at least 30 seconds. In order to allow unlimited lease duration, this property can be set to 0 or -1. {% endhint %}
{% hint style="info" %} In the case of on-premise license type, lease duration can be set to 0 to honor the lease duration set in the LexFloatServer config file. {% endhint %}
This option is valid for on-premise-floating and hosted-floating license types only. It allows for the following strategies:
Each machine will only consume a single floating license/activation, irrespective of the number of instances (processes) of your app being run on the machine.
Each instance (process) of your app will consume a separate floating license/activation, irrespective of whether the instances are running on the same machine or different machines.
{% hint style="info" %}
In case of hosted-floating license type, if you want to use a per-instance leasing strategy, ensure that the permission flag in the LexActivator SetProductId()
function is set to LA_IN_MEMORY
.
{% endhint %}
This option is valid for on-premise floating license type only. It sets the maximum number of concurrent clients that can lease the floating license from the server.
{% hint style="info" %} For hosted floating licenses, the maximum number of concurrent clients that can lease the license from the server is determined by allowedActivations property {% endhint %}
Allowed number of activations (seats) for the license. If you allow (say) 10 activations for a license, then the license can be used on 10 different machines.
{% hint style="info" %} In order to allow unlimited activations, this property can be set to 0 or -1. {% endhint %}
Allowed number of deactivations for the license. This setting is ignored for hosted-floating licenses.
{% hint style="info" %} In order to allow unlimited deactivations, this property can be set to -1.
The default value for Hosted-Floating licenses is set to -1, indicating unlimited deactivations. {% endhint %}
Whenever the application starts (andIsLicenseGenuine()
is called the first time), the server sync occurs immediately in a separate thread. This setting determines the interval for further server syncs till the application is not closed.
{% hint style="info" %} The minimum allowed server sync interval up to the STARTUP plan is 3600 seconds, and for higher plans, it is 180 seconds. It is highly recommended to set it to 3600 or greater unless required. {% endhint %}
The duration for which the server sync failure due to network error is acceptable.
{% hint style="info" %} In order to allow an infinite grace period, this property can be set to "-1". {% endhint %}
The allowed difference between the network time and the system time. This can be used to allow license activations on machines where system clocks run behind the network time.
The strategy to determine the expiration start date. It allows for the following strategies:
The license starts expiring right after it is created.
The license starts expiring after the license is activated the first time. If the license allows more than one activation then all the other activations will also start expiring right after the first activation of the license.
LexActivator generates a structured fingerprint of the machine which allows for multiple fingerprint matching strategies. It allows for the following strategies:
This strategy requires an exact match of all the hardware parts which were fingerprinted. If there is a minor change in the hardware, the fingerprint will not be accepted, and the machine will be treated as a different machine.
This strategy uses fuzzy matching by comparing different hardware fingerprints and if the comparison score is greater than a minimum threshold value, the machine is accepted. This is the recommended strategy.
This strategy is similar to fuzzy but with a much lower threshold value.
{% hint style="info" %} Sometimes few machines misbehave by reporting major changes in hardware fingerprints due to many issues, in such cases, you should change the strategy to "Loose". {% endhint %}
List of required metadata keys that a license using the license template must have.
List of required meter attributes which a license using the license template must have.
The number of seconds to wait before the license expiration date to trigger the license.expiring-soon
webhook event.
Regex for the license key format. The default regex is ^([A-F0-9]{6}-){5}[A-F0-9]{6}$
which generates the license keys in the format:XXXXXX-XXXXXX-XXXXXX-XXXXXX-XXXXXX-XXXXXX
List of the allowed countries. The country name is resolved using the IP address. If none of the countries is selected, then all the countries are allowed.
List of the disallowed countries. The country name is resolved using the IP address. If none of the countries is selected, this setting is ignored.
IP address range in CIDR notation e.g. 196.210.135.105/24. If no range is specified, then all the IP addresses are allowed.
List of the allowed IP addresses. If none of the IP addresses is included, then all the IP addresses are allowed.
List of the disallowed IP addresses. If none of the IP addresses is included, this setting is ignored.
Whether to allow an activation inside a virtual machine. Cloned virtual machines may report the same fingerprint.
Whether to allow an activation inside a container. This must never be set to true
for an on-premise floating license.
Whether to allow the client app to set the lease duration for the hosted-floating license activation.
It prevents multiple users inside an OS from using the same license key. If enabled, each user will consume a license activation from the allowed number of activations for a license.
In case you want to enforce user authentication for license activation in addition to the license key, you can set this property to true
.
In case you don't want to store the IP address and location of the license activation, you can set this property to true
.