open-license-manager
2014-08-05 82d408374c8ece8f13b50b93ff24ab9633de14f0
src/library/LicenseReader.cpp
@@ -18,12 +18,13 @@
#include <fstream>
#include <sstream>
#include <stdlib.h>
#include "pc-identifiers.h"
#include "LicenseReader.h"
#include "base/StringUtils.h"
#include "base/public-key.h"
#include <build_properties.h>
#include "os/os.hpp"
#include "os/os-cpp.h"
namespace license {
@@ -47,21 +48,29 @@
EventRegistry FullLicenseInfo::validate(int sw_version) {
   EventRegistry er;
   OsFunctions::initialize();
   os_initialize();
   bool sigVerified = OsFunctions::verifySignature(printForSign().c_str(),
         license_signature.c_str());
   if (sigVerified) {
      er.addEvent(LICENSE_VERIFIED, INFO);
      er.addEvent(LICENSE_VERIFIED, SVRT_INFO);
   } else {
      er.addEvent(LICENSE_CORRUPTED, SEVERITY_ERROR);
      er.addEvent(LICENSE_CORRUPTED, SVRT_ERROR);
   }
   if (has_expiry) {
      time_t now = time(NULL);
      if (expires_on() < now) {
         er.addEvent(PRODUCT_EXPIRED, SEVERITY_ERROR, "");
         er.addEvent(PRODUCT_EXPIRED, SVRT_ERROR, "");
      }
      if (valid_from() > now) {
         er.addEvent(PRODUCT_EXPIRED, SEVERITY_ERROR);
         er.addEvent(PRODUCT_EXPIRED, SVRT_ERROR);
      }
   }
   if (has_client_sig) {
      PcSignature str_code;
      strncpy(str_code, client_signature.c_str(), sizeof(str_code));
      EVENT_TYPE event = validate_pc_signature(str_code);
      if (event != LICENSE_OK) {
         er.addEvent(event, SVRT_ERROR);
      }
   }
   return er;
@@ -105,7 +114,7 @@
      ini.Reset();
      SI_Error rc = ini.LoadFile((*it).c_str());
      if (rc < 0) {
         result.addEvent(FILE_FORMAT_NOT_RECOGNIZED, SEVERITY_WARN, *it);
         result.addEvent(FILE_FORMAT_NOT_RECOGNIZED, SVRT_WARN, *it);
         continue;
      } else {
         loadAtLeastOneFile = true;
@@ -113,7 +122,7 @@
      const char* productNamePtr = product.c_str();
      int sectionSize = ini.GetSectionSize(productNamePtr);
      if (sectionSize <= 0) {
         result.addEvent(PRODUCT_NOT_LICENSED, SEVERITY_WARN, *it);
         result.addEvent(PRODUCT_NOT_LICENSED, SVRT_WARN, *it);
         continue;
      } else {
         atLeastOneProductLicensed = true;
@@ -123,7 +132,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,12 +147,22 @@
         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 {
         result.addEvent(LICENSE_MALFORMED, SEVERITY_WARN, *it);
         result.addEvent(LICENSE_MALFORMED, SVRT_WARN, *it);
      }
   }
   if (!loadAtLeastOneFile) {
@@ -174,11 +193,11 @@
            for (auto it = existing_pos.begin(); it != existing_pos.end();
                  ++it) {
               diskFiles.push_back(*it);
               eventRegistry.addEvent(LICENSE_FILE_FOUND, INFO, *it);
               eventRegistry.addEvent(LICENSE_FILE_FOUND, SVRT_INFO, *it);
            }
         }
      } else {
         eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SEVERITY_WARN,
         eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SVRT_WARN,
               varName);
      }
   }
@@ -204,19 +223,19 @@
               for (auto it = existing_pos.begin();
                     it != existing_pos.end(); ++it) {
                  diskFiles.push_back(*it);
                  eventRegistry.addEvent(LICENSE_FILE_FOUND, INFO, *it);
                  eventRegistry.addEvent(LICENSE_FILE_FOUND, SVRT_INFO, *it);
               }
            } else {
               eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND,
                     SEVERITY_WARN, env_var_value);
                     SVRT_WARN, env_var_value);
            }
         } else {
            eventRegistry.addEvent(ENVIRONMENT_VARIABLE_NOT_DEFINED,
                  SEVERITY_WARN);
                  SVRT_WARN);
         }
      } else {
         eventRegistry.addEvent(ENVIRONMENT_VARIABLE_NOT_DEFINED,
               SEVERITY_WARN);
               SVRT_WARN);
      }
   }
   return licenseFileFoundWithEnvVariable;
@@ -233,9 +252,9 @@
      if (f.good()) {
         foundNearModule = true;
         diskFiles.push_back(temptativeLicense);
         eventRegistry.addEvent(LICENSE_FILE_FOUND, INFO, temptativeLicense);
         eventRegistry.addEvent(LICENSE_FILE_FOUND, SVRT_INFO, temptativeLicense);
      } else {
         eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SEVERITY_WARN,
         eventRegistry.addEvent(LICENSE_FILE_NOT_FOUND, SVRT_WARN,
               temptativeLicense);
      }
      f.close();
@@ -285,21 +304,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;
    }*/
   string result = oss.str();
   }
   if (this->extra_data.length() > 0) {
      oss << "|" << extra_data;
   }
#ifdef _DEBUG
   cout << "[" << oss.str() << "]" << endl;
   return result;
#endif
   return oss.str();
}