From dda16735b94661b798d6c0fd3e41af944de0a1fe Mon Sep 17 00:00:00 2001 From: gcontini <1121667+gcontini@users.noreply.github.com> Date: 周日, 13 10月 2019 15:02:19 +0800 Subject: [PATCH] refactoring - locators --- src/library/LicenseReader.cpp | 307 +++++++++++++++++--------------------------------- 1 files changed, 104 insertions(+), 203 deletions(-) diff --git a/src/library/LicenseReader.cpp b/src/library/LicenseReader.cpp index 9927426..7c020b1 100644 --- a/src/library/LicenseReader.cpp +++ b/src/library/LicenseReader.cpp @@ -2,7 +2,7 @@ * LicenseReader.cpp * * Created on: Mar 30, 2014 - * + * */ #ifdef _WIN32 @@ -10,6 +10,7 @@ #else # include <unistd.h> #endif + #include <cstring> #include <ctime> #include <vector> @@ -17,24 +18,27 @@ #include <iterator> #include <fstream> #include <sstream> + #include <stdlib.h> #include <math.h> + #include "pc-identifiers.h" -#include "LicenseReader.h" +#include "build_properties.h" +#include "public-key.h" +#include "LicenseReader.hpp" #include "base/StringUtils.h" #include "base/logger.h" -#include "public-key.h" -#include <build_properties.h> +#include "locate/LocatorFactory.hpp" namespace license { const char *FullLicenseInfo::UNUSED_TIME = "0000-00-00"; -FullLicenseInfo::FullLicenseInfo(const string& source, const string& product, - const string& license_signature, int licenseVersion, string from_date, - string to_date, const string& client_signature, +FullLicenseInfo::FullLicenseInfo(const string &source, const string &product, + const string &license_signature, int licenseVersion, string from_date, + string to_date, const string &client_signature, unsigned int from_sw_version, unsigned int to_sw_version, - const string& extra_data) : + const string &extra_data) : source(source), product(product), // license_signature(license_signature), license_version(licenseVersion), // from_date(from_date), to_date(to_date), // @@ -70,7 +74,7 @@ } if (has_client_sig) { PcSignature str_code; - strncpy(str_code, client_signature.c_str(), sizeof(str_code)-1); + strncpy(str_code, client_signature.c_str(), sizeof(str_code) - 1); const EVENT_TYPE event = validate_pc_signature(str_code); if (event != LICENSE_OK) { er.addEvent(event, SVRT_ERROR); @@ -79,7 +83,7 @@ return er; } -void FullLicenseInfo::toLicenseInfo(LicenseInfo* license) const { +void FullLicenseInfo::toLicenseInfo(LicenseInfo *license) const { if (license != nullptr) { strncpy(license->proprietary_data, extra_data.c_str(), PROPRIETARY_DATA_SIZE); @@ -91,225 +95,122 @@ license->days_left = 999999; } else { strncpy(license->expiry_date, to_date.c_str(), 11); - const double secs = difftime( - seconds_from_epoch(to_date.c_str()), - time(nullptr)); + const double secs = difftime(seconds_from_epoch(to_date.c_str()), + time(nullptr)); license->days_left = round(secs / (60 * 60 * 24)); } } } -LicenseReader::LicenseReader(const LicenseLocation& licenseLocation) : - licenseLocation(licenseLocation) { +LicenseReader::LicenseReader(const LicenseLocation &licenseLocation) : + licenseLocation(licenseLocation) { } EventRegistry LicenseReader::readLicenses(const string &product, - vector<FullLicenseInfo>& licenseInfoOut) { + vector<FullLicenseInfo> &licenseInfoOut) { vector<string> diskFiles; - EventRegistry result = getLicenseDiskFiles(diskFiles); - if (!result.isGood()) { - return result; + vector<unique_ptr<locate::LocatorStrategy>> locator_strategies; + FUNCTION_RETURN ret = locate::LocatorFactory::getActiveStrategies( + locator_strategies, licenseLocation.licenseFileLocation); + EventRegistry eventRegistry; + if (ret != FUNC_RET_OK) { + eventRegistry.addError(LICENSE_FILE_NOT_FOUND); + return eventRegistry; } - bool loadAtLeastOneFile = false; + + if (!eventRegistry.isGood()) { + return eventRegistry; + } + bool atLeastOneFileFound = false; + bool atLeastOneFileRecognized = false; bool atLeastOneProductLicensed = false; bool atLeastOneLicenseComplete = false; - CSimpleIniA ini; - for (auto it = diskFiles.begin(); it != diskFiles.end(); it++) { - ini.Reset(); - const SI_Error rc = ini.LoadFile((*it).c_str()); - if (rc < 0) { - result.addEvent(FILE_FORMAT_NOT_RECOGNIZED, SVRT_WARN, *it); + for (unique_ptr<locate::LocatorStrategy>& locator : locator_strategies) { + vector<string> licenseLocations = locator->licenseLocations( + eventRegistry); + if (licenseLocations.size() == 0) { continue; - } else { - loadAtLeastOneFile = true; } - const char* productNamePtr = product.c_str(); - const int sectionSize = ini.GetSectionSize(productNamePtr); - if (sectionSize <= 0) { - result.addEvent(PRODUCT_NOT_LICENSED, SVRT_WARN, *it); - continue; - } else { - atLeastOneProductLicensed = true; - } - /* - * sw_version_from = (optional int) - * sw_version_to = (optional int) - * from_date = YYYY-MM-DD (optional) - * to_date = YYYY-MM-DD (optional) - * client_signature = XXXX-XXXX-XXXX-XXXX (optional string 16) - * license_signature = XXXXXXXXXX (mandatory, 1024) - * application_data = xxxxxxxxx (optional string 16) - */ - const char * license_signature = ini.GetValue(productNamePtr, - "license_signature", nullptr); - long license_version = ini.GetLongValue(productNamePtr, - "license_version", -1); - if (license_signature != nullptr && license_version > 0) { - const string from_date = trim_copy( - ini.GetValue(productNamePtr, "from_date", - FullLicenseInfo::UNUSED_TIME)); - const 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());*/ - const int from_sw_version = ini.GetLongValue(productNamePtr, - "from_sw_version", - FullLicenseInfo::UNUSED_SOFTWARE_VERSION); - const int to_sw_version = ini.GetLongValue(productNamePtr, - "to_sw_version", FullLicenseInfo::UNUSED_SOFTWARE_VERSION); - string extra_data = trim_copy( - ini.GetValue(productNamePtr, "extra_data", "")); - FullLicenseInfo licInfo(*it, product, license_signature, - (int) license_version, from_date, to_date, client_signature, - from_sw_version, to_sw_version, extra_data); - licenseInfoOut.push_back(licInfo); - atLeastOneLicenseComplete = true; - } else { - result.addEvent(LICENSE_MALFORMED, SVRT_WARN, *it); - } - } - if (!loadAtLeastOneFile) { - result.turnEventIntoError(FILE_FORMAT_NOT_RECOGNIZED); - } - if (!atLeastOneProductLicensed) { - result.turnEventIntoError(PRODUCT_NOT_LICENSED); - } - if (!atLeastOneLicenseComplete) { - result.turnEventIntoError(LICENSE_MALFORMED); - } - return result; -} - -bool LicenseReader::findLicenseWithExplicitLocation(vector<string>& diskFiles, - EventRegistry& eventRegistry) { -//bool hasFileLocation = false; - bool licenseFoundWithExplicitLocation = false; - if (licenseLocation.licenseFileLocation != nullptr - && licenseLocation.licenseFileLocation[0] != '\0') { - //hasFileLocation = true; - const string varName(licenseLocation.licenseFileLocation); - const vector<string> declared_positions = splitLicensePositions(varName); - vector<string> existing_pos = filterExistingFiles(declared_positions); - if (existing_pos.size() > 0) { - if (existing_pos.size() > 0) { - licenseFoundWithExplicitLocation = true; - for (auto it = existing_pos.begin(); it != existing_pos.end(); - ++it) { - diskFiles.push_back(*it); - eventRegistry.addEvent(LICENSE_FILE_FOUND, SVRT_INFO, *it); - } - } - } else { - eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SVRT_WARN, varName); - } - } - return licenseFoundWithExplicitLocation; -} - -bool LicenseReader::findFileWithEnvironmentVariable(vector<string>& diskFiles, - EventRegistry& eventRegistry) { - bool licenseFileFoundWithEnvVariable = false; - if (licenseLocation.environmentVariableName != nullptr - && licenseLocation.environmentVariableName[0] != '\0') { - const string varName(licenseLocation.environmentVariableName); - if (varName.length() > 0) { - //var name is passed in by the calling application. - char* env_var_value = getenv(varName.c_str()); - if (env_var_value != nullptr && env_var_value[0] != '\0') { - const vector<string> declared_positions = splitLicensePositions( - string(env_var_value)); - vector<string> existing_pos = filterExistingFiles( - declared_positions); - if (existing_pos.size() > 0) { - licenseFileFoundWithEnvVariable = true; - for (auto it = existing_pos.begin(); - it != existing_pos.end(); ++it) { - diskFiles.push_back(*it); - eventRegistry.addEvent(LICENSE_FILE_FOUND, SVRT_INFO, - *it); - } - } else { - eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SVRT_WARN, - env_var_value); - } + atLeastOneFileFound = true; + CSimpleIniA ini; + for (auto it = licenseLocations.begin(); it != licenseLocations.end(); + it++) { + ini.Reset(); + string license = locator->retrieveLicense((*it).c_str()); + const SI_Error rc = ini.LoadData(license.c_str(), license.size()); + if (rc < 0) { + eventRegistry.addEvent(FILE_FORMAT_NOT_RECOGNIZED, SVRT_WARN, + *it); + continue; } else { - eventRegistry.addEvent(ENVIRONMENT_VARIABLE_NOT_DEFINED, - SVRT_WARN); + atLeastOneFileRecognized = true; } - } else { - eventRegistry.addEvent(ENVIRONMENT_VARIABLE_NOT_DEFINED, SVRT_WARN); - } - } - return licenseFileFoundWithEnvVariable; -} - -EventRegistry LicenseReader::getLicenseDiskFiles(vector<string>& diskFiles) { - EventRegistry eventRegistry; - const bool licenseFoundWithExplicitLocation = findLicenseWithExplicitLocation( - diskFiles, eventRegistry); - bool foundNearModule = false; - if (licenseLocation.openFileNearModule) { - char fname[MAX_PATH] = { 0 }; - const FUNCTION_RETURN fret = getModuleName(fname); - if (fret == FUNC_RET_OK) { - const string temptativeLicense = string(fname) + ".lic"; - ifstream f(temptativeLicense.c_str()); - if (f.good()) { - foundNearModule = true; - diskFiles.push_back(temptativeLicense); - eventRegistry.addEvent(LICENSE_FILE_FOUND, SVRT_INFO, - temptativeLicense); + const char *productNamePtr = product.c_str(); + const int sectionSize = ini.GetSectionSize(productNamePtr); + if (sectionSize <= 0) { + eventRegistry.addEvent(PRODUCT_NOT_LICENSED, SVRT_WARN, *it); + continue; } else { - eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SVRT_WARN, - temptativeLicense); + atLeastOneProductLicensed = true; } - f.close(); - } else { - LOG_WARN("Error determining module name."); + /* + * sw_version_from = (optional int) + * sw_version_to = (optional int) + * from_date = YYYY-MM-DD (optional) + * to_date = YYYY-MM-DD (optional) + * client_signature = XXXX-XXXX-XXXX-XXXX (optional string 16) + * license_signature = XXXXXXXXXX (mandatory, 1024) + * application_data = xxxxxxxxx (optional string 16) + */ + const char *license_signature = ini.GetValue(productNamePtr, + "license_signature", nullptr); + long license_version = ini.GetLongValue(productNamePtr, + "license_version", -1); + if (license_signature != nullptr && license_version > 0) { + const string from_date = trim_copy( + ini.GetValue(productNamePtr, "from_date", + FullLicenseInfo::UNUSED_TIME)); + const 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());*/ + const int from_sw_version = ini.GetLongValue(productNamePtr, + "from_sw_version", + FullLicenseInfo::UNUSED_SOFTWARE_VERSION); + const int to_sw_version = ini.GetLongValue(productNamePtr, + "to_sw_version", + FullLicenseInfo::UNUSED_SOFTWARE_VERSION); + string extra_data = trim_copy( + ini.GetValue(productNamePtr, "extra_data", "")); + FullLicenseInfo licInfo(*it, product, license_signature, + (int) license_version, from_date, to_date, + client_signature, from_sw_version, to_sw_version, + extra_data); + licenseInfoOut.push_back(licInfo); + atLeastOneLicenseComplete = true; + } else { + eventRegistry.addEvent(LICENSE_MALFORMED, SVRT_WARN, *it); + } } } - const bool licenseFileFoundWithEnvVariable = findFileWithEnvironmentVariable( - diskFiles, eventRegistry); - - if (!foundNearModule && !licenseFoundWithExplicitLocation - && !licenseFileFoundWithEnvVariable) { + if (!atLeastOneFileFound) { eventRegistry.turnEventIntoError(ENVIRONMENT_VARIABLE_NOT_DEFINED); eventRegistry.turnEventIntoError(LICENSE_FILE_NOT_FOUND); + } else if (!atLeastOneFileRecognized) { + eventRegistry.turnEventIntoError(FILE_FORMAT_NOT_RECOGNIZED); + } else if (!atLeastOneProductLicensed) { + eventRegistry.turnEventIntoError(PRODUCT_NOT_LICENSED); + } else if (!atLeastOneLicenseComplete) { + eventRegistry.turnEventIntoError(LICENSE_MALFORMED); } return eventRegistry; } -vector<string> LicenseReader::filterExistingFiles( - vector<string> licensePositions) { - vector<string> existingFiles; - for (auto it = licensePositions.begin(); it != licensePositions.end(); - it++) { - ifstream f(it->c_str()); - if (f.good()) { - existingFiles.push_back(*it); - } - f.close(); - } - return existingFiles; -} - -vector<string> LicenseReader::splitLicensePositions(string licensePositions) { - std::stringstream streamToSplit(licensePositions); - std::string segment; - std::vector<string> seglist; - - while (std::getline(streamToSplit, segment, ';')) { - seglist.push_back(segment); - } - return seglist; -} - LicenseReader::~LicenseReader() { - } string FullLicenseInfo::printForSign() const { @@ -336,7 +237,7 @@ } -void FullLicenseInfo::printAsIni(ostream & a_ostream) const { +void FullLicenseInfo::printAsIni(ostream &a_ostream) const { CSimpleIniA ini; string result; const string product = toupper_copy(trim_copy(this->product)); -- Gitblit v1.9.1