Project

General

Profile

Download (6.29 KB) Statistics
| Branch: | Tag: | Revision:
1
#! /usr/local/bin/php -f
2
<?php
3
/*
4
	sshd - Modified to work on disk based system
5
	Copyright 2004 Scott K Ullrich
6

    
7
	Original Copyright (C) 2004 Fred Mol <fredmol@xs4all.nl>.
8
	All rights reserved.
9

    
10
	Redistribution and use in source and binary forms, with or without
11
	modification, are permitted provided that the following conditions are met:
12

    
13
	1. Redistributions of source code must retain the above copyright notice,
14
	   this list of conditions and the following disclaimer.
15

    
16
	2. Redistributions in binary form must reproduce the above copyright
17
	   notice, this list of conditions and the following disclaimer in the
18
	   documentation and/or other materials provided with the distribution.
19

    
20
	THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
21
	INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
22
	AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23
	AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
24
	OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25
	SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
	INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27
	CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28
	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29
	POSSIBILITY OF SUCH DAMAGE.
30
*/
31

    
32
	require_once("globals.inc");
33
	require_once("config.inc");
34
	require_once("functions.inc");
35
	require_once("shaper.inc");
36

    
37
	if(isset($config['system']['enablesshd'])) {
38
		/* do nothing, we're enabled */
39
	} else {
40
		if($g['booting'])
41
			echo "SSHD is disabled.";
42
		exit;
43
	}
44

    
45
	conf_mount_rw();
46

    
47
	function file_size($file) {
48
	  $size = filesize($file);
49
	  return $size;
50
	}
51

    
52
	/* restore ssh data for nanobsd platform */
53
	if($g['platform'] == "nanobsd" and file_exists("/conf/sshd/ssh_host_key")) {
54
		if(!file_exists("/etc/ssh/ssh_host_key.pub")) {
55
			echo "Restoring SSH from /conf/sshd/";
56
			exec("cp /conf/sshd/* /etc/ssh/");
57
		}
58
	}
59

    
60
	/*    if any of these files are 0 bytes then they are corrupted.
61
	 *    remove them
62
	 */
63
	$files_to_check = array('ssh_host_dsa_key','ssh_host_dsa_key.pub','ssh_host_key','ssh_host_key.pub','ssh_host_rsa_key','ssh_host_rsa_key.pub','/root/.ssh/authorized_keys');
64
	foreach($files_to_check as $f2c) {
65
		if(file_exists("/etc/ssh/{$f2c}"))
66
			if(file_size("/etc/ssh/{$f2c}")==0) {
67
				mwexec("rm /etc/ssh/ssh_host*", true);
68
			}
69
	}
70

    
71
	if (!is_dir("/var/empty")) {
72
		/* make ssh home directory */
73
		mkdir("/var/empty", 0555);
74
	}
75

    
76
	if(!file_exists("/var/log/lastlog")) {
77
		/* Login related files. */
78
		touch("/var/log/lastlog");
79
	}
80

    
81
	$sshConfigDir = "/etc/ssh";
82

    
83
	if($config['system']['ssh']['port'] <> "") {
84
		$sshport = $config['system']['ssh']['port'];
85
	} else {
86
		$sshport = 22;
87
	}
88

    
89
	/* Include default configuration for pfSense */
90
	$sshconf = "# This file is automatically generated at startup\n";
91
	$sshconf .= "Ciphers aes128-ctr,aes256-ctr,arcfour256,arcfour,aes128-cbc,aes256-cbc\n";
92
	$sshconf .= "PermitRootLogin yes\n";
93
	$sshconf .= "Compression yes\n";
94
	$sshconf .= "ClientAliveInterval 30\n";
95
	$sshconf .= "UseDNS no\n";
96
	$sshconf .= "X11Forwarding no\n";
97
	if(isset($config['system']['ssh']['sshdkeyonly'])) {
98
		$sshconf .= "# Login via Key only\n";
99
		$sshconf .= "PasswordAuthentication no\n";
100
		$sshconf .= "ChallengeResponseAuthentication no\n";
101
		$sshconf .= "PubkeyAuthentication yes\n";
102
	} else {
103
		$sshconf .= "# Login via Key and Password\n";
104
		$sshconf .= "PasswordAuthentication yes\n";
105
		$sshconf .= "ChallengeResponseAuthentication yes\n";
106
		$sshconf .= "PubkeyAuthentication yes\n";
107
	}
