f000766bb501aa6f64648256e2d85f1c358fe438
[moodle.git] / mnet / remote_client.php
1 <?php // $Id$
2 /**
3  * An object to represent lots of information about an RPC-peer machine
4  *
5  * @author  Donal McMullan  donal@catalyst.net.nz
6  * @version 0.0.1
7  * @license http://www.gnu.org/copyleft/gpl.html GNU Public License
8  * @package mnet
9  */
11 class mnet_remote_client extends mnet_peer {
13     // If the remote client is trying to execute a method on an object instead
14     // of just a function, we'll instantiate the proper class and store it in
15     // this 'object_to_call' property, or 'static_location' if it wants to be called statically
16     var $object_to_call         = false;
17     var $static_location        = false;
18     var $request_was_encrypted  = false;
19     var $request_was_signed     = false;
20     var $signatureok = false; // True if we have successfully verified that the request was signed by an established peer
21     var $pushkey = false; // True if we need to tell the remote peer about our current public key
22     var $useprivatekey = ''; // The private key we should use to sign pushkey response
24     function was_encrypted() {
25         $this->request_was_encrypted  = true;
26     }
28     /* Record private key to use in pushkey response
29      * Called when we have decrypted a request using an old (but still acceptable) keypair
30      * @param $keyresource the private key we should use to sign the response.
31      */
32     function encrypted_to($keyresource) {
33         $this->useprivatekey = $keyresource;
34     }
36     function set_pushkey() {
37         $this->pushkey = true;
38     }
40     function was_signed() {
41         $this->request_was_signed  = true;
42     }
44     function signature_verified() {
45         $this->signatureok = true;
46     }
48     function object_to_call($object) {
49         $this->object_to_call = $object;
50     }
52     function static_location($location) {
53         $this->static_location = $location;
54     }
56     function plaintext_is_ok() {
57         global $CFG;
59         $trusted_hosts = explode(',', get_config('mnet', 'mnet_trusted_hosts'));
61         foreach($trusted_hosts as $host) {
62             list($network, $mask) = explode('/', $host.'/');
63             if (empty($network)) continue;
64             if (strlen($mask) == 0) $mask = 32;
65             
66             if (ip_in_range($_SERVER['REMOTE_ADDR'], $network, $mask)) {
67                 return true;
68             }
69         }
71         return false;
72     }
74     function refresh_key() {
75         global $CFG;
76         // set up an RPC request
77         require_once $CFG->dirroot.'/mnet/xmlrpc/client.php';
78         $mnetrequest = new mnet_xmlrpc_client();
79         // Use any method - listServices is pretty lightweight.
80         $mnetrequest->set_method('system/listServices');
82         // Do RPC call and store response
83         if ($mnetrequest->send($this) === true) {
84             // Ok - we actually don't care about the result
85             $temp = new mnet_peer();
86             $temp->set_id($this->id);
87             if($this->public_key != $temp->public_key) {
88                 $newkey = clean_param($temp->public_key, PARAM_PEM);
89                 if(!empty($newkey)) {
90                     $this->public_key = $newkey;
91                     return true;
92                 }
93             }
94         }
95         return false;
96     }
97 }
98 ?>