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

webServiceUrl

string

URL to the QLM License Server.

activationKey

string

activation key to update

licenseData

string

XML 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>

response

string

XML fragment containing the result of the call

Return

TypeDescription

bool

returns 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;
// Make sure that the AdminEncryptionKey is set when calling the Management API
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 - update the customer associated with a license

//Modify the user associated with the license
string customerEmail = "support@soraco.co";

string licenseData = String.Format(@"<licenseArguments ");
licenseData += String.Format(@" Email='{0}'", customerEmail);            
licenseData += String.Format(@"> </licenseArguments>");

string response;
// Make sure that the AdminEncryptionKey is set when calling the Management API
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);

Last updated