1. Field
Certain embodiments of the invention generally relate to software licensing systems and methods. In particular, some embodiments may relate to activating or re-activating licenses, features, or upgrades.
2. Description of the Related Art
A software license generally refers to a legal instrument that governs the use and distribution of computer software products or programs. Typically, a software license grants a user the right to use copies of a copyrighted software product. The software license may also explain the terms of use and may set forth restrictions to the granted right to use the software. Some common forms of licenses include “shrink wrap” licenses, “online” licenses, and “site” licenses.
A “shrink wrap” license is a license that accompanies a physical software product that is sold individually in a package. Usually, this type of software is provided on a disk or some other type of physical medium. The term “shrink wrap” is used because this type of software is sold in a shrink wrapped package, and the user is assumed to have accepted the terms of the shrink wrap license upon breaking the seal of the package that holds the disk.
An “online” license refers to a license that accompanies software products that are downloaded from the Internet. This license is typically presented to the user prior to downloading the software, and provides the user with an option to accept or reject the license. If the user clicks the button to accept the license, then the user has accepted the terms of the license and the user is granted access to the software program.
A “site” license refers to a single license that allows for the installation of multiple copies of the same software on multiple machines at one or more of the purchaser's sites. This type of license is can be used to provide software to companies or other organizations that have numerous computers. The purchaser pays for a certain number of copies, and the site license allows the purchaser to install that number of copies on its computers.
In addition, there are a number of types of licenses, such as evaluation and commercial, and types of licensing models.
One embodiment is directed to a method including creating, by a server, a registration record in a database upon activation of a license for a product. The registration record includes an activation key for the license. The method may further include generating a new registration record comprising a new activation key when a change to the license occurs, generating a globally unique identifier for linking the registration record with the new registration record, and storing the linked registration records in the database.
Another embodiment is directed to an apparatus including at least one processor and at least one memory including computer program code. The at least one memory and computer program code are configured, with the at least one processor, to cause the apparatus at least to create a registration record comprising an activation key for the license in a database upon activation of a license for a product, generate a new registration record comprising a new activation key when a change to the license occurs, generate a globally unique identifier for linking the registration record with the new registration record, and store the linked registration records in the database.
Another embodiment is directed to a computer program embodied on a non-transitory computer readable medium. The computer program is configured to control a processor to perform a process including creating a registration record in a database upon activation of a license for a product. The registration record includes an activation key for the license. The process may further include generating a new registration record comprising a new activation key when a change to the license occurs, generating a globally unique identifier for linking the registration record with the new registration record, and storing the linked registration records in the database.
For proper understanding of the invention, reference should be made to the accompanying drawings, wherein:
It will be readily understood that the components of the invention, as generally described and illustrated in the figures herein, may be arranged and designed in a wide variety of different configurations. Thus, the following detailed description of the embodiments of systems, methods, apparatuses, and computer program products for a reusable license activation key, as represented in the attached figures, is not intended to limit the scope of the invention, but is merely representative of selected embodiments of the invention.
If desired, the different functions discussed below may be performed in a different order and/or concurrently with each other. Furthermore, if desired, one or more of the described functions may be optional or may be combined. As such, the following description should be considered as merely illustrative of the principles, teachings and embodiments of this invention, and not in limitation thereof
When a user or customer buys a specific software product, a purchase registration record is created in a database and the user is given an activation key for that product. If a user later purchases a maintenance renewal or product upgrade, finance constraints may require the creation of a new purchase registration record with new activation keys for these actions.
As will be discussed in detail below, embodiments provide a reusable activation key feature which allows users to still use the original activation key even if it is not related to a current state of their purchase. To achieve this feature, related registration records are linked together by a unique identifier. Whenever a user enters the original activation key and proceeds with product activation, a licensing server searches the linked registration records for this activation key and selects the corresponding current activation key for activation.
As mentioned above, there are a number of types of licenses and types of licensing models. For example, the types of licenses may include evaluation licenses, commercial licenses, temporary licenses, volume licenses, and free licenses. An evaluation license provides customers with a temporary license for a testing period; they can be valid for a limited number of days (e.g., 30 days) and once the evaluation period expires, the license would need to be converted into a commercial, temporary or extension license or the product will stop working.
A commercial license is defined as being perpetual in term and therefore can be used any time without expiration. Its usage is limited by a maintenance period that defines for which product versions it can be used. In other words, the commercial license can be used only with the product released before the end of the last maintenance period.
In contrast, a temporary license has a limited time frame and is used for special purposes, such as migration and update scenarios, etc. A free license may be valid for any predefined time period and provides a free version of a product, which may develop into a commercial version.
A volume license refers to a special type of license bundled with the product release. This license is bound to a specific product version and customer, and is used to install the product on any number of computers. The volume license does not expire, but a new version of a product will need a new volume license.
In addition to the above license types, there are several licensing models. For example, these may include single activation, multi activation, and seat based models. The single activation model refers to licenses that can be activated on a single computer only. The multi activation model refers to a license that can be activated on multiple computers. The licensing server can keep track of activated licenses and prevents activation on more than the allowed number of computers. A seat based model refers to a license that contains a defined number of “seats.” Seats can be activated all on a single computer or they can be distributed over multiple computers as needed.
According to an embodiment, as illustrated in
According to certain embodiments, licensing system 100 may include a licensing server 101, licensing client 110, product licensor 120 (e.g., customer), and a set of tools and utilities 122. Licensing server 101 may include a licensing service 102 and licensing database 105. Licensing service 102 may store information on customer's licenses, provide a set of services related to licenses, such as creation, activation, deactivation, synchronization, license maintenance, etc. Licensing server 101 may be accessed from the internet, for example via a licensing framework 111 or via a customer portal website or application 130, or internally by sales and support via a business management software (e.g., Netsuite™).
Licensing client 110 may include a licensing framework 111 and licensing store 112. Licensing framework 111 is a software package configured to manage licenses in licensing store 112 and communication with licensing server 101. A license can hold an unlimited set of attributes named features. Each feature may have a name and numeric value, and can be used by the product or licensing system 100 to find out what that specific license allows or disallows, how many elements are licensed, etc.
Licensing store 112 includes one or more files that contain encrypted records (e.g., licenses) located on the customer's computer. The licenses (represented by the encrypted records) are managed by licensing framework 111, which works upon licensing store 112 and communicates with licensing server 101.
In one embodiment, licensing store 112 may include one or more locally stored encrypted file(s) in XML format, for example. These file(s) may contain license records encoded as Base64 text and some extra information (e.g., UMID for the license record, type of license, date of creation and last access, etc.). According to an embodiment, the license records in the licensing store 112 can be automatically synchronized with the licensing server 101. This synchronization may occur, for example, periodically once per 24 hours or it can be performed on demand. In an embodiment, synchronization compares licenses in licensing store 112 with licenses available on the licensing server 101. If there are any updates available they are downloaded, and local licenses in the licensing store 112 are updated.
Product licensor 120 includes a dedicated software module included in a licensed product to check license validity and may perform operations, such as license activation, synchronization, etc. In an embodiment, licensing system 100 may also include tools and utilities 122, which include a set of dedicated software modules used for license related tasks, such as license management, maintenance checking, license store maintenance, etc.
A license lifecycle may be defined as a state machine, as illustrated in
After the automated import, evaluation licenses 200 are now stored in the licensing store. A unique machine ID (UMID) may be generated for the license and the UMID is sent during activation together with license information to the licensing server. The UMID may be a Base64 encoded sequence of bytes that uniquely identifies a particular machine and license on that machine The UMID can have an extension separated by character “:” that contains additional information about the product version, RTM date, etc. UMID can be generated for each machine and license on that machine The UMID can be used for both online and offline activation.
Referring again to
If the evaluation period expires and the evaluation license 200 is not activated, the evaluation license 200 becomes an expired evaluation license 210 and the product cannot be run.
The activated commercial license 220 can be deactivated, which means that the license is removed from the licensing store and is marked as deactivated on the licensing server. This allows the license to be activated again (e.g., after migration, upgrade, maintenance, etc.). In addition, activated licenses can be upgraded. For instance, the number of seats can be increased, e.g., if the license is originally approved for 10 computers, it can be upgraded to 20 computers, etc.
Returning to
At 350, once a commercial license is purchased, the product can be activated, which includes registration of a machine id on the licensing server. The evaluation license is then upgraded to commercial and the product can run indefinitely.
According to an embodiment, if the product is moved onto a new computer (e.g., server migration, etc.), the license record is deactivated. The product cannot run anymore on the original computer after deactivation, but the license can be activated on the new computer.
With respect to synchronization, if a customer changes the license status (e.g., upgrade, maintenance renewal, seat upgrade), those changes may be applied automatically in the background (e.g., once per 24 hours) or manually by the customer at any time. In certain embodiments, tier upgrade, version upgrade or maintenance renewal can be performed automatically or manually. Once the license record is updated in the licensing store, the customer has access to all features defined by the new (upgraded) license. Another type of upgrade is a seat based upgrade, which (re)allocates number of activated license seats over the computers.
It should be noted that, in some embodiments, data transfers between the licensing server and licensing store may be realized by licensing framework modules over web services, for example. In an embodiment, an encrypted extension of the Simple Object Access Protocol (SOAP) (REF1-Web Services Enhancements Architecture) may be used for communication with the licensing proxy over the Internet. Web services can activate and deactivate licenses, check license status, update customer information and can be called by product (either automatically or from an interface by user), customer (via customer portal), or support person (e.g., via Netsuite™).
Depending upon the licensing model, embodiments may provide several subsequent data models based upon set of database tables, which may be stored in the licensing server. In an embodiment, the following tables may be used:
Once a license is created (i.e., license key is generated and related record is created by licensing server) it can be activated and deactivated, as discussed above. The created license has a fixed set of parameters that cannot be changed. Any changes to the license, such as upgrade or downgrade, are done by decommissioning of the old license record and the creation of a new record.
When a license is marked as decommissioned, the “paid” column of the “registration” table is changed from YES to REPLACED or UPGRADED, and it is not possible to activate/deactivate that license anymore. When the customer makes a change to the license (e.g., upgrade or downgrade), the license is marked as decommissioned and a new license record (with the parameters required by customer) having a new activation key is created to replace the decommissioned record.
The single activation license model works mostly upon tables “applications” and “registrations.” A license record can be in states of ready-to-be-activated (blank license) or activated. As mentioned above, a license record is identified by the activation key which may be GUID based. An upgrade to the license may be performed by creating new license record (new record in table registrations) which is bound by value of column NetsuiteLicenseId/LicenseGroupId. A license can be upgraded or downgraded for license parameters (tier) or product major version (only upgrade).
In certain embodiments, the following operations may occur:
The following tables show the sequence of initialization-activation-deactivation operations. Changed values, or records added are italicized. In the initial state, there exists one record with activation key and it has assigned a license id value (column NetsuiteLicenseID) used for linking with all related records, and the value of column “used” is set to 0.
The maintenance record contains related information for license maintenance. It is linked to the “registrations” table by value of column “NetsuteLicense”.
After activation value of column “Used” is set to 1, there are set content columns, License blob's value is set up.
After deactivation, the previous record is marked as replaced (Paid=REPLACE) and a new one is added with a different activation key value. While a new activation customer can use the first activation key because these records are linked by NetsuiteLicenselD value, according to an embodiment.
In an embodiment, the customer can use any of the activation keys, and the licensing server may locate the appropriate activation key at any time (Paid=YES, used=0) by Netsuite License ID, for example.
indicates data missing or illegible when filed
The multi-activation license model works mostly with tables “Applications”, “Registrations” and “Registrations_multiactivations.” A license record can be in states ready-to-be-activated (blank license) or activated to x of n licenses. Again, the record may be identified by an activation key (e.g., GUID based). The upgrade mechanism is the same as described above for the single activation model. However, to allow the license to be used on more than one computer, there is an added “Registrations_multiactivations” table that holds computer-specific information. Shared information is still in the “registrations” table. During activation of the license, a new record is created in “Registrations_MultiActivations” table and “Registrations” table record is updated with the correct activation count value. Since each computer has a unique machine ID, for any single computer there is always present a record related to the activation key and machine id. Table “registrations” may store information on how many licenses total are available and how many are in use. These counters are incremented/decremented during activation/deactivation. If license limit is reached, it is not possible to activate new licenses.
In certain embodiments, the following operations may occur:
The Seat based model extends the multi-activation model with a new mechanism in which one computer can have more than 1 license seat activated for a single license. This is important for certain server products to be able to cover number of clients connected to the server. In this model, the counter ActivationCount in the table “registrations” contains the total number of seats available for the license and this counter is incremented/decremented during activations/deactivations in similar way as for multi-activation licenses.
As mentioned above, multi-activation licensing use an extra table—Registrations_multiactivations—which is related to single instance of installation and is linked to master record in table “Registrations”. These records are addressed by machinelD used, or if not found then a new one is created.
When in initial state, master record does exist in the table similarly like in the Single activation model.
Maintenance information is treated the same way as for single activation model.
In the multi-activation model, activation is not value of column “Used” set to 1, rather counters and related logic behind license size computation (LicenseUnitSize, ActivationCount, MaxlnstallationCount) are employed. If value of ActivationCount reaches MaxInstallationCount value, further activations are blocked.
indicates data missing or illegible when filed
Because there are many installations linked to one key, shared information is stored in the “Registrations” table, and installation-related part of information (customer info, Machine ID, Computer name, License Blob, etc.) are stored in the table “Registrations_multiactivations.” Additionally, there can be activated different versions of a product (key for higher version can cover lower one). While filling “Registrations_multiactivations” data, there can be copied some information into a master record in the table “Registrations”, this may be used mainly for triggering internal synchronization mechanisms between systems working with the licensing server.
For deactivation, there may be employed counter mechanisms as mentioned above. However, instead of marking a record as used, there is licensing logic based on computations with counters and limits. In this embodiment, the deactivation process works the opposite way and decreases counters. Thus, the same product license can be moved over many computers provided that, at the time, the number of simultaneously activated licenses does not reach license size (MaxInstallationSize).
indicates data missing or illegible when filed
If there is tier upgrade performed upon license in multiactivation model, there is master record in the Registrations table abandoned and the new one is created. However these records are linked by Netsuite License ID thus customer can use any of the the activations keys.
indicates data missing or illegible when filed
indicates data missing or illegible when filed
As illustrated in
Apparatus 20 may further comprise or be coupled to a memory 34 (internal or external), which may be coupled to processor 32, for storing information and instructions that may be executed by processor 32. Memory 34 may be one or more memories and of any type suitable to the local application environment, and may be implemented using any suitable volatile or nonvolatile data storage technology such as a semiconductor-based memory device, a magnetic memory device and system, an optical memory device and system, fixed memory, and removable memory. For example, memory 34 may be comprised of any combination of random access memory (RAM), read only memory (ROM), static storage such as a magnetic or optical disk, or any other type of non-transitory machine or computer readable media. The instructions stored in memory 34 may include program instructions or computer program code that, when executed by processor 32, enable the apparatus 20 to perform tasks as described herein.
Apparatus 20 may also comprise or be coupled to one or more antennas 35 for transmitting and receiving information and/or data to and from apparatus 20. Alternatively, apparatus 20 may include a communication interface or ports for transmitting and receiving information over a network. Apparatus 20 may further comprise or be coupled to a transceiver 38 configured to transmit and receive information. The transceiver may be an external device, such as a remote radio head. For instance, transceiver 38 may be configured to modulate information on to a carrier waveform for transmission by the antenna(s) 35 and demodulate information received via the antenna(s) 35 for further processing by other elements of apparatus 20. In other embodiments, transceiver 38 may be capable of transmitting and receiving signals or data directly.
Processor 32 may perform functions associated with the operation of apparatus 20 including, without limitation, precoding of antenna gain/phase parameters, encoding and decoding of individual bits forming a communication message, formatting of information, and overall control of the apparatus 20, including processes related to management of communication resources.
In an embodiment, memory 34 stores software modules that provide functionality when executed by processor 32. The modules may include, for example, an operating system that provides operating system functionality for apparatus 20. The memory may also store one or more functional modules, such as an application or program, to provide additional functionality for apparatus 20. The components of apparatus 20 may be implemented in hardware, or as any suitable combination of hardware and software.
As mentioned above, according to one embodiment, apparatus 20 may be a server, node or host or base station in a communications network or serving such a network, such as a licensing server. In this embodiment, apparatus 20 may be controlled by memory 34 and processor 32 to create a registration record in a database upon activation of a license for a product. The registration record may include an activation key for the license. According to one embodiment, apparatus 20 may be further controlled by memory 34 and processor 32 to generate a new registration record comprising a new activation key when a change to the license occurs, to generate a globally unique identifier for linking the registration record with the new registration record, and to store the linked registration records in the database. In an embodiment, the change to the license comprises at least one of a product upgrade or a maintenance renewal.
In an embodiment, apparatus 20 may be further controlled by memory 34 and processor 32 to receive the activation key for the license from a user seeking to activate a feature of the product, and to search the linked registration records for the new activation key using the received activation key. When the new activation key is found, apparatus 20 may be further controlled by memory 34 and processor 32 to use the new activation key to activate the feature of the product.
In an embodiment, the method of
In some embodiments, the functionality of any of the methods described herein, such as that of
One having ordinary skill in the art will readily understand that the invention as discussed above may be practiced with steps in a different order, and/or with hardware elements in configurations which are different than those which are disclosed. Therefore, although the invention has been described based upon these preferred embodiments, it would be apparent to those of skill in the art that certain modifications, variations, and alternative constructions would be apparent, while remaining within the spirit and scope of the invention. In order to determine the metes and bounds of the invention, therefore, reference should be made to the appended claims.
This application claims priority from U.S. provisional application No. 61/994,395 filed on May 16, 2014. The contents of this earlier filed application are hereby incorporated in its entirety.
Number | Date | Country | |
---|---|---|---|
61994395 | May 2014 | US |