From b5001a9a6e6d0f63f2f2d26a2f710519a6fcc6a0 Mon Sep 17 00:00:00 2001 From: open-license-manager <rillf@maildrop.cc> Date: 周一, 26 5月 2014 01:00:10 +0800 Subject: [PATCH] pc id --- src/library/LicenseReader.cpp | 23 +++++++++++++++++++++-- 1 files changed, 21 insertions(+), 2 deletions(-) diff --git a/src/library/LicenseReader.cpp b/src/library/LicenseReader.cpp index 093b276..16662dd 100644 --- a/src/library/LicenseReader.cpp +++ b/src/library/LicenseReader.cpp @@ -64,6 +64,14 @@ er.addEvent(PRODUCT_EXPIRED, SEVERITY_ERROR); } } + if (has_client_sig) { + UserPcIdentifier str_code; + strncpy(str_code, client_signature.c_str(), sizeof(str_code)); + EVENT_TYPE event = validate_user_pc_identifier(str_code); + if (event != OK) { + er.addEvent(event, SEVERITY_ERROR); + } + } return er; } @@ -123,7 +131,7 @@ * sw_version_to = (optional int) * from_date = YYYY-MM-DD (optional) * to_date = YYYY-MM-DD (optional) - * client_signature = XXXXXXXX (optional string 16) + * client_signature = XXXX-XXXX-XXXX-XXXX (optional string 16) * license_signature = XXXXXXXXXX (mandatory, 1024) * application_data = xxxxxxxxx (optional string 16) */ @@ -138,8 +146,19 @@ string to_date = trim_copy( ini.GetValue(productNamePtr, "to_date", FullLicenseInfo::UNUSED_TIME)); + string client_signature = trim_copy( + ini.GetValue(productNamePtr, "client_signature", "")); + client_signature.erase( + std::remove(client_signature.begin(), + client_signature.end(), "-"), + client_signature.end()); + int from_sw_version = ini.GetLongValue(productNamePtr, + "from_sw_version", FullLicenseInfo::UNUSED_SOFTWARE_VERSION); + int to_sw_version = ini.GetLongValue(productNamePtr, + "to_sw_version", FullLicenseInfo::UNUSED_SOFTWARE_VERSION); FullLicenseInfo licInfo(*it, product, license_signature, - (int) license_version, from_date, to_date); + (int) license_version, from_date, to_date, + client_signature,from_sw_version,to_sw_version); licenseInfoOut.push_back(licInfo); atLeastOneLicenseComplete = true; } else { -- Gitblit v1.9.1