mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 02:00:34 +05:00
Improve new MG license mechanism to be binary compatible 2.14/2.15
This commit is contained in:
parent
426c37e4f6
commit
1117f6b618
@ -431,11 +431,74 @@ namespace SMESHUtils_MGLicenseKeyGen // API implementation
|
|||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Unlock a specific MeshGems product (for products called as a library)
|
||||||
|
* \param [in] product - product of MeshGems to unlock
|
||||||
|
* \param [out] error - return error description
|
||||||
|
* \return bool - is a success
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
bool UnlockProduct( const std::string& product, std::string& error )
|
||||||
|
{
|
||||||
|
MESSAGE("SMESH UnlockProduct: " << product);
|
||||||
|
LibraryFile libraryFile;
|
||||||
|
if ( !loadLibrary( error, libraryFile ))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
bool ok = false;
|
||||||
|
// get the key from KeyGen
|
||||||
|
std::string key = SMESHUtils_MGLicenseKeyGen::GetKey(error);
|
||||||
|
typedef int (*SignFun)(const char* );
|
||||||
|
|
||||||
|
// specific function to unlock each product
|
||||||
|
std::string function = "meshgems_" + product + "_unlock_product";
|
||||||
|
|
||||||
|
SignFun signFun = (SignFun) GetProc( theLibraryHandle, function.c_str() );
|
||||||
|
if ( !signFun )
|
||||||
|
{
|
||||||
|
if ( ! getLastError( error ))
|
||||||
|
error = SMESH_Comment( "Can't find symbol '") << function << "' in '" << getenv( theEnvVar ) << "'";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SMESH_TRY;
|
||||||
|
|
||||||
|
int status = signFun( key.c_str() );
|
||||||
|
// MeshGems status: 0: OK, 1: warning, -1: error
|
||||||
|
ok = status >= 0;
|
||||||
|
|
||||||
|
SMESH_CATCH( SMESH::returnError );
|
||||||
|
|
||||||
|
if ( !error.empty() )
|
||||||
|
{
|
||||||
|
ok = false;
|
||||||
|
}
|
||||||
|
else if ( !ok )
|
||||||
|
error = "UnlockProduct() failed (located in '" + libraryFile._name + "')";
|
||||||
|
}
|
||||||
|
return ok;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Sign a CAD (or don't do it if env MESHGEMS_OLD_STYLE is set)
|
||||||
|
* \param [in] meshgems_cad - pointer to a MG CAD object (meshgems_cad_t)
|
||||||
|
* \param [out] error - return error description
|
||||||
|
* \return bool - is a success
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
bool SignCAD( void* meshgems_cad, std::string& error )
|
bool SignCAD( void* meshgems_cad, std::string& error )
|
||||||
{
|
{
|
||||||
const char *meshGemsOldStyleEnvVar( getenv( MESHGEMS_OLD_STYLE ) );
|
const char *meshGemsOldStyleEnvVar( getenv( MESHGEMS_OLD_STYLE ) );
|
||||||
if ( !meshGemsOldStyleEnvVar || strlen(meshGemsOldStyleEnvVar) == 0 )
|
if ( !meshGemsOldStyleEnvVar || strlen(meshGemsOldStyleEnvVar) == 0 )
|
||||||
return SignCAD_After(meshgems_cad, error);
|
{
|
||||||
|
if (NeedsMGSpatialEnvLicense(error))
|
||||||
|
// SignCAD is only called by cadsurf. Other components call SignMesh
|
||||||
|
return UnlockProduct("cadsurf", error);
|
||||||
|
else
|
||||||
|
return SignCAD_After(meshgems_cad, error);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -479,12 +542,27 @@ namespace SMESHUtils_MGLicenseKeyGen // API implementation
|
|||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SignMesh( void* meshgems_mesh, std::string& error )
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Sign a mesh (or don't do it if env MESHGEMS_OLD_STYLE is set)
|
||||||
|
* \param [in] meshgems_mesh - pointer to a MG mesh (meshgems_mesh_t)
|
||||||
|
* \param [in] product - product of MeshGems to unlock
|
||||||
|
* \param [out] error - return error description
|
||||||
|
* \return bool - is a success
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
bool SignMesh( void* meshgems_mesh, const std::string& product, std::string& error )
|
||||||
{
|
{
|
||||||
const char *meshGemsOldStyleEnvVar( getenv( MESHGEMS_OLD_STYLE ) );
|
const char *meshGemsOldStyleEnvVar( getenv( MESHGEMS_OLD_STYLE ) );
|
||||||
if ( !meshGemsOldStyleEnvVar || strlen(meshGemsOldStyleEnvVar) == 0 )
|
if ( !meshGemsOldStyleEnvVar || strlen(meshGemsOldStyleEnvVar) == 0 )
|
||||||
// sign the mesh (MG 2.13 and 2.14)
|
{
|
||||||
return SignMesh_After(meshgems_mesh, error);
|
if (NeedsMGSpatialEnvLicense(error))
|
||||||
|
// unlock product (MG 2.15)
|
||||||
|
return UnlockProduct(product, error);
|
||||||
|
else
|
||||||
|
// sign the mesh (MG 2.13 and 2.14)
|
||||||
|
return SignMesh_After(meshgems_mesh, error);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
// use DLIM8 server (nothing to do here)
|
// use DLIM8 server (nothing to do here)
|
||||||
return true;
|
return true;
|
||||||
|
@ -38,8 +38,11 @@ namespace SMESHUtils_MGLicenseKeyGen
|
|||||||
// MeshGems 2.13, 2.14 (for CADSurf)
|
// MeshGems 2.13, 2.14 (for CADSurf)
|
||||||
SMESHUtils_EXPORT bool SignCAD( void* meshgems_cad, std::string& error );
|
SMESHUtils_EXPORT bool SignCAD( void* meshgems_cad, std::string& error );
|
||||||
|
|
||||||
|
// MeshGems 2.15 (for products launched as library)
|
||||||
|
SMESHUtils_EXPORT bool UnlockProduct( const std::string& product, std::string& error );
|
||||||
|
|
||||||
// MeshGems 2.13, 2.14 (for products launched as library)
|
// MeshGems 2.13, 2.14 (for products launched as library)
|
||||||
SMESHUtils_EXPORT bool SignMesh( void* meshgems_mesh, std::string& error );
|
SMESHUtils_EXPORT bool SignMesh( void* meshgems_mesh, const std::string& product, std::string& error );
|
||||||
|
|
||||||
// MeshGems 2.13, 2.14 and 2.15 (for products launched as executables)
|
// MeshGems 2.13, 2.14 and 2.15 (for products launched as executables)
|
||||||
SMESHUtils_EXPORT std::string GetKey(const std::string& gmfFile,
|
SMESHUtils_EXPORT std::string GetKey(const std::string& gmfFile,
|
||||||
|
Loading…
Reference in New Issue
Block a user