From bb9bc9051629c3319c56785c2f4ae0e605d76329 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rg=20Frings-F=C3=BCrst?= Date: Sat, 21 Nov 2015 14:51:17 +0100 Subject: Initial import of bitz-server version 0.1.6-1 --- src/main.cpp | 82 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 src/main.cpp (limited to 'src/main.cpp') diff --git a/src/main.cpp b/src/main.cpp new file mode 100644 index 0000000..e00c1c6 --- /dev/null +++ b/src/main.cpp @@ -0,0 +1,82 @@ +/* + * bitz-server, An ICAP server implementation in C++ + * Copyright (C) 2012 Uditha Atukorala + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#include + +#include +#include "bitz-server.h" +#include "bitz/config.h" +#include "bitz/logger.h" +#include "bitz/util.h" + + +int main( int argc, char **argv ) { + + // initialise the server + bitz::server::init(); + + // read command line options + bitz::server::options_t opt = bitz::server::read_options( argc, argv ); + + // initialise configurations + bitz::Config &server_config = bitz::Config::instance(); + + if ( opt.config_file != "" ) { + server_config.initialise( opt.config_file ); + } else { + server_config.initialise(); + } + + // get a copy of the configs + const bitz::config_t &config = server_config.configs(); + + // create directories + if ( ( opt.debug_flag != 1 ) && (! bitz::util::mkdirp( bitz::util::dirpath( config.pid_file ) ) ) ) { + std::cerr << "[core] failed to create run dir" << std::endl; + exit( EXIT_FAILURE ); + } + + if (! bitz::util::mkdirp( bitz::util::dirpath( config.log_file ) ) ) { + std::cerr << "[core] failed to create log dir" << std::endl; + exit( EXIT_FAILURE ); + } + + + // daemonize + if ( opt.debug_flag != 1 ) { + bitz::server::daemonize( bitz::util::dirpath( config.pid_file ).c_str(), config.pid_file.c_str() ); + } + + // initialise the logger + bitz::Logger &logger = bitz::Logger::instance( config.log_file, config.log_category ); + logger.info( std::string( PACKAGE_STRING ) + " initialised" ); + + // start the server + bitz::server::start( config.port, config.max_workers, config.max_worker_requests ); + + // run the server + bitz::server::run(); + + // we should never get here + bitz::server::shutdown(); + + return( EXIT_SUCCESS ); + +} + -- cgit v1.2.3