2003-08-13 01:53:07 +00:00
/*
Unix SMB / CIFS implementation .
2005-01-30 00:54:57 +00:00
2003-08-13 01:53:07 +00:00
Main SMB server routines
2005-01-30 00:54:57 +00:00
Copyright ( C ) Andrew Tridgell 1992 - 2005
2003-08-13 01:53:07 +00:00
Copyright ( C ) Martin Pool 2002
Copyright ( C ) Jelmer Vernooij 2002
Copyright ( C ) James J Myers 2003 < myersjj @ samba . org >
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
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2003-08-13 01:53:07 +00:00
( 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
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2003-08-13 01:53:07 +00:00
*/
# include "includes.h"
2005-02-03 11:56:03 +00:00
# include "lib/events/events.h"
2005-01-18 10:10:35 +00:00
# include "version.h"
2004-11-02 02:57:18 +00:00
# include "lib/cmdline/popt_common.h"
2005-01-30 00:54:57 +00:00
# include "system/dir.h"
2005-02-10 05:09:35 +00:00
# include "system/filesys.h"
2005-12-27 22:51:30 +00:00
# include "ntvfs/ntvfs.h"
2005-12-28 15:38:36 +00:00
# include "ntptr/ntptr.h"
2005-12-30 22:46:16 +00:00
# include "auth/gensec/gensec.h"
2010-06-23 10:33:15 +10:00
# include "libcli/auth/schannel.h"
2006-03-07 11:07:23 +00:00
# include "smbd/process_model.h"
2006-11-06 16:11:52 +00:00
# include "param/secrets.h"
2012-07-19 15:41:52 -07:00
# include "lib/util/pidfile.h"
2007-09-08 12:42:09 +00:00
# include "param/param.h"
2009-08-07 17:19:39 +10:00
# include "dsdb/samdb/samdb.h"
# include "auth/session.h"
2009-09-18 18:05:55 -07:00
# include "lib/messaging/irpc.h"
# include "librpc/gen_ndr/ndr_irpc.h"
# include "cluster/cluster.h"
2010-03-29 20:20:25 +11:00
# include "dynconfig/dynconfig.h"
2011-12-03 07:03:35 +01:00
# include "lib/util/samba_modules.h"
2013-07-10 14:48:18 +02:00
# include "nsswitch/winbind_client.h"
2003-08-13 01:53:07 +00:00
2005-01-30 00:54:57 +00:00
/*
2005-07-10 08:06:28 +00:00
recursively delete a directory tree
2005-01-30 00:54:57 +00:00
*/
2005-07-10 08:06:28 +00:00
static void recursive_delete ( const char * path )
2003-08-13 01:53:07 +00:00
{
2005-01-30 00:54:57 +00:00
DIR * dir ;
struct dirent * de ;
2003-08-13 01:53:07 +00:00
2005-01-30 00:54:57 +00:00
dir = opendir ( path ) ;
if ( ! dir ) {
return ;
2003-08-13 01:53:07 +00:00
}
2005-01-30 00:54:57 +00:00
for ( de = readdir ( dir ) ; de ; de = readdir ( dir ) ) {
2005-07-10 08:06:28 +00:00
char * fname ;
struct stat st ;
2006-04-24 00:16:51 +00:00
if ( ISDOT ( de - > d_name ) | | ISDOTDOT ( de - > d_name ) ) {
2005-07-10 08:06:28 +00:00
continue ;
}
fname = talloc_asprintf ( path , " %s/%s " , path , de - > d_name ) ;
if ( stat ( fname , & st ) ! = 0 ) {
continue ;
}
if ( S_ISDIR ( st . st_mode ) ) {
recursive_delete ( fname ) ;
talloc_free ( fname ) ;
continue ;
}
if ( unlink ( fname ) ! = 0 ) {
DEBUG ( 0 , ( " Unabled to delete '%s' - %s \n " ,
fname , strerror ( errno ) ) ) ;
smb_panic ( " unable to cleanup tmp files " ) ;
2005-01-30 00:54:57 +00:00
}
2005-07-10 08:06:28 +00:00
talloc_free ( fname ) ;
2003-08-13 01:53:07 +00:00
}
2005-01-30 00:54:57 +00:00
closedir ( dir ) ;
2005-07-10 08:06:28 +00:00
}
/*
cleanup temporary files . This is the new alternative to
TDB_CLEAR_IF_FIRST . Unfortunately TDB_CLEAR_IF_FIRST is not
efficient on unix systems due to the lack of scaling of the byte
range locking system . So instead of putting the burden on tdb to
cleanup tmp files , this function deletes them .
*/
2007-12-02 22:32:11 +01:00
static void cleanup_tmp_files ( struct loadparm_context * lp_ctx )
2005-07-10 08:06:28 +00:00
{
char * path ;
TALLOC_CTX * mem_ctx = talloc_new ( NULL ) ;
2007-12-02 22:32:11 +01:00
path = smbd_tmp_path ( mem_ctx , lp_ctx , NULL ) ;
2005-01-30 00:54:57 +00:00
2005-07-10 08:06:28 +00:00
recursive_delete ( path ) ;
2005-01-30 00:54:57 +00:00
talloc_free ( mem_ctx ) ;
}
2003-08-13 01:53:07 +00:00
2006-03-08 12:31:57 +00:00
static void sig_hup ( int sig )
{
debug_schedule_reopen_logs ( ) ;
}
2006-09-11 04:47:56 +00:00
static void sig_term ( int sig )
{
# if HAVE_GETPGRP
static int done_sigterm ;
if ( done_sigterm = = 0 & & getpgrp ( ) = = getpid ( ) ) {
DEBUG ( 0 , ( " SIGTERM: killing children \n " ) ) ;
done_sigterm = 1 ;
kill ( - getpgrp ( ) , SIGTERM ) ;
}
# endif
2009-08-07 17:19:39 +10:00
DEBUG ( 0 , ( " Exiting pid %d on SIGTERM \n " , ( int ) getpid ( ) ) ) ;
2010-10-02 12:44:28 -07:00
exit ( 127 ) ;
2006-09-11 04:47:56 +00:00
}
2005-01-30 00:54:57 +00:00
/*
setup signal masks
*/
static void setup_signals ( void )
{
2003-08-13 01:53:07 +00:00
/* we are never interested in SIGPIPE */
2007-10-01 22:13:02 +00:00
BlockSignals ( true , SIGPIPE ) ;
2003-08-13 01:53:07 +00:00
# if defined(SIGFPE)
/* we are never interested in SIGFPE */
2007-10-01 22:13:02 +00:00
BlockSignals ( true , SIGFPE ) ;
2003-08-13 01:53:07 +00:00
# endif
2005-12-15 16:53:20 +00:00
/* We are no longer interested in USR1 */
2007-10-01 22:13:02 +00:00
BlockSignals ( true , SIGUSR1 ) ;
2005-12-15 16:53:20 +00:00
2003-08-13 01:53:07 +00:00
# if defined(SIGUSR2)
/* We are no longer interested in USR2 */
2007-10-01 22:13:02 +00:00
BlockSignals ( true , SIGUSR2 ) ;
2003-08-13 01:53:07 +00:00
# endif
/* POSIX demands that signals are inherited. If the invoking process has
2010-02-21 17:46:46 +11:00
* these signals masked , we will have problems , as we won ' t receive them . */
2007-10-01 22:13:02 +00:00
BlockSignals ( false , SIGHUP ) ;
BlockSignals ( false , SIGTERM ) ;
2005-01-30 00:54:57 +00:00
2006-03-08 12:31:57 +00:00
CatchSignal ( SIGHUP , sig_hup ) ;
2006-09-11 04:47:56 +00:00
CatchSignal ( SIGTERM , sig_term ) ;
2005-12-15 16:53:20 +00:00
}
2005-01-30 00:54:57 +00:00
2005-05-17 06:20:54 +00:00
/*
handle io on stdin
*/
2008-12-29 20:24:57 +01:00
static void server_stdin_handler ( struct tevent_context * event_ctx , struct tevent_fd * fde ,
2009-02-02 08:41:28 +01:00
uint16_t flags , void * private_data )
2005-05-17 06:20:54 +00:00
{
2009-02-02 08:41:28 +01:00
const char * binary_name = ( const char * ) private_data ;
2005-05-17 06:20:54 +00:00
uint8_t c ;
if ( read ( 0 , & c , 1 ) = = 0 ) {
2005-12-15 18:08:25 +00:00
DEBUG ( 0 , ( " %s: EOF on stdin - terminating \n " , binary_name ) ) ;
2006-09-11 04:47:56 +00:00
# if HAVE_GETPGRP
if ( getpgrp ( ) = = getpid ( ) ) {
2009-08-07 17:19:39 +10:00
DEBUG ( 0 , ( " Sending SIGTERM from pid %d \n " , ( int ) getpid ( ) ) ) ;
2006-09-11 04:47:56 +00:00
kill ( - getpgrp ( ) , SIGTERM ) ;
}
# endif
2005-05-17 06:20:54 +00:00
exit ( 0 ) ;
}
}
2005-06-12 00:17:23 +00:00
/*
die if the user selected maximum runtime is exceeded
*/
2008-12-29 20:24:57 +01:00
_NORETURN_ static void max_runtime_handler ( struct tevent_context * ev ,
struct tevent_timer * te ,
2009-02-02 08:41:28 +01:00
struct timeval t , void * private_data )
2005-06-12 00:17:23 +00:00
{
2009-02-02 08:41:28 +01:00
const char * binary_name = ( const char * ) private_data ;
2012-02-20 08:08:19 +11:00
DEBUG ( 0 , ( " %s: maximum runtime exceeded - terminating at %llu, current ts: %llu \n " ,
binary_name , ( unsigned long long ) t . tv_sec , ( unsigned long long ) time ( NULL ) ) ) ;
2005-06-12 00:17:23 +00:00
exit ( 0 ) ;
}
2009-08-07 17:19:39 +10:00
/*
2009-10-23 14:30:00 +11:00
pre - open the key databases . This saves a lot of time in child
processes
2009-08-07 17:19:39 +10:00
*/
2009-10-23 14:30:00 +11:00
static void prime_ldb_databases ( struct tevent_context * event_ctx )
2009-08-07 17:19:39 +10:00
{
2009-10-23 14:30:00 +11:00
TALLOC_CTX * db_context ;
db_context = talloc_new ( event_ctx ) ;
2010-10-10 23:25:38 +02:00
samdb_connect ( db_context , event_ctx , cmdline_lp_ctx , system_session ( cmdline_lp_ctx ) , 0 ) ;
2010-12-20 21:26:35 +11:00
privilege_connect ( db_context , cmdline_lp_ctx ) ;
2009-10-23 14:30:00 +11:00
/* we deliberately leave these open, which allows them to be
* re - used in ldb_wrap_connect ( ) */
2009-08-07 17:19:39 +10:00
}
2009-09-18 18:05:55 -07:00
/*
called when a fatal condition occurs in a child task
*/
static NTSTATUS samba_terminate ( struct irpc_message * msg ,
struct samba_terminate * r )
{
DEBUG ( 0 , ( " samba_terminate: %s \n " , r - > in . reason ) ) ;
exit ( 1 ) ;
}
/*
setup messaging for the top level samba ( parent ) task
*/
static NTSTATUS setup_parent_messaging ( struct tevent_context * event_ctx ,
struct loadparm_context * lp_ctx )
{
2011-05-03 10:40:33 +10:00
struct imessaging_context * msg ;
2009-09-18 18:05:55 -07:00
NTSTATUS status ;
2011-05-03 10:40:33 +10:00
msg = imessaging_init ( talloc_autofree_context ( ) ,
2011-10-13 20:01:56 +11:00
lp_ctx ,
2011-07-22 14:55:32 +10:00
cluster_id ( 0 , SAMBA_PARENT_TASKID ) , event_ctx , false ) ;
2009-09-18 18:05:55 -07:00
NT_STATUS_HAVE_NO_MEMORY ( msg ) ;
2012-08-07 15:50:46 +10:00
status = irpc_add_name ( msg , " samba " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
2009-09-18 18:05:55 -07:00
status = IRPC_REGISTER ( msg , irpc , SAMBA_TERMINATE ,
samba_terminate , NULL ) ;
return status ;
}
2010-03-29 20:20:25 +11:00
/*
show build info
*/
static void show_build ( void )
{
# define CONFIG_OPTION(n) { #n, dyn_ ## n }
struct {
const char * name ;
const char * value ;
} config_options [ ] = {
CONFIG_OPTION ( BINDIR ) ,
CONFIG_OPTION ( SBINDIR ) ,
CONFIG_OPTION ( CONFIGFILE ) ,
CONFIG_OPTION ( NCALRPCDIR ) ,
CONFIG_OPTION ( LOGFILEBASE ) ,
CONFIG_OPTION ( LMHOSTSFILE ) ,
CONFIG_OPTION ( DATADIR ) ,
CONFIG_OPTION ( MODULESDIR ) ,
CONFIG_OPTION ( LOCKDIR ) ,
2011-07-12 13:04:08 +02:00
CONFIG_OPTION ( STATEDIR ) ,
CONFIG_OPTION ( CACHEDIR ) ,
2010-03-29 20:20:25 +11:00
CONFIG_OPTION ( PIDDIR ) ,
CONFIG_OPTION ( PRIVATE_DIR ) ,
2011-02-07 13:13:44 +11:00
CONFIG_OPTION ( CODEPAGEDIR ) ,
2010-03-29 20:20:25 +11:00
CONFIG_OPTION ( SETUPDIR ) ,
CONFIG_OPTION ( WINBINDD_SOCKET_DIR ) ,
CONFIG_OPTION ( WINBINDD_PRIVILEGED_SOCKET_DIR ) ,
CONFIG_OPTION ( NTP_SIGND_SOCKET_DIR ) ,
{ NULL , NULL }
} ;
int i ;
2010-10-14 12:42:40 +11:00
printf ( " Samba version: %s \n " , SAMBA_VERSION_STRING ) ;
2010-04-21 15:35:55 +10:00
printf ( " Build environment: \n " ) ;
# ifdef BUILD_SYSTEM
printf ( " Build host: %s \n " , BUILD_SYSTEM ) ;
# endif
2010-03-29 20:20:25 +11:00
printf ( " Paths: \n " ) ;
for ( i = 0 ; config_options [ i ] . name ; i + + ) {
printf ( " %s: %s \n " , config_options [ i ] . name , config_options [ i ] . value ) ;
}
exit ( 0 ) ;
}
2009-09-18 18:05:55 -07:00
2005-01-30 00:54:57 +00:00
/*
main server .
*/
2005-12-15 18:08:25 +00:00
static int binary_smbd_main ( const char * binary_name , int argc , const char * argv [ ] )
2005-01-30 00:54:57 +00:00
{
2007-08-22 12:21:40 +00:00
bool opt_daemon = false ;
bool opt_interactive = false ;
2005-01-30 00:54:57 +00:00
int opt ;
poptContext pc ;
2010-11-01 15:38:37 +11:00
# define _MODULE_PROTO(init) extern NTSTATUS init(void);
STATIC_service_MODULES_PROTO ;
2011-12-03 07:03:35 +01:00
init_module_fn static_init [ ] = { STATIC_service_MODULES } ;
init_module_fn * shared_init ;
2008-12-29 20:24:57 +01:00
struct tevent_context * event_ctx ;
2008-06-20 11:03:12 +02:00
uint16_t stdin_event_flags ;
2005-01-30 00:54:57 +00:00
NTSTATUS status ;
const char * model = " standard " ;
2005-06-12 00:17:23 +00:00
int max_runtime = 0 ;
2013-06-10 13:33:40 -07:00
struct stat st ;
2006-04-03 14:02:53 +00:00
enum {
2007-08-22 12:21:40 +00:00
OPT_DAEMON = 1000 ,
OPT_INTERACTIVE ,
2010-03-29 20:20:25 +11:00
OPT_PROCESS_MODEL ,
OPT_SHOW_BUILD
2006-04-03 14:02:53 +00:00
} ;
2005-01-30 00:54:57 +00:00
struct poptOption long_options [ ] = {
POPT_AUTOHELP
2007-08-22 12:21:40 +00:00
{ " daemon " , ' D ' , POPT_ARG_NONE , NULL , OPT_DAEMON ,
" Become a daemon (default) " , NULL } ,
2006-04-03 14:02:53 +00:00
{ " interactive " , ' i ' , POPT_ARG_NONE , NULL , OPT_INTERACTIVE ,
2005-01-30 00:54:57 +00:00
" Run interactive (not a daemon) " , NULL } ,
2006-04-03 14:02:53 +00:00
{ " model " , ' M ' , POPT_ARG_STRING , NULL , OPT_PROCESS_MODEL ,
2005-01-30 00:54:57 +00:00
" Select process model " , " MODEL " } ,
2006-04-03 14:02:53 +00:00
{ " maximum-runtime " , 0 , POPT_ARG_INT , & max_runtime , 0 ,
2005-12-15 18:08:25 +00:00
" set maximum runtime of the server process, till autotermination " , " seconds " } ,
2010-03-29 20:20:25 +11:00
{ " show-build " , ' b ' , POPT_ARG_NONE , NULL , OPT_SHOW_BUILD , " show build info " , NULL } ,
2005-06-13 08:12:39 +00:00
POPT_COMMON_SAMBA
2005-01-30 00:54:57 +00:00
POPT_COMMON_VERSION
2006-09-06 12:28:01 +00:00
{ NULL }
2005-01-30 00:54:57 +00:00
} ;
2005-12-15 18:08:25 +00:00
pc = poptGetContext ( binary_name , argc , argv , long_options , 0 ) ;
2006-04-03 14:02:53 +00:00
while ( ( opt = poptGetNextOpt ( pc ) ) ! = - 1 ) {
switch ( opt ) {
2007-08-22 12:21:40 +00:00
case OPT_DAEMON :
opt_daemon = true ;
break ;
2006-04-03 14:02:53 +00:00
case OPT_INTERACTIVE :
2007-08-22 12:21:40 +00:00
opt_interactive = true ;
2006-04-03 14:02:53 +00:00
break ;
case OPT_PROCESS_MODEL :
model = poptGetOptArg ( pc ) ;
break ;
2010-03-29 20:20:25 +11:00
case OPT_SHOW_BUILD :
show_build ( ) ;
break ;
2007-08-22 12:21:40 +00:00
default :
2007-12-11 22:23:06 +01:00
fprintf ( stderr , " \n Invalid option %s: %s \n \n " ,
2007-08-22 12:21:40 +00:00
poptBadOption ( pc , 0 ) , poptStrerror ( opt ) ) ;
poptPrintUsage ( pc , stderr , 0 ) ;
2010-02-13 18:03:08 +01:00
return 1 ;
2006-04-03 14:02:53 +00:00
}
}
2007-08-22 12:21:40 +00:00
if ( opt_daemon & & opt_interactive ) {
2007-12-11 22:23:06 +01:00
fprintf ( stderr , " \n ERROR: "
2007-08-22 12:21:40 +00:00
" Option -i|--interactive is not allowed together with -D|--daemon \n \n " ) ;
poptPrintUsage ( pc , stderr , 0 ) ;
2010-02-13 18:03:08 +01:00
return 1 ;
2007-08-22 12:21:40 +00:00
} else if ( ! opt_interactive ) {
/* default is --daemon */
opt_daemon = true ;
}
2005-01-30 00:54:57 +00:00
poptFreeContext ( pc ) ;
2007-08-22 12:21:40 +00:00
setup_logging ( binary_name , opt_interactive ? DEBUG_STDOUT : DEBUG_FILE ) ;
2005-01-30 00:54:57 +00:00
setup_signals ( ) ;
2003-08-13 01:53:07 +00:00
/* we want total control over the permissions on created files,
so set our umask to 0 */
umask ( 0 ) ;
2005-12-15 18:08:25 +00:00
DEBUG ( 0 , ( " %s version %s started. \n " , binary_name , SAMBA_VERSION_STRING ) ) ;
2014-01-02 14:04:26 +01:00
DEBUGADD ( 0 , ( " Copyright Andrew Tridgell and the Samba Team 1992-2014 \n " ) ) ;
2003-08-13 01:53:07 +00:00
2004-07-13 21:04:56 +00:00
if ( sizeof ( uint16_t ) < 2 | | sizeof ( uint32_t ) < 4 | | sizeof ( uint64_t ) < 8 ) {
2003-08-13 01:53:07 +00:00
DEBUG ( 0 , ( " ERROR: Samba is not configured correctly for the word size on your machine \n " ) ) ;
2007-06-01 10:17:02 +00:00
DEBUGADD ( 0 , ( " sizeof(uint16_t) = %u, sizeof(uint32_t) %u, sizeof(uint64_t) = %u \n " ,
2007-08-23 02:10:17 +00:00
( unsigned int ) sizeof ( uint16_t ) , ( unsigned int ) sizeof ( uint32_t ) , ( unsigned int ) sizeof ( uint64_t ) ) ) ;
2010-02-13 18:03:08 +01:00
return 1 ;
2003-08-13 01:53:07 +00:00
}
2004-07-13 21:04:56 +00:00
2007-08-22 12:21:40 +00:00
if ( opt_daemon ) {
2003-08-13 01:53:07 +00:00
DEBUG ( 3 , ( " Becoming a daemon. \n " ) ) ;
2010-03-26 11:17:37 +01:00
become_daemon ( true , false , false ) ;
2003-08-13 01:53:07 +00:00
}
2007-12-10 04:33:16 +01:00
cleanup_tmp_files ( cmdline_lp_ctx ) ;
2005-01-30 00:54:57 +00:00
2014-02-03 15:46:08 +13:00
if ( ! directory_exist ( lpcfg_lock_directory ( cmdline_lp_ctx ) ) ) {
mkdir ( lpcfg_lock_directory ( cmdline_lp_ctx ) , 0755 ) ;
2003-08-13 01:53:07 +00:00
}
2014-02-03 15:57:21 +13:00
pidfile_create ( lpcfg_pid_directory ( cmdline_lp_ctx ) , binary_name ) ;
2005-01-30 00:54:57 +00:00
2011-05-03 13:24:10 +10:00
/* Set up a database to hold a random seed, in case we don't
* have / dev / urandom */
2011-05-06 16:22:41 +02:00
if ( ! randseed_init ( talloc_autofree_context ( ) , cmdline_lp_ctx ) ) {
2010-02-13 18:03:08 +01:00
return 1 ;
2003-08-13 01:53:07 +00:00
}
2012-06-10 22:08:20 +10:00
if ( lpcfg_server_role ( cmdline_lp_ctx ) = = ROLE_ACTIVE_DIRECTORY_DC ) {
2011-10-12 22:55:34 +11:00
if ( ! open_schannel_session_store ( talloc_autofree_context ( ) , cmdline_lp_ctx ) ) {
2014-03-26 12:30:30 +02:00
exit_daemon ( " Samba cannot open schannel store for secured NETLOGON operations. " , EACCES ) ;
2010-06-23 10:33:15 +10:00
}
}
2013-07-10 14:48:18 +02:00
/* make sure we won't go through nss_winbind */
if ( ! winbind_off ( ) ) {
2014-03-26 12:30:30 +02:00
exit_daemon ( " Samba failed to disable recusive winbindd calls. " , EACCES ) ;
2013-07-10 14:48:18 +02:00
}
2011-06-06 14:58:28 +10:00
gensec_init ( ) ; /* FIXME: */
2004-04-19 11:21:50 +00:00
2011-06-06 14:58:28 +10:00
ntptr_init ( ) ; /* FIXME: maybe run this in the initialization function
2005-12-26 21:58:31 +00:00
of the spoolss RPC server instead ? */
2007-12-10 04:33:16 +01:00
ntvfs_init ( cmdline_lp_ctx ) ; /* FIXME: maybe run this in the initialization functions
2005-12-26 21:58:31 +00:00
of the SMB [ , 2 ] server instead ? */
2007-12-10 04:33:16 +01:00
process_model_init ( cmdline_lp_ctx ) ;
2005-12-26 21:58:31 +00:00
2011-12-03 07:03:35 +01:00
shared_init = load_samba_modules ( NULL , " service " ) ;
2005-12-26 16:46:55 +00:00
2011-12-03 07:03:35 +01:00
run_init_functions ( static_init ) ;
run_init_functions ( shared_init ) ;
2005-12-26 16:46:55 +00:00
talloc_free ( shared_init ) ;
2005-01-30 00:54:57 +00:00
/* the event context is the top level structure in smbd. Everything else
should hang off that */
2008-06-14 13:00:53 -04:00
event_ctx = s4_event_context_init ( talloc_autofree_context ( ) ) ;
2005-01-14 01:32:56 +00:00
2007-10-05 21:51:47 +00:00
if ( event_ctx = = NULL ) {
2014-03-26 12:30:30 +02:00
exit_daemon ( " Initializing event context failed " , EACCES ) ;
2007-10-05 21:51:47 +00:00
}
2007-08-22 12:21:40 +00:00
if ( opt_interactive ) {
2008-06-20 11:03:12 +02:00
/* terminate when stdin goes away */
2009-01-03 15:24:31 +01:00
stdin_event_flags = TEVENT_FD_READ ;
2008-06-20 11:03:12 +02:00
} else {
/* stay alive forever */
stdin_event_flags = 0 ;
2005-06-07 08:33:17 +00:00
}
2005-05-17 06:20:54 +00:00
2008-06-20 11:03:12 +02:00
/* catch EOF on stdin */
# ifdef SIGTTIN
signal ( SIGTTIN , SIG_IGN ) ;
# endif
2013-06-10 13:33:40 -07:00
if ( fstat ( 0 , & st ) ! = 0 ) {
2014-03-26 12:30:30 +02:00
exit_daemon ( " Samba failed to set standard input handler " , ENOTTY ) ;
2013-06-10 13:33:40 -07:00
}
if ( S_ISFIFO ( st . st_mode ) | | S_ISSOCK ( st . st_mode ) ) {
tevent_add_fd ( event_ctx ,
event_ctx ,
0 ,
stdin_event_flags ,
server_stdin_handler ,
discard_const ( binary_name ) ) ;
}
2005-06-12 00:17:23 +00:00
if ( max_runtime ) {
2011-06-06 22:40:20 +02:00
DEBUG ( 0 , ( " Called with maxruntime %d - current ts %llu \n " ,
max_runtime , ( unsigned long long ) time ( NULL ) ) ) ;
2009-01-03 15:24:31 +01:00
tevent_add_timer ( event_ctx , event_ctx ,
timeval_current_ofs ( max_runtime , 0 ) ,
max_runtime_handler ,
discard_const ( binary_name ) ) ;
2005-06-12 00:17:23 +00:00
}
2012-08-22 21:01:16 +10:00
if ( lpcfg_server_role ( cmdline_lp_ctx ) ! = ROLE_ACTIVE_DIRECTORY_DC
& & ! lpcfg_parm_bool ( cmdline_lp_ctx , NULL , " server role check " , " inhibit " , false )
& & ! str_list_check_ci ( lpcfg_server_services ( cmdline_lp_ctx ) , " smb " )
& & ! str_list_check_ci ( lpcfg_dcerpc_endpoint_servers ( cmdline_lp_ctx ) , " remote " )
& & ! str_list_check_ci ( lpcfg_dcerpc_endpoint_servers ( cmdline_lp_ctx ) , " mapiproxy " ) ) {
DEBUG ( 0 , ( " At this time the 'samba' binary should only be used for either: \n " ) ) ;
DEBUGADD ( 0 , ( " 'server role = active directory domain controller' or to access the ntvfs file server with 'server services = +smb' or the rpc proxy with 'dcerpc endpoint servers = remote' \n " ) ) ;
DEBUGADD ( 0 , ( " You should start smbd/nmbd/winbindd instead for domain member and standalone file server tasks \n " ) ) ;
2014-03-26 12:30:30 +02:00
exit_daemon ( " Samba detected misconfigured 'server role' and exited. Check logs for details " , EINVAL ) ;
2012-08-22 21:01:16 +10:00
} ;
2009-10-23 14:30:00 +11:00
prime_ldb_databases ( event_ctx ) ;
2009-08-07 17:19:39 +10:00
2009-09-18 18:05:55 -07:00
status = setup_parent_messaging ( event_ctx , cmdline_lp_ctx ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2014-03-26 12:30:30 +02:00
exit_daemon ( " Samba failed to setup parent messaging " , NT_STATUS_V ( status ) ) ;
2009-09-18 18:05:55 -07:00
}
2005-12-15 18:08:25 +00:00
DEBUG ( 0 , ( " %s: using '%s' process model \n " , binary_name , model ) ) ;
2009-09-20 22:17:35 +02:00
2007-12-10 04:33:16 +01:00
status = server_service_startup ( event_ctx , cmdline_lp_ctx , model ,
2010-07-16 14:32:42 +10:00
lpcfg_server_services ( cmdline_lp_ctx ) ) ;
2005-01-30 00:54:57 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2014-03-26 12:30:30 +02:00
exit_daemon ( " Samba failed to start services " , NT_STATUS_V ( status ) ) ;
2004-07-13 21:04:56 +00:00
}
2003-08-13 01:53:07 +00:00
2014-03-25 12:53:04 +02:00
if ( opt_daemon ) {
daemon_ready ( " samba " ) ;
}
2005-01-30 00:54:57 +00:00
/* wait for events - this is where smbd sits for most of its
life */
2009-01-03 15:24:31 +01:00
tevent_loop_wait ( event_ctx ) ;
2005-01-14 01:32:56 +00:00
2005-01-30 00:54:57 +00:00
/* as everything hangs off this event context, freeing it
should initiate a clean shutdown of all services */
talloc_free ( event_ctx ) ;
2005-01-14 01:32:56 +00:00
return 0 ;
2004-07-13 21:04:56 +00:00
}
2009-09-20 22:17:35 +02:00
int main ( int argc , const char * argv [ ] )
2004-07-13 21:04:56 +00:00
{
2009-03-20 15:13:39 +01:00
return binary_smbd_main ( " samba " , argc , argv ) ;
2003-08-13 01:53:07 +00:00
}