1
0
mirror of https://github.com/osmarks/ngircd.git synced 2025-01-19 03:52:52 +00:00
ngircd/INSTALL

187 lines
6.0 KiB
Plaintext
Raw Normal View History

ngIRCd - Next Generation IRC Server
(c)2001-2004 by Alexander Barton,
alex@barton.de, http://www.barton.de/
2003-03-04 13:46:53 +00:00
ngIRCd is free software and published under the
terms of the GNU General Public License.
2003-03-04 13:46:53 +00:00
-- INSTALL --
2002-12-18 12:19:07 +00:00
2003-03-04 13:46:53 +00:00
2002-12-18 12:19:07 +00:00
2003-03-04 13:46:53 +00:00
I. Upgrade Information
~~~~~~~~~~~~~~~~~~~~~~
2002-12-18 12:19:07 +00:00
Differences to version 0.8.x
- The maximum length of passwords has been raised to 20 characters (instead
of 8 characters). If your passwords are longer than 8 characters then they
are cut at an other position now.
2003-03-07 14:45:10 +00:00
Differences to version 0.6.x
- Some options of the configure script have been renamed:
--disable-syslog -> --without-syslog
--disable-zlib -> --without-zlib
Please call "./configure --help" to review the full list of options!
2003-03-04 13:46:53 +00:00
Differences to version 0.5.x
2002-12-18 12:19:07 +00:00
- Starting with version 0.6.0, other servers are identified using asynchronous
2003-03-04 13:46:53 +00:00
passwords: therefore the variable "Password" in [Server]-sections has been
replaced by "MyPassword" and "PeerPassword".
2003-03-04 13:46:53 +00:00
- New configuration variables, section [Global]: MaxConnections, MaxJoins
(see example configuration file "doc/sample-ngircd.conf"!).
2003-03-04 13:46:53 +00:00
II. Standard Installation
~~~~~~~~~~~~~~~~~~~~~~~~~
2003-03-23 23:13:15 +00:00
ngIRCd is developed for UNIX-based systems, which means that the installation
on modern UNIX-like systems that are supported by GNU autoconf and GNU
2003-03-04 13:46:53 +00:00
automake ("configure") should be no problem.
2003-03-04 13:46:53 +00:00
The normal installation procedure after getting (and expanding) the source
files (using a distribution archive or CVS) is as following:
2003-03-04 13:46:53 +00:00
1) ./autogen.sh [only necessary when using CVS]
2) ./configure
3) make
4) make install
2004-09-03 20:01:12 +00:00
(Please see details below!)
Now the newly compiled executable "ngircd" is installed in its standard
location, /usr/local/sbin/.
The next step is to configure and afterwards starting the daemon. Please
have a look at the ngircd(8) and ngircd.conf(5) manual pages for details
and all possible options.
If no previous version of the configuration file exists (the standard name
is /usr/local/etc/ngircd.conf), a sample configuration file containing all
possible options will be installed there. You'll find its template in the
doc/ directory: sample-ngircd.conf.
2003-03-08 12:34:55 +00:00
2003-03-04 13:46:53 +00:00
1): "autogen.sh"
2003-03-04 13:46:53 +00:00
The first step, autogen.sh, is only necessary if the configure-script isn't
already generated. This never happens in official ("stable") releases in
tar.gz-archives, but when using CVS.
This step is therefore only interesting for developers.
2003-03-04 13:46:53 +00:00
autogen.sh produces the Makefile.in's, which are necessary for the configure
script itself, and some more files for make. To run autogen.sh you'll need
2003-03-08 12:34:55 +00:00
GNU autoconf and GNU automake (use recent versions! autoconf 2.53 and
automake 1.6.1 are known to work).
2003-03-04 13:46:53 +00:00
Again: "end users" do not need this step!
2003-03-08 12:34:55 +00:00
2): "./configure"
The configure-script is used to detect local system dependencies.
In the perfect case, configure should recognise all needed libraries, header
2003-03-04 13:46:53 +00:00
files and so on. If this shouldn't work, "./configure --help" shows all
possible options.
2003-03-04 13:46:53 +00:00
In addition, you can pass some command line options to "configure" to enable
and/or disable some features of ngIRCd. All these options are shown using
"./configure --help", too.
Compiling a static binary will avoid you the hassle of feeding a chroot dir
(if you want use the chroot feature). Just do something like:
CFLAGS=-static ./configure [--your-options ...]
Then you can use a void directory as ChrootDir (like OpenSSH's /var/empty).
2003-03-08 12:34:55 +00:00
3): "make"
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
The make command uses the Makefiles produced by configure and compiles the
ngIRCd daemon.
2002-05-08 15:44:43 +00:00
2003-03-08 12:34:55 +00:00
4): "make install"
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
Use "make install" to install the server and a sample configuration file on
the local system. Normally, root privileges are necessary to complete this
step. If there is already an older configuration file present, it won't be
overwritten.
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
This files will be installed by default:
2002-05-08 15:44:43 +00:00
- /usr/local/sbin/ngircd: executable server
2003-03-04 13:46:53 +00:00
- /usr/local/etc/ngircd.conf: sample configuration (if not already present)
2003-04-21 23:31:39 +00:00
- /usr/local/share/doc/ngircd/: documentation
2003-03-04 13:46:53 +00:00
II. Useful make-targets
~~~~~~~~~~~~~~~~~~~~~~~
2003-03-04 13:46:53 +00:00
The Makefile produced by the configure-script contains always these useful
targets:
2003-03-04 13:46:53 +00:00
- clean: delete every product from the compiler/linker
next step: -> make
2003-03-04 13:46:53 +00:00
- distclean: the above plus erase all generated Makefiles
next step: -> ./configure
- maintainer-clean: erase all automatic generated files
2003-03-04 13:46:53 +00:00
next step: -> ./autogen.sh
2002-03-03 13:07:01 +00:00
2003-03-04 13:46:53 +00:00
III. Sample configuration file ngircd.conf
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
In the sample configuration file, there are comments beginning with "#" OR
";" -- this is only for the better understanding of the file.
2002-05-08 15:44:43 +00:00
The file is separated in four blocks: [Global], [Operator], [Server], and
2003-03-10 00:23:34 +00:00
[Channel].
In the [Global] section, there is the main configuration like the server
name and the ports, on which the server should be listening. IRC operators
of this server are defined in [Operator] blocks. [Server] is the section
where server links are configured. And [Channel] blocks are used to
2003-03-04 13:46:53 +00:00
configure pre-defined ("persistent") IRC channels.
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
The meaning of the variables in the configuration file is explained in the
"doc/sample-ngircd.conf", which is used as sample configuration file in
2003-03-10 00:23:34 +00:00
/usr/local/etc after running "make install" (if you don't already have one)
and in the "ngircd.conf" manual page.
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
IV. Command line options
~~~~~~~~~~~~~~~~~~~~~~~~
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
These parameters could be passed to the ngIRCd:
2002-05-08 15:44:43 +00:00
-f, --config <file>
2003-03-04 13:46:53 +00:00
The daemon uses the file <file> as configuration file rather than
the standard configuration /usr/local/etc/ngircd.conf.
2002-05-08 15:44:43 +00:00
-n, --nodaemon
2003-03-04 13:46:53 +00:00
ngIRCd should be running as a foreground process.
2002-05-08 15:44:43 +00:00
-p, --passive
2003-03-04 13:46:53 +00:00
Server-links won't be automatically established.
2002-05-08 15:44:43 +00:00
2004-02-22 22:12:44 +00:00
-t, --configtest
2003-03-04 13:46:53 +00:00
Reads, validates and dumps the configuration file as interpreted
by the server. Then exits.
2002-05-08 15:44:43 +00:00
2003-03-04 13:46:53 +00:00
Use "--help" to see a short help text describing all available parameters
the server understands, with "--version" the ngIRCd shows its version
number. In both cases the server exits after the output.
2002-05-08 15:44:43 +00:00
2002-03-03 13:07:01 +00:00
--
$Id: INSTALL,v 1.21 2005/02/10 08:20:09 alex Exp $