cfgfile.h 4.38 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
/* Icecast
 *
 * This program is distributed under the GNU General Public License, version 2.
 * A copy of this license is included with this source.
 *
 * Copyright 2000-2004, Jack Moffitt <jack@xiph.org, 
 *                      Michael Smith <msmith@xiph.org>,
 *                      oddsock <oddsock@xiph.org>,
 *                      Karl Heyes <karl@xiph.org>
 *                      and others (see AUTHORS for details).
 */

Karl Heyes's avatar
Karl Heyes committed
13 14
#ifndef __CFGFILE_H__
#define __CFGFILE_H__
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34

#define CONFIG_EINSANE -1
#define CONFIG_ENOROOT -2
#define CONFIG_EBADROOT -3
#define CONFIG_EPARSE -4

#define MAX_YP_DIRECTORIES 25


#include "thread/thread.h"
#include "avl/avl.h"
#include "global.h"

typedef struct ice_config_dir_tag
{
    char *host;
    int touch_interval;
    struct ice_config_dir_tag *next;
} ice_config_dir_t;

Michael Smith's avatar
Michael Smith committed
35 36 37 38 39 40
typedef struct _config_options {
    char *name;
    char *value;
    struct _config_options *next;
} config_options_t;

41 42 43 44 45 46 47 48 49 50
typedef struct _mount_proxy {
    char *mountname; /* The mountpoint this proxy is used for */

    char *username; /* Username and password for this mountpoint. If unset, */
    char *password; /* falls back to global source password */

    char *dumpfile; /* Filename to dump this stream to (will be appended). NULL
                       to not dump. */
    int max_listeners; /* Max listeners for this mountpoint only. -1 to not 
                          limit here (i.e. only use the global limit) */
Michael Smith's avatar
Michael Smith committed
51 52 53 54 55 56
    char *fallback_mount; /* Fallback mountname */

    int fallback_override; /* When this source arrives, do we steal back
                              clients from the fallback? */
    int no_mount; /* Do we permit direct requests of this mountpoint? (or only
                     indirect, through fallbacks) */
Karl Heyes's avatar
Karl Heyes committed
57 58 59
    int burst_size; /* amount to send to a new client if possible, -1 take
                     * from global setting */
    unsigned int queue_size_limit;
Karl Heyes's avatar
Karl Heyes committed
60
    int no_yp; /* Do we prevent YP on this mount */
61
    int hidden; /* Do we list this on the xsl pages */
Karl Heyes's avatar
Karl Heyes committed
62
    unsigned int source_timeout;  /* source timeout in seconds */
Michael Smith's avatar
Michael Smith committed
63 64

    char *auth_type; /* Authentication type */
65
    char *cluster_password;
Michael Smith's avatar
Michael Smith committed
66
    config_options_t *auth_options; /* Options for this type */
67 68 69 70 71 72 73 74 75 76 77 78 79 80
    struct _mount_proxy *next;
} mount_proxy;

typedef struct _aliases {
    char *source;
    char *destination;
    int port;
    char *bind_address;
    struct _aliases *next;
}aliases;

typedef struct {
    int port;
    char *bind_address;
81
    int shoutcast_compat;
82 83 84 85 86 87 88 89 90 91 92
} listener_t;

typedef struct ice_config_tag
{
    char *config_filename;

    char *location;
    char *admin;

    int client_limit;
    int source_limit;
Karl Heyes's avatar
Karl Heyes committed
93
    unsigned int queue_size_limit;
94
    int threadpool_size;
Karl Heyes's avatar
Karl Heyes committed
95
    unsigned int burst_size;
96 97 98 99 100 101
    int client_timeout;
    int header_timeout;
    int source_timeout;
    int ice_login;
    int fileserve;

102
    char *shoutcast_mount;
103 104 105
    char *source_password;
    char *admin_username;
    char *admin_password;
106 107
    char *relay_username;
    char *relay_password;
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127

    int touch_interval;
    ice_config_dir_t *dir_list;

    char *hostname;
    int port;

    listener_t listeners[MAX_LISTEN_SOCKETS];

    char *master_server;
    int master_server_port;
    int master_update_interval;
    char *master_password;

    relay_server *relay;

    mount_proxy *mounts;

    char *base_dir;
    char *log_dir;
128
    char *pidfile;
129 130 131 132 133 134
    char *webroot_dir;
    char *adminroot_dir;
    aliases *aliases;

    char *access_log;
    char *error_log;
135
    char *playlist_log;
136 137 138 139 140 141 142 143
    int loglevel;

    int chroot;
    int chuid;
    char *user;
    char *group;
    char *yp_url[MAX_YP_DIRECTORIES];
    int    yp_url_timeout[MAX_YP_DIRECTORIES];
144
    int    yp_touch_interval[MAX_YP_DIRECTORIES];
145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172
    int num_yp_directories;
} ice_config_t;

typedef struct {
    mutex_t config_lock;
    mutex_t relay_lock;
    mutex_t mounts_lock;
} ice_config_locks;

void config_initialize(void);
void config_shutdown(void);

int config_parse_file(const char *filename, ice_config_t *configuration);
int config_initial_parse_file(const char *filename);
int config_parse_cmdline(int arg, char **argv);
void config_set_config(ice_config_t *config);
void config_clear(ice_config_t *config);

int config_rehash(void);

ice_config_locks *config_locks(void);

ice_config_t *config_get_config(void);
void config_release_config(void);

/* To be used ONLY in one-time startup code */
ice_config_t *config_get_config_unlocked(void);

Karl Heyes's avatar
Karl Heyes committed
173
#endif  /* __CFGFILE_H__ */
174 175 176