X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;ds=inline;f=src%2Futil.cpp;h=40fcf25ac0dc2f5c9c6cbb3a6ab839404c20921d;hb=ecdc4c456ebcc3e0871b765d1f4d15e73520d2a3;hp=5cf30da1d2dac01576e6ce5dce6dbaa4f845add4;hpb=91814cbc6f74173f40278062f8de1859c9b2e7c4;p=cassiopeia.git diff --git a/src/util.cpp b/src/util.cpp index 5cf30da..40fcf25 100644 --- a/src/util.cpp +++ b/src/util.cpp @@ -9,17 +9,15 @@ #include void writeFile( const std::string& name, const std::string& content ) { - std::ofstream file; - - file.open( name ); + std::ofstream file( name ); file << content; - file.close(); + + //! \FIXME: Error checking } std::string readFile( const std::string& name ) { std::ifstream t( name ); std::string res = std::string( std::istreambuf_iterator( t ), std::istreambuf_iterator() ); - t.close(); return res; } @@ -28,14 +26,25 @@ std::string writeBackFile( const std::string& serial, const std::string& cert, c errno = 0; std::string filename = keydir; + if( 0 != mkdir( filename.c_str(), 0755 ) ) { - return ""; + if( EEXIST != errno ) { + return ""; + } + + //! \FIXME: Check this is a directory } filename += "/crt"; + if( 0 != mkdir( filename.c_str(), 0755 ) ) { - return ""; + if( EEXIST != errno ) { + return ""; + } + + //! \FIXME: Check this is a directory } + std::string first; if( serial.length() < 3 ) { @@ -45,9 +54,15 @@ std::string writeBackFile( const std::string& serial, const std::string& cert, c } filename += "/" + first; + if( 0 != mkdir( filename.c_str(), 0755 ) ) { - return ""; + if( EEXIST != errno ) { + return ""; + } + + //! \FIXME: Check this is a directory } + filename += "/" + serial + ".crt"; writeFile( filename, cert ); @@ -94,7 +109,7 @@ std::pair parseDate( const std::string& date ) { std::string checkS( check, siz ); if( checkS != date ) { - return std::pair( false, 0 ); + return { false, 0 }; } return std::pair( true, res ); @@ -119,7 +134,6 @@ std::pair addMonths( std::time_t t, int32_t count ) { } return std::pair( true, res ); - } std::pair parseMonthInterval( std::time_t t, const std::string& date ) { @@ -142,6 +156,7 @@ std::pair parseMonthInterval( std::time_t t, const std::string& da return std::pair( false, 0 ); } } + std::pair parseYearInterval( std::time_t t, const std::string& date ) { if( date[date.size() - 1] != 'y' ) { return std::pair( false, 0 ); @@ -162,3 +177,29 @@ std::pair parseYearInterval( std::time_t t, const std::string& dat return std::pair( false, 0 ); } } + +std::unique_ptr openLogfile( const std::string &name ) { + struct stat buffer; + std::string tname = name; + int ctr = 2; + + while( stat( tname.c_str(), &buffer ) == 0 ) { + tname = name + "_" + std::to_string( ctr++ ); + } + + auto res = std::make_unique( tname ); + + if( ! res->good() ) { + throw std::string( "Failed to open file for logging: " ) + name; + } + + return res; +} + +std::string timestamp(){ + time_t c_time; + if( time( &c_time ) == -1 ) { + throw std::runtime_error( "Error while fetching time?" ); + } + return std::to_string( c_time ); +}