From 4bd7da9ff2eb06c11b1f54e2b8e2cfb44af56776 Mon Sep 17 00:00:00 2001
From: gcontini <1121667+gcontini@users.noreply.github.com>
Date: 周六, 02 5月 2020 10:20:38 +0800
Subject: [PATCH] rename StringUtils in string_utls

---
 src/library/locate/ExternalDefinition.cpp      |    2 
 src/library/os/linux/execution_environment.cpp |    2 
 src/library/limits/license_verifier.cpp        |    2 
 test/library/os_linux_test.cpp                 |    2 
 src/library/locate/EnvironmentVarData.cpp      |    2 
 src/library/os/linux/dmi_info.cpp              |    2 
 src/library/os/windows/network.cpp             |    2 
 src/inspector/inspector.cpp                    |   66 ++++++++++++++++++++++++++-------
 test/library/os/execution_environment_test.cpp |    2 
 src/library/os/windows/dmi_info.cpp            |    2 
 src/library/base/string_utils.cpp              |    2 
 src/library/locate/EnvironmentVarLocation.cpp  |    2 
 src/library/os/linux/network.cpp               |    2 
 test/library/os/network_test.cpp               |    2 
 src/library/licensecc.cpp                      |    2 
 src/library/LicenseReader.cpp                  |    2 
 include/licensecc/datatypes.h                  |   14 ++++++
 17 files changed, 80 insertions(+), 30 deletions(-)

