UpdateLicenseInfo

Description

Updates the data associated with a license key.

Note that to call this function, you must:

  • Set the AdminEncryptionKey
bool UpdateLicenseInfo (string webServiceUrl, string activationKey, 
                        string licenseData, out string response)

Parameters

ParameterTypeDescription
webServiceUrlstringURL to the QLM License Server.
activationKeystringactivation key to update
licenseDatastringXML fragment containing the fields to update. The XML fragment should be of the form:

<licenseArguments
field1=" 'value'
field2=" 'value' "
</licenseArguments>

where field1 is the name of a field in the LicenseKeys table. For fields of type date, you should use the following date/time format: yyyy-MM-dd HH:mm:ss

Example:
<licenseArguments
ComputerName= " 'my pc' "
UserData1=" 'my user data' "
</licenseArguments>
responsestringXML fragment containing the result of the call

Return

TypeDescription
boolreturns true if the operation succeeded; false otherwise.

Response XML format

<?xml version='1.0' encoding='UTF-8'?>
<QuickLicenseManager>
<result>Successfully updated license information for ActivationKey=XYZ.</result>
</QuickLicenseManager>

Example error response

<?xml version='1.0' encoding='UTF-8'?>
<QuickLicenseManager>
<error>Details about the error</error>
</QuickLicenseManager>

Important: The value part of the licenseData xml fragment must be properly escaped for xml reserved keywords.

Remarks

When updating license information of a multiple activations license key (Number of Licenses > 1), the data associated with each activated computer is stored in the ActivationLog table instead of the LicenseKeys table. Therefore, to update data in the ActivationLog table, you need to specify which computer to update. The computerID, computerKey and computerName arguments can be specified to identify the computer. At least one of these arguments must be specified.

The ActivationLog table contains the following updatable fields: ComputerKey, ComputerName, ComputerID, ActivationDate, LastAccessedDate, ActivationCount

Use ParseResults to interpret the results of the call and load the returned data into an ILicenseInfo object.

Example: modify the number of licenses

//Modify the number of licenses and available licenses

int numLicenses = 3;
int availableLicenses = 2;

string licenseData = String.Format(@"<licenseArguments ");
licenseData += String.Format(@" NumLicenses='{0}'", numLicenses);
licenseData += String.Format(@" AvailableLicenses='{0}'", availableLicenses);
licenseData += String.Format(@"> </licenseArguments>");

string response;
lv.QlmLicenseObject.AdminEncryptionKey = "{B6163D99-F46A-4580-BB42-BF276A507A14}";
lv.QlmLicenseObject.UpdateLicenseInfo(string.Empty, lv.ActivationKey, licenseData, out response);

ILicenseInfo li = new LicenseInfo();
string message = string.Empty;
if (lv.QlmLicenseObject.ParseResults(response, ref li, ref message))
{
  // success
}
else
{
  // error
}

Example - how to escape characters

string userData = "Test&Go";  
userData = SecurityElement.Escape(userData);

string licenseData = String.Format (@"\<licenseArguments UserData1=""N'{0}'""> </licenseArguments>", 
                                    userData);