From 36ce07093b68b07513149577c209ae7a57ab356b Mon Sep 17 00:00:00 2001 From: Gabriele Contini <contini.mailing@gmail.com> Date: 周日, 15 3月 2020 16:26:21 +0800 Subject: [PATCH] Merge branch 'feature/pc_identifiers' into develop issues #2 #3 #14 #49 --- src/library/licensecc.cpp | 73 ++++++++++++++++++++++++++---------- 1 files changed, 53 insertions(+), 20 deletions(-) diff --git a/src/library/licensecc.cpp b/src/library/licensecc.cpp index fe1b3a7..5378638 100644 --- a/src/library/licensecc.cpp +++ b/src/library/licensecc.cpp @@ -1,36 +1,62 @@ //============================================================================ -// Name : license-manager-cpp.cpp +// Name : licensecc.cpp // Author : // Version : // Copyright : BSD //============================================================================ +#define __STDC_WANT_LIB_EXT1__ 1 #include <fstream> #include <stdio.h> +#include <string.h> #include <stdlib.h> #include <cstring> #include <iostream> #include <licensecc/datatypes.h> #include <licensecc/licensecc.h> +#include <licensecc_properties.h> +#include "base/logger.h" +#include "hw_identifier/hw_identifier_facade.hpp" #include "limits/license_verifier.hpp" +#include "base/StringUtils.h" #include "LicenseReader.hpp" using namespace std; -void print_error(char out_buffer[256], LicenseInfo* licenseInfo) {} -void identify_pc(IDENTIFICATION_STRATEGY pc_id_method, char chbuffer[PC_IDENTIFIER_SIZE + 1]) {} + +void print_error(char out_buffer[LCC_API_ERROR_BUFFER_SIZE], LicenseInfo* licenseInfo) {} + +bool identify_pc(LCC_API_IDENTIFICATION_STRATEGY pc_id_method, char* chbuffer, size_t* bufSize) { + bool result = false; + if (*bufSize > LCC_API_PC_IDENTIFIER_SIZE && chbuffer != nullptr) { + try { + string pc_id = license::hw_identifier::HwIdentifierFacade::generate_user_pc_signature(pc_id_method); + strncpy(chbuffer, pc_id.c_str(), *bufSize); + result = true; + } catch (const std::exception& ex) { + LOG_ERROR("Error calculating hw_identifier: %s", ex.what()); +#ifdef _DEBUG + cout + << "Error occurred: " << ex.what() << std::endl; +#endif + } + } else { + *bufSize = LCC_API_PC_IDENTIFIER_SIZE + 1; + } + return result; +} static void mergeLicenses(const vector<LicenseInfo>& licenses, LicenseInfo* license_out) { if (license_out != nullptr) { - int days_left = -1; + int days_left = INT_MIN; for (auto it = licenses.begin(); it != licenses.end(); it++) { // choose the license that expires later... if (!it->has_expiry) { *license_out = *it; break; - } else if (days_left < it->days_left) { + } else if (days_left < (int)it->days_left) { *license_out = *it; days_left = it->days_left; } @@ -38,32 +64,38 @@ } } -EVENT_TYPE acquire_license(const CallerInformations* callerInformation, const LicenseLocation* licenseLocation, - LicenseInfo* license_out) { - license::LicenseReader lr = license::LicenseReader(licenseLocation); +LCC_EVENT_TYPE acquire_license(const CallerInformations* callerInformation, + const LicenseLocation* licenseLocation, LicenseInfo* license_out) { + const license::LicenseReader lr = license::LicenseReader(licenseLocation); vector<license::FullLicenseInfo> licenses; string project; - if (callerInformation != nullptr && strlen(callerInformation->project_name) > 0) { - project = string(callerInformation->project_name); + size_t str_size; + if (callerInformation != nullptr && + (str_size = license::mstrnlen_s(callerInformation->project_name, sizeof callerInformation->project_name)) > 0) { + project = string(callerInformation->project_name, str_size); } else { project = string(LCC_PROJECT_NAME); } license::EventRegistry er = lr.readLicenses(string(project), licenses); - EVENT_TYPE result; + LCC_EVENT_TYPE result; if (licenses.size() > 0) { vector<LicenseInfo> licenses_with_errors; vector<LicenseInfo> licenses_ok; license::LicenseVerifier verifier(er); - for (auto it = licenses.begin(); it != licenses.end(); it++) { - FUNCTION_RETURN signatureValid = verifier.verify_signature(*it); + for (auto full_lic_info_it = licenses.begin(); full_lic_info_it != licenses.end(); full_lic_info_it++) { + if (callerInformation != nullptr) { + full_lic_info_it->m_magic = callerInformation->magic; + } + const FUNCTION_RETURN signatureValid = verifier.verify_signature(*full_lic_info_it); + LicenseInfo licInfo = verifier.toLicenseInfo(*full_lic_info_it); if (signatureValid == FUNC_RET_OK) { - if (verifier.verify_limits(*it) == FUNC_RET_OK) { - licenses_ok.push_back(verifier.toLicenseInfo(*it)); + if (verifier.verify_limits(*full_lic_info_it) == FUNC_RET_OK) { + licenses_ok.push_back(licInfo); } else { - licenses_with_errors.push_back(verifier.toLicenseInfo(*it)); + licenses_with_errors.push_back(licInfo); } } else { - licenses_with_errors.push_back(verifier.toLicenseInfo(*it)); + licenses_with_errors.push_back(licInfo); } } if (licenses_ok.size() > 0) { @@ -89,11 +121,12 @@ #endif if (license_out != nullptr) { - er.exportLastEvents(license_out->status, AUDIT_EVENT_NUM); + er.exportLastEvents(license_out->status, LCC_API_AUDIT_EVENT_NUM); } return result; } -EVENT_TYPE confirm_license(char* product, LicenseLocation licenseLocation) { return LICENSE_OK; } +LCC_EVENT_TYPE confirm_license(char* product, LicenseLocation licenseLocation) { return LICENSE_OK; } -EVENT_TYPE release_license(char* product, LicenseLocation licenseLocation) { return LICENSE_OK; } +LCC_EVENT_TYPE release_license(char* product, LicenseLocation licenseLocation) { return LICENSE_OK; } + -- Gitblit v1.9.1