diff --git a/include/licensecc/datatypes.h b/include/licensecc/datatypes.h
index f99e232..8a229ea 100644
--- a/include/licensecc/datatypes.h
+++ b/include/licensecc/datatypes.h
@@ -95,7 +95,19 @@
  */
 typedef struct {
 	char version[LCC_API_VERSION_LENGTH + 1];  // software version in format xxxx[.xxxx.xxxx] //TODO
-	char project_name[LCC_API_PROJECT_NAME_SIZE + 1];  // name of the project (must correspond to the name in the license)
+	/**
+	 * Name of the feature you want to verify. If empty the default feature will be verified.
+	 * Every project has a default feature that is equal to the project name.
+	 * Every feature has a section in the license file:
+	 * <pre>
+	 * [feature_xx]
+	 * sig=AAAA
+	 * [bb]
+	 * expiry-date
+	 * </pre>
+	 */
+	char feature_name[LCC_API_PROJECT_NAME_SIZE +
+					  1];  // name of the feature you' (must correspond to the name in the license)
 	/**
 	 * this number passed in by the application must correspond to the magic number used when compiling the library.
 	 * See cmake parameter -DLCC_PROJECT_MAGIC_NUM and licensecc_properties.h macro VERIFY_MAGIC
diff --git a/src/inspector/inspector.cpp b/src/inspector/inspector.cpp
index 3ec672c..1c4d0af 100644
--- a/src/inspector/inspector.cpp
+++ b/src/inspector/inspector.cpp
@@ -1,8 +1,13 @@
 #include <iostream>
+#include <vector>
 #include <map>
 #include <unordered_map>
 #include <licensecc/licensecc.h>
 #include <fstream>
+#include <string.h>
+#include "../library/base/string_utils.h"
+#include "../library/ini/SimpleIni.h"
+#include "../library/os/dmi_info.hpp"
 #include "../library/os/cpu_info.hpp"
 #include "../library/os/dmi_info.hpp"
 
@@ -23,10 +28,9 @@
 													 {HV, "Microsoft Hypervisor"},
 													 {V_OTHER, "Other type of vm"}};
 
-const unordered_map<int, string> descByVirt = {
-	{LCC_API_VIRTUALIZATION_SUMMARY::NONE, "No virtualization"},
-	{LCC_API_VIRTUALIZATION_SUMMARY::VM, "Virtual machine"},
-	{LCC_API_VIRTUALIZATION_SUMMARY::CONTAINER, "Container"}};
+const unordered_map<int, string> descByVirt = {{LCC_API_VIRTUALIZATION_SUMMARY::NONE, "No virtualization"},
+											   {LCC_API_VIRTUALIZATION_SUMMARY::VM, "Virtual machine"},
+											   {LCC_API_VIRTUALIZATION_SUMMARY::CONTAINER, "Container"}};
 
 const unordered_map<int, string> descByCloudProvider = {{PROV_UNKNOWN, "Provider unknown"},
 														{ON_PREMISE, "On premise hardware (no cloud)"},
@@ -53,11 +57,27 @@
 	std::copy(fname.begin(), fname.end(), licLocation.licenseData);
 	LCC_EVENT_TYPE result = acquire_license(nullptr, &licLocation, &licenseInfo);
 	if (result == LICENSE_OK) {
-		cout << "license OK" << endl;
+		cout << "default project [" << LCC_PROJECT_NAME << "]: license OK" << endl;
 	} else {
-		cerr << stringByEventType.find(result)->second << endl;
+		cerr << "default project [" << LCC_PROJECT_NAME << "]:" << stringByEventType.find(result)->second << endl;
 	}
-
+	CSimpleIniA ini;
+	ini.LoadFile(fname.c_str());
+	CSimpleIniA::TNamesDepend sections;
+	ini.GetAllSections(sections);
+	CallerInformations callerInformation;
+	for (CSimpleIniA::Entry section : sections) {
+		const string section_name(section.pItem, 15);
+		if (section_name != LCC_PROJECT_NAME) {
+			std::copy(section_name.begin(), section_name.end(), callerInformation.project_name);
+			LCC_EVENT_TYPE result = acquire_license(&callerInformation, &licLocation, &licenseInfo);
+			if (result == LICENSE_OK) {
+				cout << "project [" << section.pItem << "]: license OK" << endl;
+			} else {
+				cerr << "project [" << section.pItem << "]" << stringByEventType.find(result)->second << endl;
+			}
+		}
+	}
 	return result;
 }
 
@@ -75,19 +95,18 @@
 	}
 	cout << "Virtualiz. class :" << descByVirt.find(exec_env_info.virtualization)->second << endl;
 	cout << "Virtualiz. detail:" << descByVirtDetail.find(exec_env_info.virtualization_detail)->second << endl;
-	cout << "Cloud provider   :" << descByCloudProvider.find(exec_env_info.cloud_provider)->second << endl
-		 << "=============" << endl;
+	cout << "Cloud provider   :" << descByCloudProvider.find(exec_env_info.cloud_provider)->second << endl;
+
 	license::os::CpuInfo cpu;
 	cout << "Cpu Vendor       :" << cpu.vendor() << endl;
 	cout << "Cpu Brand        :" << cpu.brand() << endl;
 	cout << "Cpu hypervisor   :" << cpu.is_hypervisor_set() << endl;
 	cout << "Cpu model        :0x" << std::hex << ((long)cpu.model()) << std::dec << endl;
 	license::os::DmiInfo dmi_info;
-	cout << "Bios vendor     :" << dmi_info.bios_vendor() << endl;
-	cout << "Bios description:" << dmi_info.bios_description() << endl;
-	cout << "System vendor   :" << dmi_info.sys_vendor() << endl << endl;
-
-
+	cout << "Bios vendor      :" << dmi_info.bios_vendor() << endl;
+	cout << "Bios description :" << dmi_info.bios_description() << endl;
+	cout << "System vendor    :" << dmi_info.sys_vendor() << endl << endl;
+	cout << "==================" << endl;
 	if (argc == 2) {
 		const string fname(argv[1]);
 		ifstream license_file(fname);
@@ -97,4 +116,23 @@
 			cerr << "license file :" << fname << " not found." << endl;
 		}
 	}
+	bool find_license_with_env_var = FIND_LICENSE_WITH_ENV_VAR;
+	if (find_license_with_env_var) {
+		char* env_var_value = getenv(LCC_LICENSE_LOCATION_ENV_VAR);
+		if (env_var_value != nullptr && env_var_value[0] != '\0') {
+			cout << "environment variable [" << LCC_LICENSE_LOCATION_ENV_VAR << "] value [" << env_var_value << "]"
+				 << endl;
+			const vector<string> declared_licenses = license::split_string(string(env_var_value), ';');
+			for (string fname : declared_licenses) {
+				ifstream license_file(fname);
+				if (license_file.good()) {
+					verifyLicense(fname);
+				} else {
+					cerr << "license file :" << fname << " not found." << endl;
+				}
+			}
+		} else {
+			cout << "environment variable [" << LCC_LICENSE_LOCATION_ENV_VAR << "] configured but not defined." << endl;
+		}
+	}
 }
diff --git a/src/library/LicenseReader.cpp b/src/library/LicenseReader.cpp
index 673bb1d..5d071c3 100644
--- a/src/library/LicenseReader.cpp
+++ b/src/library/LicenseReader.cpp
@@ -26,7 +26,7 @@
 
 #include "base/base.h"
 #include "LicenseReader.hpp"
-#include "base/StringUtils.h"
+#include "base/string_utils.h"
 #include "base/logger.h"
 #include "locate/LocatorFactory.hpp"
 
diff --git a/src/library/base/string_utils.cpp b/src/library/base/string_utils.cpp
index 1d5d27b..74b0458 100644
--- a/src/library/base/string_utils.cpp
+++ b/src/library/base/string_utils.cpp
@@ -13,7 +13,7 @@
 #include <algorithm>
 #include <stdexcept>
 #include <regex>
-#include "StringUtils.h"
+#include "string_utils.h"
 
 #ifdef _WIN32
 #include <time.h>  //mktime under windows
diff --git a/src/library/licensecc.cpp b/src/library/licensecc.cpp
index dd377e1..087d7cf 100644
--- a/src/library/licensecc.cpp
+++ b/src/library/licensecc.cpp
@@ -21,7 +21,7 @@
 #include "hw_identifier/hw_identifier_facade.hpp"
 #include "os/execution_environment.hpp"
 #include "limits/license_verifier.hpp"
-#include "base/StringUtils.h"
+#include "base/string_utils.h"
 #include "LicenseReader.hpp"
 
 using namespace std;
diff --git a/src/library/limits/license_verifier.cpp b/src/library/limits/license_verifier.cpp
index 71c2cc8..cfd89c0 100644
--- a/src/library/limits/license_verifier.cpp
+++ b/src/library/limits/license_verifier.cpp
@@ -9,7 +9,7 @@
 #include <licensecc_properties.h>
 
 #include "license_verifier.hpp"
-#include "../base/StringUtils.h"
+#include "../base/string_utils.h"
 #include "../os/signature_verifier.hpp"
 #include "../hw_identifier/hw_identifier_facade.hpp"
 
diff --git a/src/library/locate/EnvironmentVarData.cpp b/src/library/locate/EnvironmentVarData.cpp
index 707d6a5..21dc9ea 100644
--- a/src/library/locate/EnvironmentVarData.cpp
+++ b/src/library/locate/EnvironmentVarData.cpp
@@ -16,7 +16,7 @@
 
 #include "../base/base64.h"
 #include "../base/EventRegistry.h"
-#include "../base/StringUtils.h"
+#include "../base/string_utils.h"
 
 namespace license {
 namespace locate {
diff --git a/src/library/locate/EnvironmentVarLocation.cpp b/src/library/locate/EnvironmentVarLocation.cpp
index e74228a..e029483 100644
--- a/src/library/locate/EnvironmentVarLocation.cpp
+++ b/src/library/locate/EnvironmentVarLocation.cpp
@@ -7,7 +7,7 @@
 
 #include <licensecc_properties.h>
 
-#include "../base/StringUtils.h"
+#include "../base/string_utils.h"
 #include "EnvironmentVarLocation.hpp"
 #include "../base/file_utils.hpp"
 
diff --git a/src/library/locate/ExternalDefinition.cpp b/src/library/locate/ExternalDefinition.cpp
index a5309de..a7386de 100644
--- a/src/library/locate/ExternalDefinition.cpp
+++ b/src/library/locate/ExternalDefinition.cpp
@@ -14,7 +14,7 @@
 
 #include "../base/base64.h"
 #include "../base/EventRegistry.h"
-#include "../base/StringUtils.h"
+#include "../base/string_utils.h"
 
 #include "ExternalDefinition.hpp"
 #include "../base/file_utils.hpp"
diff --git a/src/library/os/linux/dmi_info.cpp b/src/library/os/linux/dmi_info.cpp
index c5d388d..e03cbd4 100644
--- a/src/library/os/linux/dmi_info.cpp
+++ b/src/library/os/linux/dmi_info.cpp
@@ -1,6 +1,6 @@
 
 #include "../../base/file_utils.hpp"
-#include "../../base/StringUtils.h"
+#include "../../base/string_utils.h"
 
 #include "../dmi_info.hpp"
 
diff --git a/src/library/os/linux/execution_environment.cpp b/src/library/os/linux/execution_environment.cpp
index a00df29..75520eb 100644
--- a/src/library/os/linux/execution_environment.cpp
+++ b/src/library/os/linux/execution_environment.cpp
@@ -18,7 +18,7 @@
 #include "../cpu_info.hpp"
 #include "../execution_environment.hpp"
 #include "../../base/file_utils.hpp"
-#include "../../base/StringUtils.h"
+#include "../../base/string_utils.h"
 
 namespace license {
 namespace os {
diff --git a/src/library/os/linux/network.cpp b/src/library/os/linux/network.cpp
index 1f7a76a..4e8ccda 100644
--- a/src/library/os/linux/network.cpp
+++ b/src/library/os/linux/network.cpp
@@ -28,7 +28,7 @@
 #include <string.h>
 #include <memory.h>
 
-#include "../../base/StringUtils.h"
+#include "../../base/string_utils.h"
 #include "../../base/logger.h"
 #include "../network.hpp"
 
diff --git a/src/library/os/windows/dmi_info.cpp b/src/library/os/windows/dmi_info.cpp
index 0b9103a..618be23 100644
--- a/src/library/os/windows/dmi_info.cpp
+++ b/src/library/os/windows/dmi_info.cpp
@@ -8,7 +8,7 @@
 #include <windows.h>
 #include "isvm/BIOSReader.h"
 #include "isvm/Native.h"
-#include "../../base/StringUtils.h"
+#include "../../base/string_utils.h"
 #include "../dmi_info.hpp"
 
 namespace license {
diff --git a/src/library/os/windows/network.cpp b/src/library/os/windows/network.cpp
index 6334b9d..f3ccd2d 100644
--- a/src/library/os/windows/network.cpp
+++ b/src/library/os/windows/network.cpp
@@ -17,7 +17,7 @@
 #include <stdio.h>
 //#pragma comment(lib, "IPHLPAPI.lib")
 
-#include "../../base/StringUtils.h"
+#include "../../base/string_utils.h"
 #include "../../base/logger.h"
 #include "../network.hpp"
 
diff --git a/test/library/os/execution_environment_test.cpp b/test/library/os/execution_environment_test.cpp
index 14a2abc..be9256c 100644
--- a/test/library/os/execution_environment_test.cpp
+++ b/test/library/os/execution_environment_test.cpp
@@ -5,7 +5,7 @@
 
 #include <licensecc_properties.h>
 #include <licensecc_properties_test.h>
-#include "../../../src/library/base/StringUtils.h"
+#include "../../../src/library/base/string_utils.h"
 #include "../../../src/library/os/network.hpp"
 #include "../../../src/library/os/execution_environment.hpp"
 
diff --git a/test/library/os/network_test.cpp b/test/library/os/network_test.cpp
index f5a7483..50e4254 100644
--- a/test/library/os/network_test.cpp
+++ b/test/library/os/network_test.cpp
@@ -5,7 +5,7 @@
 
 #include <licensecc_properties.h>
 #include <licensecc_properties_test.h>
-#include "../../../src/library/base/StringUtils.h"
+#include "../../../src/library/base/string_utils.h"
 #include "../../../src/library/os/network.hpp"
 #include "../../../src/library/os/execution_environment.hpp"
 
diff --git a/test/library/os_linux_test.cpp b/test/library/os_linux_test.cpp
index 510d50f..68d3c76 100644
--- a/test/library/os_linux_test.cpp
+++ b/test/library/os_linux_test.cpp
@@ -5,7 +5,7 @@
 
 #include <licensecc_properties.h>
 #include <licensecc_properties_test.h>
-#include "../../src/library/base/StringUtils.h"
+#include "../../src/library/base/string_utils.h"
 #include "../../src/library/os/os.h"
 #include "../../src/library/os/execution_environment.hpp"
 

--
Gitblit v1.9.1