summaryrefslogtreecommitdiff
path: root/INSTALL
blob: 6a85252f2da15293aebd1d3d9276f34bf45bea40 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
rssh installation
-----------------

If you are upgrading from a previous version of rssh, see the notes in the
last section of this file.  Otherwise, to install rssh, the following steps
should suffice:

  $ ./configure
  $ make
  $ su root
  # make install

If you are already root, make install should suffice; however it is generally
considered bad practice to build software as root.  To change where rssh is
installed, use the --prefix option to configure:

  $ ./configure --prefix=/var/rssh

The configure script will look for the scp and sftp-server binaries in
common locations.  If it does not find them, you must set the location manually
using the --with-scp and --with-sftp-server options, like so:

  $ ./configure --with-scp=/path/to/scp --with-sftp-server=/var/lib/sftp-server

The program will not work properly if the paths for these executables is not
correct.  If you are planning to use chroot jails, you need to make sure you
have copies of those binaries at the same configured locations, RELATIVE TO
THE ROOT OF THE CHROOT JAIL.  See the file CHROOT for more information about
setting up a chroot jail.


STATIC vs. DYNAMIC LINKING
--------------------------

Because of the security implications mentioned in the file SECURITY, the
default is to compile rssh statically.  Note however that this results in a
very large executable size.  If you wish to use shared libraries with rssh,
you can do so by removing the -static from the variable CFLAGS in the first
few lines of the file Makefile.  Warning: you should only do this if at least
one of the following is true:

  - you are using rssh with OpenSSH 3.5 or later and have disabled user
    environment files
  - you have made sure the users' home directories and .ssh director are
    non-writable
  - you don't care about your users' ability to circumvent rssh.

Otherwise, your users will be able to execute arbitrary commands and gain
shell access to the system you are trying to restrict with rssh.

Note that ./configure now detects if you have OpenSSH v3.5 installed, and if
so will use dynamic linking by default.  However, it is still up to the system
administrator to be sure to use the PermitUserEnvironment=no option when
configuring sshd.  Failing to do so will allow users to circumvent the
protections offered by rssh.

SOLARIS USERS TAKE NOTE: Due to brain damage in Solaris's C libraries, it is
very difficult to build static binaries (of just about any program) on
Solaris, and even if you succeed, the binaries you build may not work.  Make
sure you run the configure script with --disable-static to build dynamically
linked binaries.  This implies that you should be running OpenSSH 3.5 or
later, with the option PermitUserEnvironment set to no, for security reasons.
See the file SECURITY and/or the rssh man page for more information.


Upgrading from a previous version of rssh
-----------------------------------------

If you are upgrading to 2.2.x from a previous 2.x.x release, you should note
that the configuration file format has changed.  A shell script is provided to
convert between the old format and the new format.  The change in formats is
very minor; there are extra digits in the permissions field.  The script
initializes any existing entries to all zeros for the new permissions fields.

If your config file is /etc/rssh.conf, you can invoke the script simply like
this:

  # ./conf_convert.sh

Otherwise, you must pass the location of the config file on the command line,
like so:

  # ./conf_convert.sh /usr/local/etc/rssh.conf

The script will save a new copy of your config file with the necessary changes
into <path to old config file>.NEW if it is successful.   BE VERY CAREFUL!
Depending on if you do any strange quoting in your config file, the restulting
config file may not be usable.  It should be fine for most users, however.