Project

General

Profile

Download (7.25 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php
2
/*
3
	$Id$
4
	
5
        xmlrpc.php
6
        Copyright (C) 2005 Colin Smith
7
        All rights reserved.
8

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

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

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

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

    
30
	TODO:
31
		* Expose more functions.
32
*/
33

    
34
require_once("xmlrpc_server.inc");
35
require_once("xmlrpc.inc");
36
require_once("config.inc");
37
require_once("functions.inc");
38
require_once("array_intersect_key.inc");
39

    
40
$xmlrpc_g = array(
41
			"return" => array(
42
						"true" => new XML_RPC_Response(new XML_RPC_Value(true, $XML_RPC_Boolean)),
43
						"false" => new XML_RPC_Response(new XML_RPC_Value(false, $XML_RPC_Boolean)),
44
						"authfail" => new XML_RPC_Response(0, $XML_RPC_erruser+1, "Authentication failure")
45
				)
46
		);
47

    
48
/*
49
 *   pfSense XMLRPC errors
50
 *   $XML_RPC_erruser + 1 = Auth failure
51
 */
52
$XML_RPC_erruser = 200;
53

    
54
/* EXPOSED FUNCTIONS */
55

    
56
$backup_config_section_doc = 'XMLRPC wrapper for backup_config_section. This method must be called with two parameters: a string containing the local system\'s password followed by an array containing the keys to be backed up.';
57
$backup_config_section_sig = array(
58
				array(
59
					$XML_RPC_Struct, // First signature element is return value.
60
					$XML_RPC_String,
61
					$XML_RPC_Array
62
				)
63
			);
64

    
65
function backup_config_section_xmlrpc($raw_params) {
66
	global $config, $xmlrpc_g;
67
	$params = xmlrpc_params_to_php($raw_params);
68
	if(!xmlrpc_auth($params)) return $xmlrpc_g['return']['authfail'];
69
	$val = array_intersect_key($config, array_flip($params[0]));
70
	return new XML_RPC_Response(XML_RPC_encode($val));
71
}
72

    
73
/*****************************/
74

    
75
$restore_config_section_doc = 'XMLRPC wrapper for restore_config_section. This method must be called with two parameters: a string containing the local system\'s password and an array to merge into the system\'s config. This function returns true upon completion.';
76
$restore_config_section_sig = array(
77
					array(
78
						$XML_RPC_Boolean,
79
						$XML_RPC_String,
80
						$XML_RPC_Struct
81
					)
82
				);
83

    
84
function restore_config_section_xmlrpc($raw_params) {
85
	global $config, $xmlrpc_g;
86
	$params = xmlrpc_params_to_php($raw_params);
87
	if(!xmlrpc_auth($params)) return $xmlrpc_g['return']['authfail'];
88
	$config = array_merge($config, $params[0]);
89
	$mergedkeys = implode(",", array_keys($params[0]));
90
	write_config("Merged in config ({$mergedkeys} sections) from XMLRPC client.");
91
	return $xmlrpc_g['return']['true'];
92
}
93

    
94
/*****************************/
95

    
96
$filter_configure_doc = 'Basic XMLRPC wrapper for filter_configure. This method must be called with one paramater: a string containing the local system\'s password. This function returns true upon completion.';
97
$filter_configure_sig = array(
98
				array(
99
					$XML_RPC_Boolean,
100
					$XML_RPC_String
101
				)
102
			);
103

    
104
function filter_configure_xmlrpc($raw_params) {
105
	global $xmlrpc_g;
106
	$params = xmlrpc_params_to_php($raw_params);
107
	if(!xmlrpc_auth($params)) return $xmlrpc_g['return']['authfail'];
108
	filter_configure();
109
	return $xmlrpc_g['return']['true'];
110
}
111

    
112
/*****************************/
113

    
114
$check_firmware_version_doc = 'Basic XMLRPC wrapper for filter_configure. This function will return the output of check_firmware_version upon completion.';
115
$check_firmware_version_sig = array(
116
					array(
117
						$XML_RPC_String,
118
						$XML_RPC_String
119
					)
120
				);
121

    
122
function check_firmware_version_xmlrpc($raw_params) {
123
	return new XML_RPC_Response(new XML_RPC_Value(check_firmware_version(false), $XML_RPC_String));
124
}
125

    
126
/*****************************/
127

    
128
$reboot_doc = 'Basic XMLRPC wrapper for rc.reboot.';
129
$reboot_sig = array(array($XML_RPC_Boolean, $XML_RPC_String));
130

    
131
function reboot_xmlrpc($raw_params) {
132
	global $xmlrpc_g;
133
	$params = xmlrpc_params_to_php($raw_params);
134
	if(!xmlrpc_auth($params)) return $xmlrpc_g['return']['authfail'];
135
	mwexec_bg("/etc/rc.reboot");
136
	return $xmlrpc_g['return']['true'];
137
}
138

    
139
/*****************************/
140

    
141
$get_notices_sig = array(
142
				array(
143
					$XML_RPC_Array, 
144
					$XML_RPC_String
145
				),
146
				array(
147
					$XML_RPC_Array
148
				)
149
			);
150

    
151
function get_notices_xmlrpc($raw_params) {
152
	global $g, $xmlrpc_g;
153
	require_once("notices.inc");
154
	$params = array_pop(xmlrpc_params_to_php($raw_params));
155
	if(!$params) {
156
		$toreturn = get_notices();
157
	} else {
158
		$toreturn = get_notices($params);
159
	}
160
	$response = new XML_RPC_Response(XML_RPC_encode($toreturn));
161
	return $response;
162
}
163

    
164
/*****************************/
165

    
166
$carp_configure_doc = 'Basic XMLRPC wrapper for configuring CARP interfaces.';
167
$carp_configure_sig = array(
168
				array(
169
					$XML_RPC_Boolean,
170
					$XML_RPC_String
171
				)
172
			);
173
			
174
function interfaces_carp_configure_xmlrpc($raw_params) {
175
	global $xmlrpc_g;
176
	$params = xmlrpc_params_to_php($raw_params);
177
	if(!xmlrpc_auth($params)) return new XML_RPC_Response(new XML_RPC_Value("auth_failure", $XML_RPC_String));
178
	interfaces_carp_configure();
179
	interfaces_carp_bring_up_final();
180
	return new XML_RPC_Response(new XML_RPC_Value(true, $XML_RPC_Boolean));
181
}
182

    
183
/*****************************/
184

    
185
$server = new XML_RPC_Server(
186
        array(
187
            'pfsense.interfaces_carp_configure' => array('function' => 'interfaces_carp_configure_xmlrpc',
188
							'signature' => $carp_configure_doc,
189
							'docstring' => $carp_configure_sig),
190
            'pfsense.backup_config_section' => 	array('function' => 'backup_config_section_xmlrpc',
191
							'signature' => $backup_config_section_sig,
192
							'docstring' => $backup_config_section_doc),
193
	    'pfsense.restore_config_section' => array('function' => 'restore_config_section_xmlrpc',
194
							'signature' => $restore_config_section_sig,
195
							'docstring' => $restore_config_section_doc),
196
	    'pfsense.filter_configure' => 	array('function' => 'filter_configure_xmlrpc',
197
							'signature' => $filter_configure_sig,
198
							'docstring' => $filter_configure_doc),
199
	    'pfsense.check_firmware_version' =>	array('function' => 'check_firmware_version_xmlrpc',
200
							'signature' => $check_firmware_version_sig,
201
							'docstring' => $check_firmware_version_doc),
202
	    'pfsense.reboot' =>			array('function' => 'reboot_xmlrpc',
203
							'signature' => $reboot_sig,
204
							'docstring' => $reboot_doc),
205
	    'pfsense.get_notices' =>		array('function' => 'get_notices_xmlrpc',
206
							'signature' => $get_notices_sig)
207
        )
208
);
209
?>
(155-155/155)