main.c revision b728c54e411fd1964195497572ab7066138206cb
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainen/* Copyright (C) 2002-2003 Timo Sirainen */
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainenvoid (*hook_mail_storage_created)(struct mail_storage **storage) = NULL;
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainenvoid (*hook_client_created)(struct client **client) = NULL;
fa45f3f1ad423381ba07056e415ffc4d6449f089Timo Sirainenstatic char log_prefix[128]; /* syslog() needs this to be permanent */
fa45f3f1ad423381ba07056e415ffc4d6449f089Timo Sirainenstatic void sig_quit(int signo __attr_unused__)
43a2293a8bddfbeed84b29193c599071c44d17c7Timo Sirainenstatic void open_logfile(void)
8f1d14e3ada93a6d6ee64f73c6e6ae2364d8eba1Timo Sirainen /* quite a long user name, cut it */
9e708a17f984ef7690ff2468ec19ad62c95b1ac2Timo Sirainen user = t_strndup(user, sizeof(log_prefix)-6-2);
f9ef36afc131626754716d6f4874a2ad04da0ac4Timo Sirainen i_snprintf(log_prefix, sizeof(log_prefix), "pop3(%s)", user);
6ef7e31619edfaa17ed044b45861d106a86191efTimo Sirainen i_set_failure_syslog(log_prefix, LOG_NDELAY, LOG_MAIL);
f99fab9747beba303a64e7db9026e3185425833dTimo Sirainen /* log to file or stderr */
9439bed2f07d6475febd8a247cd2f0990fb32a13Timo Sirainen i_set_failure_file(getenv("LOGFILE"), log_prefix);
321221ddc2dedc4ad79839770765adc40d311a0dTimo Sirainen i_set_failure_timestamp_format(getenv("LOGSTAMP"));
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainenstatic void drop_privileges(void)
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainen /* Log file or syslog opening probably requires roots */
f9ef36afc131626754716d6f4874a2ad04da0ac4Timo Sirainen /* Most likely needed. Have to open /dev/urandom before possible
f9ef36afc131626754716d6f4874a2ad04da0ac4Timo Sirainen chrooting. */
fa45f3f1ad423381ba07056e415ffc4d6449f089Timo Sirainenstatic int main_init(void)
fa45f3f1ad423381ba07056e415ffc4d6449f089Timo Sirainen modules = getenv("MODULE_DIR") == NULL ? NULL :
00f5efa3156ab6a0b4f21e8c703d0eb816cf3091Timo Sirainen /* support also maildir-specific environment */
00f5efa3156ab6a0b4f21e8c703d0eb816cf3091Timo Sirainen storage = mail_storage_create_with_data(mail, getenv("USER"),
00f5efa3156ab6a0b4f21e8c703d0eb816cf3091Timo Sirainen i_fatal("Failed to create storage with data: %s", mail);
316dad8277db6575354eba30d3fc7a1c0447c513Timo Sirainenstatic void main_deinit(void)
316dad8277db6575354eba30d3fc7a1c0447c513Timo Sirainen /* warn about being killed because of some signal, except SIGINT (^C)
316dad8277db6575354eba30d3fc7a1c0447c513Timo Sirainen which is too common at least while testing :) */
316dad8277db6575354eba30d3fc7a1c0447c513Timo Sirainen if (lib_signal_kill != 0 && lib_signal_kill != 2)
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainen i_warning("Killed with signal %d", lib_signal_kill);
38a72d61d3a114816771f3045f374d56e2194232Timo Sirainenint main(int argc __attr_unused__, char *argv[], char *envp[])
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainen /* NOTE: we start rooted, so keep the code minimal until
548f87789cf9865572b7b86f7be5a9bbfa132f3fTimo Sirainen restrict_access_by_env() is called */