main.c revision ae08adadadc5ad6a6629442b7b01785864cbfa36
/* Copyright (C) 2002 Timo Sirainen */
#include "common.h"
#include "buffer.h"
#include "ioloop.h"
#include "network.h"
#include "lib-signals.h"
#include "restrict-access.h"
#include "fd-close-on-exec.h"
#include "randgen.h"
#include "mech.h"
#include "userdb.h"
#include "passdb.h"
#include "password-scheme.h"
#include "auth-master-connection.h"
#include "auth-client-connection.h"
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <syslog.h>
#include <pwd.h>
#include <grp.h>
int standalone = FALSE;
static buffer_t *masters_buf;
{
}
static void open_logfile(void)
{
return;
}
else {
/* log to file or stderr */
}
}
{
return (uid_t)-1;
}
{
return (gid_t)-1;
}
static int create_unix_listener(const char *env)
{
unsigned int mask;
int fd, i;
return -1;
else {
}
for (i = 0; i < 5; i++) {
if (fd != -1)
break;
if (errno != EADDRINUSE)
/* see if it really exists */
/* delete and try again */
}
i_fatal("chown(%s, %s, %s) failed: %m",
}
return fd;
}
static void add_extra_listeners(void)
{
struct auth_master_connection *master;
unsigned int i;
for (i = 1;; i++) {
t_push();
t_pop();
break;
}
if (master_fd != -1) {
master_path, FALSE);
}
if (client_fd != -1) {
client_path, TRUE);
}
t_pop();
}
}
static void drop_privileges(void)
{
unsigned int seed;
open_logfile();
random_init();
/* Initialize databases so their configuration files can be readable
only by root. Also load all modules here. */
/* Password lookups etc. may require roots, allow it. */
}
{
const char *env;
unsigned int pid;
userdb_init();
passdb_init();
mech_init();
if (standalone) {
/* starting standalone */
i_fatal("dovecot-auth is usually started through "
"dovecot master process. If you wish to run "
"it standalone, you'll need to set AUTH_* "
"environment variables (AUTH_1 isn't set).");
}
if (!nodaemon) {
switch (fork()) {
case -1:
i_fatal("fork() failed: %m");
case 0:
break;
default:
exit(0);
}
if (setsid() < 0)
i_fatal("setsid() failed: %m");
if (chdir("/") < 0)
i_fatal("chdir(/) failed: %m");
}
} else {
if (pid == 0)
i_fatal("AUTH_PROCESS can't be 0");
}
/* everything initialized, notify masters that all is well */
for (i = 0; i < size; i++)
}
static void main_deinit(void)
{
struct auth_master_connection **master;
if (lib_signal_kill != 0)
for (i = 0; i < size; i++)
mech_deinit();
closelog();
}
{
#ifdef DEBUG
#endif
/* NOTE: we start rooted, so keep the code minimal until
restrict_access_by_env() is called */
lib_init();
main_deinit();
lib_deinit();
return 0;
}