blob: 014f62b3e01a8f430d4174a42f6cb2f9eadb2d51 [file] [log] [blame]
Ben Lindstromf96704d2001-06-25 04:17:12 +00001/* $OpenBSD: pathnames.h,v 1.8 2001/06/22 21:55:49 markus Exp $ */
Ben Lindstrom36579d32001-01-29 07:39:26 +00002
Ben Lindstrom226cfa02001-01-22 05:34:40 +00003/*
4 * Author: Tatu Ylonen <ylo@cs.hut.fi>
5 * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
6 * All rights reserved
7 *
8 * As far as I am concerned, the code I have written for this software
9 * can be used freely for any purpose. Any derived versions of this
10 * software must be clearly marked as such, and if the derived work is
11 * incompatible with the protocol description in the RFC file, it must be
12 * called by a name other than "ssh" or "Secure Shell".
13 */
14
15#ifndef ETCDIR
16#define ETCDIR "/etc"
17#endif
18
19#ifndef _PATH_SSH_PIDDIR
20#define _PATH_SSH_PIDDIR "/var/run"
21#endif
22
23/*
24 * System-wide file containing host keys of known hosts. This file should be
25 * world-readable.
26 */
27#define _PATH_SSH_SYSTEM_HOSTFILE ETCDIR "/ssh_known_hosts"
28#define _PATH_SSH_SYSTEM_HOSTFILE2 ETCDIR "/ssh_known_hosts2"
29
30/*
31 * Of these, ssh_host_key must be readable only by root, whereas ssh_config
32 * should be world-readable.
33 */
Ben Lindstrom226cfa02001-01-22 05:34:40 +000034#define _PATH_SERVER_CONFIG_FILE ETCDIR "/sshd_config"
35#define _PATH_HOST_CONFIG_FILE ETCDIR "/ssh_config"
Ben Lindstrom5eabda32001-04-12 23:34:34 +000036#define _PATH_HOST_KEY_FILE ETCDIR "/ssh_host_key"
Ben Lindstrom226cfa02001-01-22 05:34:40 +000037#define _PATH_HOST_DSA_KEY_FILE ETCDIR "/ssh_host_dsa_key"
Ben Lindstrom5eabda32001-04-12 23:34:34 +000038#define _PATH_HOST_RSA_KEY_FILE ETCDIR "/ssh_host_rsa_key"
Ben Lindstrom93a29e02001-06-25 04:13:25 +000039#define _PATH_DH_MODULI ETCDIR "/moduli"
40/* Backwards compatibility */
Ben Lindstrom226cfa02001-01-22 05:34:40 +000041#define _PATH_DH_PRIMES ETCDIR "/primes"
42
Ben Lindstrom27eebe62001-01-25 23:04:22 +000043#ifndef _PATH_SSH_PROGRAM
Ben Lindstrom226cfa02001-01-22 05:34:40 +000044#define _PATH_SSH_PROGRAM "/usr/bin/ssh"
Ben Lindstrom27eebe62001-01-25 23:04:22 +000045#endif
Ben Lindstrom226cfa02001-01-22 05:34:40 +000046
47/*
48 * The process id of the daemon listening for connections is saved here to
49 * make it easier to kill the correct daemon when necessary.
50 */
51#define _PATH_SSH_DAEMON_PID_FILE _PATH_SSH_PIDDIR "/sshd.pid"
52
53/*
54 * The directory in user\'s home directory in which the files reside. The
55 * directory should be world-readable (though not all files are).
56 */
57#define _PATH_SSH_USER_DIR ".ssh"
58
59/*
60 * Per-user file containing host keys of known hosts. This file need not be
61 * readable by anyone except the user him/herself, though this does not
62 * contain anything particularly secret.
63 */
64#define _PATH_SSH_USER_HOSTFILE "~/.ssh/known_hosts"
65#define _PATH_SSH_USER_HOSTFILE2 "~/.ssh/known_hosts2"
66
67/*
68 * Name of the default file containing client-side authentication key. This
69 * file should only be readable by the user him/herself.
70 */
71#define _PATH_SSH_CLIENT_IDENTITY ".ssh/identity"
72#define _PATH_SSH_CLIENT_ID_DSA ".ssh/id_dsa"
73#define _PATH_SSH_CLIENT_ID_RSA ".ssh/id_rsa"
74
75/*
76 * Configuration file in user\'s home directory. This file need not be
77 * readable by anyone but the user him/herself, but does not contain anything
78 * particularly secret. If the user\'s home directory resides on an NFS
79 * volume where root is mapped to nobody, this may need to be world-readable.
80 */
81#define _PATH_SSH_USER_CONFFILE ".ssh/config"
82
83/*
84 * File containing a list of those rsa keys that permit logging in as this
85 * user. This file need not be readable by anyone but the user him/herself,
86 * but does not contain anything particularly secret. If the user\'s home
87 * directory resides on an NFS volume where root is mapped to nobody, this
88 * may need to be world-readable. (This file is read by the daemon which is
89 * running as root.)
90 */
91#define _PATH_SSH_USER_PERMITTED_KEYS ".ssh/authorized_keys"
Ben Lindstromf96704d2001-06-25 04:17:12 +000092
93/* backward compat for protocol v2 */
Ben Lindstrom226cfa02001-01-22 05:34:40 +000094#define _PATH_SSH_USER_PERMITTED_KEYS2 ".ssh/authorized_keys2"
95
96/*
97 * Per-user and system-wide ssh "rc" files. These files are executed with
98 * /bin/sh before starting the shell or command if they exist. They will be
99 * passed "proto cookie" as arguments if X11 forwarding with spoofing is in
100 * use. xauth will be run if neither of these exists.
101 */
102#define _PATH_SSH_USER_RC ".ssh/rc"
103#define _PATH_SSH_SYSTEM_RC ETCDIR "/sshrc"
104
105/*
106 * Ssh-only version of /etc/hosts.equiv. Additionally, the daemon may use
107 * ~/.rhosts and /etc/hosts.equiv if rhosts authentication is enabled.
108 */
109#define _PATH_SSH_HOSTS_EQUIV ETCDIR "/shosts.equiv"
110#define _PATH_RHOSTS_EQUIV "/etc/hosts.equiv"
111
112/*
113 * Default location of askpass
114 */
Ben Lindstromcb577332001-01-22 21:06:19 +0000115#ifndef _PATH_SSH_ASKPASS_DEFAULT
Ben Lindstrom226cfa02001-01-22 05:34:40 +0000116#define _PATH_SSH_ASKPASS_DEFAULT "/usr/X11R6/bin/ssh-askpass"
Ben Lindstromcb577332001-01-22 21:06:19 +0000117#endif
Ben Lindstrom226cfa02001-01-22 05:34:40 +0000118
119/* for scp */
120#ifndef _PATH_CP
121#define _PATH_CP "cp"
122#endif
123
Damien Millerd7686fd2001-02-10 00:40:03 +1100124/* for sftp */
125#ifndef _PATH_SFTP_SERVER
126#define _PATH_SFTP_SERVER "/usr/libexec/sftp-server"
127#endif
Damien Miller896b88a2001-02-27 14:42:48 +1100128#ifndef _PATH_LS
Damien Millerd7686fd2001-02-10 00:40:03 +1100129#define _PATH_LS "ls"
Damien Miller896b88a2001-02-27 14:42:48 +1100130#endif
Damien Millerd7686fd2001-02-10 00:40:03 +1100131
Ben Lindstrom226cfa02001-01-22 05:34:40 +0000132/* path to login program */
133#ifndef LOGIN_PROGRAM
134# ifdef LOGIN_PROGRAM_FALLBACK
135# define LOGIN_PROGRAM LOGIN_PROGRAM_FALLBACK
136# else
137# define LOGIN_PROGRAM "/usr/bin/login"
138# endif
139#endif /* LOGIN_PROGRAM */
140
141/* Askpass program define */
142#ifndef ASKPASS_PROGRAM
143#define ASKPASS_PROGRAM "/usr/lib/ssh/ssh-askpass"
144#endif /* ASKPASS_PROGRAM */
145
146/*
147 * Relevant only when using builtin PRNG.
148 */
149#ifndef SSH_PRNG_SEED_FILE
Ben Lindstromcb577332001-01-22 21:06:19 +0000150# define SSH_PRNG_SEED_FILE _PATH_SSH_USER_DIR"/prng_seed"
Ben Lindstrom226cfa02001-01-22 05:34:40 +0000151#endif /* SSH_PRNG_SEED_FILE */
152#ifndef SSH_PRNG_COMMAND_FILE
153# define SSH_PRNG_COMMAND_FILE ETCDIR "/ssh_prng_cmds"
154#endif /* SSH_PRNG_COMMAND_FILE */
155