From af928739ea648f8f3a5d64771d236fe7498eaf26 Mon Sep 17 00:00:00 2001 From: open-license-manager <rillf@maildrop.cc> Date: 周三, 16 4月 2014 06:24:03 +0800 Subject: [PATCH] signature OK --- src/library/os/linux/os-linux.cpp | 80 +++++++++---- test/functional/date_test.cpp | 50 ++++++++ src/library/LicenseReader.cpp | 80 ++++++------ src/license-generator/license-generator.cpp | 2 test/functional/generate-license.cpp | 39 ++++++ test/functional/hijiaking_test.cpp | 33 +++++ src/library/license++.cpp | 4 src/library/os/os.hpp | 1 src/library/LicenseReader.h | 15 +- test/functional/generate-license.h | 7 + 10 files changed, 236 insertions(+), 75 deletions(-) diff --git a/src/library/LicenseReader.cpp b/src/library/LicenseReader.cpp index 7ad0ede..174bdb0 100644 --- a/src/library/LicenseReader.cpp +++ b/src/library/LicenseReader.cpp @@ -28,10 +28,10 @@ namespace license { FullLicenseInfo::FullLicenseInfo(const string& source, const string& product, - const string& license_signature, int licenseVersion, // - time_t from_date, time_t to_date, // - const string& client_signature, unsigned int from_sw_version, - unsigned int to_sw_version, const string& extra_data) : + 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) : source(source), product(product), // license_signature(license_signature), license_version(licenseVersion), // from_date(from_date), to_date(to_date), // @@ -47,6 +47,7 @@ EventRegistry FullLicenseInfo::validate(int sw_version) { EventRegistry er; + OsFunctions::initialize(); bool sigVerified = OsFunctions::verifySignature(printForSign().c_str(), license_signature.c_str()); if (sigVerified) { @@ -56,10 +57,10 @@ } if (has_expiry) { time_t now = time(NULL); - if (this->to_date < now) { + if (expires_on() < now) { er.addEvent(PRODUCT_EXPIRED, SEVERITY_ERROR, ""); } - if (this->from_date > now) { + if (valid_from() > now) { er.addEvent(PRODUCT_EXPIRED, SEVERITY_ERROR); } } @@ -77,9 +78,9 @@ license->expiry_date[0] = '\0'; license->days_left = 999999; } else { - tm * timeinfo = localtime(&to_date); - strftime(license->expiry_date, 11, "%Y-%m-%d", timeinfo); - double secs = difftime(time(NULL), to_date); + strncpy(license->expiry_date, to_date.c_str(), 11); + double secs = difftime(time(NULL), + seconds_from_epoch(to_date.c_str())); license->days_left = (int) secs / 60 * 60 * 24; } } @@ -87,16 +88,6 @@ LicenseReader::LicenseReader(const LicenseLocation& licenseLocation) : licenseLocation(licenseLocation) { -} - -time_t LicenseReader::read_date(const char * productName, const char * ini_key, - const CSimpleIniA& ini) const { - string from_date_str = ini.GetValue(productName, ini_key); - time_t from_date = FullLicenseInfo::UNUSED_TIME; - if (from_date_str.length() > 0) { - from_date = seconds_from_epoch(from_date_str.c_str()); - } - return from_date; } EventRegistry LicenseReader::readLicenses(const string &product, @@ -141,8 +132,12 @@ long license_version = ini.GetLongValue(productNamePtr, "license_version", -1); if (license_signature != NULL && license_version > 0) { - time_t from_date = read_date(productNamePtr, "from_date", ini); - time_t to_date = read_date(productNamePtr, "to_date", ini); + string from_date = trim_copy( + ini.GetValue(productNamePtr, "from_date", + FullLicenseInfo::UNUSED_TIME)); + string to_date = trim_copy( + ini.GetValue(productNamePtr, "to_date", + FullLicenseInfo::UNUSED_TIME)); FullLicenseInfo licInfo(*it, product, license_signature, (int) license_version, from_date, to_date); licenseInfoOut.push_back(licInfo); @@ -290,19 +285,22 @@ oss << toupper_copy(trim_copy(this->product)); oss << SHARED_RANDOM ; - if (has_client_sig) { - oss << trim_copy(this->client_signature); - } - if (has_versions) { - oss << "|" << this->from_sw_version << "-" << this->to_sw_version; - } + /*if (has_client_sig) { + oss << trim_copy(this->client_signature); + } + if (has_versions) { + oss << "|" << this->from_sw_version << "-" << this->to_sw_version; + }*/ if (has_expiry) { - oss << "|" << this->from_date << "-" << this->to_date; - } - if (this->extra_data.length() > 0) { - oss << "|" << extra_data; - } - return oss.str(); + oss << "|" << this->from_date << "|" << this->to_date; + }/* + if (this->extra_data.length() > 0) { + oss << "|" << extra_data; + }*/ + string result = oss.str(); + cout << "[" << oss.str() << "]" << endl; + return result; + } void FullLicenseInfo::printAsIni(ostream & a_ostream) const { @@ -323,15 +321,11 @@ ini.SetLongValue(product.c_str(), "to_sw_version", to_sw_version); } - char buff[20]; if (this->from_date != UNUSED_TIME) { - strftime(buff, 20, "%Y-%m-%d", localtime(&this->from_date)); - ini.SetValue(product.c_str(), "from_date", buff); + ini.SetValue(product.c_str(), "from_date", from_date.c_str()); } - char buff2[20]; if (this->to_date != UNUSED_TIME) { - strftime(buff2, 20, "%Y-%m-%d", localtime(&this->to_date)); - ini.SetValue(product.c_str(), "to_date", buff2); + ini.SetValue(product.c_str(), "to_date", to_date.c_str()); } if (this->extra_data.length() > 0) { ini.SetValue(product.c_str(), "extra_data", this->extra_data.c_str()); @@ -339,5 +333,13 @@ ini.Save(sw); } +time_t FullLicenseInfo::expires_on() const { + return seconds_from_epoch(this->to_date.c_str()); +} + +time_t FullLicenseInfo::valid_from() const { + return seconds_from_epoch(this->from_date.c_str()); +} + } diff --git a/src/library/LicenseReader.h b/src/library/LicenseReader.h index bcc6022..a172e1a 100644 --- a/src/library/LicenseReader.h +++ b/src/library/LicenseReader.h @@ -25,8 +25,8 @@ string product; string license_signature; int license_version; - time_t from_date; - time_t to_date; + string from_date; + string to_date; bool has_expiry; unsigned int from_sw_version; unsigned int to_sw_version; @@ -35,22 +35,23 @@ bool has_client_sig; string extra_data; - static const time_t UNUSED_TIME = (time_t) 0; + static constexpr const char* UNUSED_TIME = "0000-00-00"; static const unsigned int UNUSED_SOFTWARE_VERSION = 0; FullLicenseInfo(const string& source, const string& product, const string& license_signature, int licenseVersion, - time_t from_date = UNUSED_TIME, - time_t to_date = UNUSED_TIME, // + string from_date = UNUSED_TIME, + string to_date = UNUSED_TIME, // const string& client_signature = "", // unsigned int from_sw_version = UNUSED_SOFTWARE_VERSION, unsigned int to_sw_version = UNUSED_SOFTWARE_VERSION, const string& extra_data = ""); string printForSign() const; void printAsIni(ostream & a_ostream) const; - void toLicenseInfo(LicenseInfo* license) const; EventRegistry validate(int sw_version); + time_t expires_on() const; + time_t valid_from() const; }; /** * This class it is responsible to read the licenses from the disk @@ -72,8 +73,6 @@ */ class LicenseReader { private: - time_t read_date(const char * productName, const char * ini_key, - const CSimpleIniA& ini) const; const LicenseLocation licenseLocation; EventRegistry getLicenseDiskFiles(vector<string>& diskFiles); vector<string> filterExistingFiles(vector<string> licensePositions); diff --git a/src/library/license++.cpp b/src/library/license++.cpp index 03f2f2c..414fd37 100644 --- a/src/library/license++.cpp +++ b/src/library/license++.cpp @@ -31,8 +31,8 @@ if (!it->has_expiry) { it->toLicenseInfo(license); break; - } else if (curLicense_exp < it->to_date) { - curLicense_exp = it->to_date; + } else if (curLicense_exp < it->expires_on()) { + curLicense_exp = it->expires_on(); it->toLicenseInfo(license); } } diff --git a/src/library/os/linux/os-linux.cpp b/src/library/os/linux/os-linux.cpp index 2028d47..f818677 100644 --- a/src/library/os/linux/os-linux.cpp +++ b/src/library/os/linux/os-linux.cpp @@ -13,7 +13,8 @@ #include <openssl/evp.h> #include <openssl/bio.h> #include <openssl/pem.h> - +#include <openssl/err.h> +#include <iostream> namespace license { using namespace std; @@ -63,21 +64,22 @@ } bool OsFunctions::verifySignature(const char* stringToVerify, - const char* signature) { + const char* signatureB64) { EVP_MD_CTX *mdctx = NULL; char *pubKey = PUBLIC_KEY ; BIO* bio = BIO_new_mem_buf((void*) (pubKey), strlen(pubKey)); - RSA *rsa = PEM_read_bio_RSAPublicKey(bio, NULL,NULL,NULL); + RSA *rsa = PEM_read_bio_RSAPublicKey(bio, NULL, NULL, NULL); BIO_free(bio); if (rsa == NULL) { + cout<<"cippa!"<<endl; throw new logic_error("Error reading public key"); } EVP_PKEY *pkey = EVP_PKEY_new(); - EVP_PKEY_assign_RSA(pkey, rsa); + cout << "test:" <<EVP_PKEY_assign_RSA(pkey, rsa)<<endl; /*BIO* bo = BIO_new(BIO_s_mem()); BIO_write(bo, pubKey, strlen(pubKey)); @@ -87,6 +89,18 @@ //RSA* rsa = EVP_PKEY_get1_RSA( key ); //RSA * pubKey = d2i_RSA_PUBKEY(NULL, <der encoded byte stream pointer>, <num bytes>); + unsigned char buffer[129]; + BIO* b64 = BIO_new(BIO_f_base64()); + BIO* encoded_signature = BIO_new_mem_buf((void *) signatureB64, + strlen(signatureB64)); + BIO* biosig = BIO_push(b64, encoded_signature); + BIO_set_flags(biosig, BIO_FLAGS_BASE64_NO_NL); //Do not use newlines to flush buffer + unsigned int len = BIO_read(biosig, (void *) buffer, strlen(signatureB64)); + //Can test here if len == decodeLen - if not, then return an error + buffer[len] = 0; + + BIO_free_all(biosig); + /* Create the Message Digest Context */ if (!(mdctx = EVP_MD_CTX_create())) { throw new logic_error("Error creating context"); @@ -94,19 +108,35 @@ if (1 != EVP_DigestVerifyInit(mdctx, NULL, EVP_sha256(), NULL, pkey)) { throw new logic_error("Error initializing digest"); } - + int en=strlen(stringToVerify); if (1 != EVP_DigestVerifyUpdate(mdctx, stringToVerify, - strlen(stringToVerify))) { + en)) { throw new logic_error("Error initializing digest"); } - if (1 - == EVP_DigestVerifyFinal(mdctx, (unsigned char *) signature, - (unsigned long int) strlen(signature))) { - return true; + bool result; + int res= EVP_DigestVerifyFinal(mdctx, buffer, len); + if (1 == res) { + result = true; } else { + result = false; + } + if (pkey) { + EVP_PKEY_free(pkey); + } + if (mdctx) { + EVP_MD_CTX_destroy(mdctx); + } + return result; +} - return false; +void OsFunctions::initialize() { + static bool initialized = false; + if (!initialized) { + initialized = true; + ERR_load_ERR_strings(); + ERR_load_crypto_strings(); + OpenSSL_add_all_algorithms(); } } @@ -115,20 +145,20 @@ // bool rc = true; /*__asm__ ( - "push %edx\n" - "push %ecx\n" - "push %ebx\n" - "mov %eax, 'VMXh'\n" - "mov %ebx, 0\n" // any value but not the MAGIC VALUE - "mov %ecx, 10\n"// get VMWare version - "mov %edx, 'VX'\n"// port number - "in %eax, dx\n"// read port on return EAX returns the VERSION - "cmp %ebx, 'VMXh'\n"// is it a reply from VMWare? - "setz [rc] \n"// set return value - "pop %ebx \n" - "pop %ecx \n" - "pop %edx \n" - );*/ + "push %edx\n" + "push %ecx\n" + "push %ebx\n" + "mov %eax, 'VMXh'\n" + "mov %ebx, 0\n" // any value but not the MAGIC VALUE + "mov %ecx, 10\n"// get VMWare version + "mov %edx, 'VX'\n"// port number + "in %eax, dx\n"// read port on return EAX returns the VERSION + "cmp %ebx, 'VMXh'\n"// is it a reply from VMWare? + "setz [rc] \n"// set return value + "pop %ebx \n" + "pop %ecx \n" + "pop %edx \n" + );*/ return NONE; } diff --git a/src/library/os/os.hpp b/src/library/os/os.hpp index dfcbc60..d8a9795 100644 --- a/src/library/os/os.hpp +++ b/src/library/os/os.hpp @@ -34,6 +34,7 @@ class OsFunctions { public: + static void initialize(); static vector<AdapterInfo> getAdapterInfos(); static vector<DiskInfo> getDiskInfos(); static string getModuleName(); diff --git a/src/license-generator/license-generator.cpp b/src/license-generator/license-generator.cpp index 5556711..e1656f3 100644 --- a/src/license-generator/license-generator.cpp +++ b/src/license-generator/license-generator.cpp @@ -210,7 +210,7 @@ ostringstream oss; bt::time_facet *facet = new bt::time_facet("%Y-%m-%d"); oss.imbue(locale(cout.getloc(), facet)); - oss << pt << endl; + oss << pt; //delete (facet); return oss.str(); } diff --git a/test/functional/date_test.cpp b/test/functional/date_test.cpp new file mode 100644 index 0000000..92b981e --- /dev/null +++ b/test/functional/date_test.cpp @@ -0,0 +1,50 @@ +#define BOOST_TEST_MODULE standard_license_test +//#define BOOST_TEST_MAIN +#define BOOST_TEST_DYN_LINK +#include <boost/test/unit_test.hpp> +#include "../../../src/license-generator/license-generator.h" +#include "../../../src/library/api/license++.h" +#include <build_properties.h> +#include <boost/filesystem.hpp> +#include "../../src/library/ini/SimpleIni.h" +#include "generate-license.h" + +namespace fs = boost::filesystem; +using namespace license; +using namespace std; + +BOOST_AUTO_TEST_CASE( license_not_expired ) { + const string licLocation(PROJECT_TEST_TEMP_DIR "/not_expired.lic"); + vector<string> extraArgs; + extraArgs.push_back("-e"); + extraArgs.push_back("2050-10-10"); + generate_license(licLocation, extraArgs); + /* */ + LicenseInfo license; + LicenseLocation licenseLocation; + licenseLocation.openFileNearModule = false; + licenseLocation.licenseFileLocation = licLocation.c_str(); + licenseLocation.environmentVariableName = ""; + EVENT_TYPE result = acquire_license("TEST", licenseLocation, &license); + BOOST_CHECK_EQUAL(result, LICENSE_OK); + BOOST_CHECK_EQUAL(license.has_expiry, true); + BOOST_CHECK_EQUAL(license.linked_to_pc, false); +} + +BOOST_AUTO_TEST_CASE( license_expired ) { + const string licLocation(PROJECT_TEST_TEMP_DIR "/expired.lic"); + vector<string> extraArgs; + extraArgs.push_back("-e"); + extraArgs.push_back("2013-10-10"); + generate_license(licLocation, extraArgs); + /* */ + LicenseInfo license; + LicenseLocation licenseLocation; + licenseLocation.openFileNearModule = false; + licenseLocation.licenseFileLocation = licLocation.c_str(); + licenseLocation.environmentVariableName = ""; + EVENT_TYPE result = acquire_license("TEST", licenseLocation, &license); + BOOST_CHECK_EQUAL(result, PRODUCT_EXPIRED); + BOOST_CHECK_EQUAL(license.has_expiry, true); + BOOST_CHECK_EQUAL(license.linked_to_pc, false); +} diff --git a/test/functional/generate-license.cpp b/test/functional/generate-license.cpp new file mode 100644 index 0000000..8ece3cf --- /dev/null +++ b/test/functional/generate-license.cpp @@ -0,0 +1,39 @@ +/* + * generate-license.c + * + * Created on: Apr 13, 2014 + * Author: devel + */ + +#include <boost/test/unit_test.hpp> +#include "../../../src/license-generator/license-generator.h" +#include <build_properties.h> +#include <boost/filesystem.hpp> +#include "../../src/library/ini/SimpleIni.h" +#include "generate-license.h" + +namespace fs = boost::filesystem; +using namespace license; +using namespace std; + +void generate_license(const string& fname, const vector<string>& other_args) { + int argc = 4+other_args.size(); + const char** argv = new const char*[argc + 1]; + unsigned int i=0; + argv[i++] = "lic-generator"; + for(;i<=other_args.size();i++){ + argv[i] = other_args[i-1].c_str(); + } + argv[i++] = "-o"; + argv[i++] = fname.c_str(); + argv[i++] = "TEST"; + int retCode = LicenseGenerator::generateLicense(argc, argv); + delete (argv); + BOOST_CHECK_EQUAL(retCode, 0); + BOOST_ASSERT(fs::exists(fname)); + CSimpleIniA ini; + SI_Error rc = ini.LoadFile(fname.c_str()); + BOOST_CHECK_GE(rc,0); + int sectionSize = ini.GetSectionSize("TEST"); + BOOST_CHECK_GT(sectionSize,0); +} diff --git a/test/functional/generate-license.h b/test/functional/generate-license.h new file mode 100644 index 0000000..c35dabd --- /dev/null +++ b/test/functional/generate-license.h @@ -0,0 +1,7 @@ + + +#include<string> +#include<vector> + +using namespace std; +void generate_license(const string& fname, const vector<string>& other_args) ; diff --git a/test/functional/hijiaking_test.cpp b/test/functional/hijiaking_test.cpp new file mode 100644 index 0000000..d8317e6 --- /dev/null +++ b/test/functional/hijiaking_test.cpp @@ -0,0 +1,33 @@ +#define BOOST_TEST_MODULE standard_license_test +//#define BOOST_TEST_MAIN +#define BOOST_TEST_DYN_LINK +#include <boost/test/unit_test.hpp> +#include "../../../src/license-generator/license-generator.h" +#include "../../../src/library/api/license++.h" +#include <build_properties.h> +#include <boost/filesystem.hpp> +#include "../../src/library/ini/SimpleIni.h" +#include "generate-license.h" + +namespace fs = boost::filesystem; +using namespace license; +using namespace std; + + +BOOST_AUTO_TEST_CASE( standard_lic_file ) { + const string licLocation(PROJECT_TEST_TEMP_DIR "/standard_license.lic"); + vector<string> extraArgs; + generate_license(licLocation, extraArgs); + /* */ + LicenseInfo license; + LicenseLocation licenseLocation; + licenseLocation.openFileNearModule=false; + licenseLocation.licenseFileLocation = licLocation.c_str(); + licenseLocation.environmentVariableName = ""; + EVENT_TYPE result = acquire_license("TEST", + licenseLocation, & license); + BOOST_CHECK_EQUAL(result, LICENSE_OK); + BOOST_CHECK_EQUAL(license.has_expiry, false); + BOOST_CHECK_EQUAL(license.linked_to_pc, false); +} + -- Gitblit v1.9.1