thomascube
2012-03-03 884add1419729cb8eb5ed8fb47ea68e5f6ce6682
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php
 
/**
 * cPanel Password Driver
 *
 * Driver that adds functionality to change the users cPanel password.
 * The cPanel PHP API code has been taken from: http://www.phpclasses.org/browse/package/3534.html
 *
 * This driver has been tested with Hostmonster hosting and seems to work fine.
 *
 * @version 2.0
 * @author Fulvio Venturelli <fulvio@venturelli.org>
 */
 
class rcube_cpanel_password
{
    public function save($curpas, $newpass)
    {
        $rcmail = rcmail::get_instance();
 
        // Create a cPanel email object
        $cPanel = new emailAccount($rcmail->config->get('password_cpanel_host'),
        $rcmail->config->get('password_cpanel_username'),
        $rcmail->config->get('password_cpanel_password'),
        $rcmail->config->get('password_cpanel_port'),
        $rcmail->config->get('password_cpanel_ssl'),
        $rcmail->config->get('password_cpanel_theme'),
        $_SESSION['username'] );
 
        if ($cPanel->setPassword($newpass)){
            return PASSWORD_SUCCESS;
        }
        else {
            return PASSWORD_ERROR;
        }
    }
}
 
 
class HTTP
{
    function HTTP($host, $username, $password, $port, $ssl, $theme)
    {
        $this->ssl = $ssl ? 'ssl://' : '';
        $this->username = $username;
        $this->password = $password;
        $this->theme = $theme;
        $this->auth = base64_encode($username . ':' . $password);
        $this->port = $port;
        $this->host = $host;
        $this->path = '/frontend/' . $theme . '/';
    }
 
    function getData($url, $data = '')
    {
        $url = $this->path . $url;
        if(is_array($data))
        {
            $url = $url . '?';
            foreach($data as $key=>$value)
            {
                $url .= urlencode($key) . '=' . urlencode($value) . '&';
            }
            $url = substr($url, 0, -1);
        }
        $response = '';
        $fp = fsockopen($this->ssl . $this->host, $this->port);
        if(!$fp)
        {
            return false;
        }
        $out = 'GET ' . $url . ' HTTP/1.0' . "\r\n";
        $out .= 'Authorization: Basic ' . $this->auth . "\r\n";
        $out .= 'Connection: Close' . "\r\n\r\n";
        fwrite($fp, $out);
        while (!feof($fp))
        {
            $response .= @fgets($fp);
        }
        fclose($fp);
        return $response;
    }
}
 
 
class emailAccount
{
    function emailAccount($host, $username, $password, $port, $ssl, $theme, $address)
    {
        $this->HTTP = new HTTP($host, $username, $password, $port, $ssl, $theme);
        if(strpos($address, '@'))
        {
            list($this->email, $this->domain) = explode('@', $address);
        }
        else
        {
            list($this->email, $this->domain) = array($address, '');
        }
    }
 
    /**
     * Change email account password
     *
     * Returns true on success or false on failure.
     * @param string $password email account password
     * @return bool
     */
    function setPassword($password)
    {
        $data['email'] = $this->email;
        $data['domain'] = $this->domain;
        $data['password'] = $password;
        $response = $this->HTTP->getData('mail/dopasswdpop.html', $data);
        if(strpos($response, 'success') && !strpos($response, 'failure'))
        {
            return true;
        }
        return false;
    }
}