108
	$sshconf .= "# override default of no subsystems\n";
109
	$sshconf .= "Subsystem       sftp    /usr/libexec/sftp-server\n";
110
	/* Only allow protocol 2, because we say so */
111
	$sshconf .= "Protocol 2\n";
112
	/* Run the server on another port if we have one defined */
113
	$sshconf .= "Port $sshport\n";
114

    
115
	/* Write the new sshd config file */
116
	$fd = fopen("/etc/ssh/sshd_config", "w");
117
	fwrite($fd, $sshconf);
118
	fclose($fd);
119

    
120
	/* mop up from a badly implemented ssh keys -> cf backup */
121
	if($config['ssh']['dsa_key'] <> "") {
122
		unset($config['ssh']['dsa_key']);
123
		unset($config['ssh']['rsa_key']);
124
		unset($config['ssh']['rsa1_key']);
125
		unset($config['ssh']['dsa']);
126
		unset($config['ssh']['rsa']);
127
		unset($config['ssh']['rsa1']);
128
		unset($config['ssh']['ak']);
129
		write_config("Clearing SSH keys from config.xml");
130
	}
131

    
132
	/* are we already running?  if so exit */
133
	if(is_subsystem_dirty('sshdkeys')) {
134
		conf_mount_ro();
135
		exit;
136
	}
137
	
138
	// Check for all needed key files. If any are missing, the keys need to be regenerated.
139
	$files_to_check = array('ssh_host_dsa_key','ssh_host_dsa_key.pub','ssh_host_key','ssh_host_key.pub','ssh_host_rsa_key','ssh_host_rsa_key.pub');
140
	$generate_keys = false;
141
	foreach ($files_to_check as $f2c) {
142
		if (!file_exists("/etc/ssh/{$f2c}")) {
143
			$generate_keys = true;
144
		}
145
	}
146
	if ($generate_keys) {
147
		/* remove previous keys and regen later */
148
		file_notice("SSH", "{$g['product_name']} has started creating your SSH keys.  SSH Startup will be delayed.  Please note that reloading the filter rules and changes will be delayed until this operation is completed.", "SSH KeyGen", "");
149
		mwexec("rm /etc/ssh/ssh_host_*", true);
150
		mark_subsystem_dirty('sshdkeys');
151
		echo " Generating Keys:\n";
152
		system("/usr/bin/nice -n20 /usr/bin/ssh-keygen -t rsa1 -N '' -f $sshConfigDir/ssh_host_key");
153
		system("/usr/bin/nice -n20 /usr/bin/ssh-keygen -t rsa -N '' -f $sshConfigDir/ssh_host_rsa_key");
154
		system("/usr/bin/nice -n20 /usr/bin/ssh-keygen -t dsa -N '' -f $sshConfigDir/ssh_host_dsa_key");
155
		clear_subsystem_dirty('sshdkeys');
156
		file_notice("SSH", "{$g['product_name']} has completed creating your SSH keys.  SSH is now started.", "SSH Startup", "");
157
		echo "Starting SSH... ";
158
	}
159

    
160
	/* kill existing sshd process, server only, not the childs */
161
	$sshd_pid = exec("ps ax | egrep '/usr/sbin/[s]shd' | awk '{print $1}'");
162
	if($sshd_pid <> "") {
163
		echo "stopping ssh process $sshd_pid \n";
164
		mwexec("kill $sshd_pid");
165
	}
166
	/* Launch new server process */
167
	$status = mwexec("/usr/sbin/sshd");
168
	if($status <> 0) {
169
		file_notice("sshd_startup", "SSHD failed to start.", "SSHD Daemon", "");
170
		echo "error!\n";
171
	} else {
172
		echo "done.\n";
173
	}
174

    
175
	// NanoBSD
176
	if($g['platform'] == "nanobsd") {
177
		if(!is_dir("/conf/sshd"))
178
			exec("mkdir /conf/sshd");
179
		exec("cp /etc/ssh/ssh_host* /conf/sshd");
180
	}
181
	conf_mount_ro();
182

    
183
?>
(92-92/98)