From 00ce476e5395722755eb2b3320855a27d91fdefc Mon Sep 17 00:00:00 2001 From: Christophe Bourcier Date: Thu, 27 Apr 2023 16:38:04 +0200 Subject: [PATCH] Change input and results files permissions to user only --- src/HYBRIDPlugin/HYBRIDPlugin_HYBRID.cxx | 39 ++++++++++++++++++++++-- 1 file changed, 36 insertions(+), 3 deletions(-) diff --git a/src/HYBRIDPlugin/HYBRIDPlugin_HYBRID.cxx b/src/HYBRIDPlugin/HYBRIDPlugin_HYBRID.cxx index 26f186d..834e512 100644 --- a/src/HYBRIDPlugin/HYBRIDPlugin_HYBRID.cxx +++ b/src/HYBRIDPlugin/HYBRIDPlugin_HYBRID.cxx @@ -70,6 +70,9 @@ #include #include +#include +namespace boofs = boost::filesystem; + #include #include @@ -96,6 +99,13 @@ static void removeFile( const std::string& fileName ) } } +// change results files permissions to user only (using boost to be used without C++17) +static void chmodUserOnly(const char* filename) +{ + if (boofs::exists(filename)) + boofs::permissions(filename, boofs::remove_perms | boofs::group_all | boofs::others_all ); +} + //============================================================================= /*! * @@ -1383,11 +1393,17 @@ static bool writeGMFFile(MG_HYBRID_API* MGInput } MGInput->GmfCloseMesh(idx); + chmodUserOnly(theMeshFileName); if (idxRequired) - MGInput->GmfCloseMesh(idxRequired); + { + MGInput->GmfCloseMesh(idxRequired); + chmodUserOnly(theRequiredFileName); + } if (idxSol) - MGInput->GmfCloseMesh(idxSol); - + { + MGInput->GmfCloseMesh(idxSol); + chmodUserOnly(theSolFileName); + } return true; } @@ -1504,6 +1520,7 @@ bool HYBRIDPlugin_HYBRID::Compute(SMESH_Mesh& theMesh, } aIdsFile.close(); + chmodUserOnly(aSmdsToHybridIdMapFileName.c_str()); if ( ! Ok ) { if ( !_keepFiles ) { @@ -1546,9 +1563,17 @@ bool HYBRIDPlugin_HYBRID::Compute(SMESH_Mesh& theMesh, if ( _logInStandardOutput && mgHybrid.IsLibrary() ) std::cout << std::endl << mgHybrid.GetLog() << std::endl; + else + chmodUserOnly(aLogFileName.c_str()); if ( Ok ) std::cout << "End of Hybrid execution !" << std::endl; + if ( mgHybrid.IsExecutable() ) + { + chmodUserOnly(aResultFileName.c_str()); + chmodUserOnly(aResSolFileName.c_str()); + } + // -------------- // read a result // -------------- @@ -1745,9 +1770,17 @@ bool HYBRIDPlugin_HYBRID::Compute(SMESH_Mesh& theMesh, if ( _logInStandardOutput && mgHybrid.IsLibrary() ) std::cout << std::endl << mgHybrid.GetLog() << std::endl; + else + chmodUserOnly(aLogFileName.c_str()); if ( Ok ) std::cout << "End of Hybrid execution !" << std::endl; + if (mgHybrid.IsExecutable()) + { + chmodUserOnly(aResultFileName.c_str()); + chmodUserOnly(aResSolFileName.c_str()); + } + // -------------- // read a result // -------------- -- 2.39.2