Blame view

sources/apps/files_encryption/lib/session.php 6.07 KB
03e52840d   Kload   Init
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
  <?php
  /**
   * ownCloud
   *
   * @author Sam Tuke
   * @copyright 2012 Sam Tuke samtuke@owncloud.com
   *
   * This library is free software; you can redistribute it and/or
   * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
   * License as published by the Free Software Foundation; either
   * version 3 of the License, or any later version.
   *
   * This library is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   * GNU AFFERO GENERAL PUBLIC LICENSE for more details.
   *
   * You should have received a copy of the GNU Affero General Public
   * License along with this library.  If not, see <http://www.gnu.org/licenses/>.
   *
   */
  
  namespace OCA\Encryption;
  
  /**
   * Class for handling encryption related session data
   */
  
  class Session {
  
  	private $view;
31b7f2792   Kload   Upgrade to ownclo...
32
33
34
  	const NOT_INITIALIZED = '0';
  	const INIT_EXECUTED = '1';
  	const INIT_SUCCESSFUL = '2';
03e52840d   Kload   Init
35
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
36
37
  	 * if session is started, check if ownCloud key pair is set up, if not create it
  	 * @param \OC\Files\View $view
03e52840d   Kload   Init
38
39
40
41
42
43
44
45
46
47
48
49
  	 *
  	 * @note The ownCloud key pair is used to allow public link sharing even if encryption is enabled
  	 */
  	public function __construct($view) {
  
  		$this->view = $view;
  
  		if (!$this->view->is_dir('owncloud_private_key')) {
  
  			$this->view->mkdir('owncloud_private_key');
  
  		}
6d9380f96   Cédric Dupont   Update sources OC...
50
51
52
  		$appConfig = \OC::$server->getAppConfig();
  
  		$publicShareKeyId = $appConfig->getValue('files_encryption', 'publicShareKeyId');
03e52840d   Kload   Init
53
54
55
  
  		if ($publicShareKeyId === null) {
  			$publicShareKeyId = 'pubShare_' . substr(md5(time()), 0, 8);
6d9380f96   Cédric Dupont   Update sources OC...
56
  			$appConfig->setValue('files_encryption', 'publicShareKeyId', $publicShareKeyId);
03e52840d   Kload   Init
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
  		}
  
  		if (
  			!$this->view->file_exists("/public-keys/" . $publicShareKeyId . ".public.key")
  			|| !$this->view->file_exists("/owncloud_private_key/" . $publicShareKeyId . ".private.key")
  		) {
  
  			$keypair = Crypt::createKeypair();
  
  			// Disable encryption proxy to prevent recursive calls
  			$proxyStatus = \OC_FileProxy::$enabled;
  			\OC_FileProxy::$enabled = false;
  
  			// Save public key
  
  			if (!$view->is_dir('/public-keys')) {
  				$view->mkdir('/public-keys');
  			}
  
  			$this->view->file_put_contents('/public-keys/' . $publicShareKeyId . '.public.key', $keypair['publicKey']);
  
  			// Encrypt private key empty passphrase
f7d878ff1   kload   [enh] Update to 7...
79
80
81
82
83
84
85
  			$cipher = \OCA\Encryption\Helper::getCipher();
  			$encryptedKey = \OCA\Encryption\Crypt::symmetricEncryptFileContent($keypair['privateKey'], '', $cipher);
  			if ($encryptedKey) {
  				Keymanager::setPrivateSystemKey($encryptedKey, $publicShareKeyId . '.private.key');
  			} else {
  				\OCP\Util::writeLog('files_encryption', 'Could not create public share keys', \OCP\Util::ERROR);
  			}
03e52840d   Kload   Init
86
87
88
89
90
91
92
93
94
95
96
97
  
  			\OC_FileProxy::$enabled = $proxyStatus;
  
  		}
  
  		if (\OCA\Encryption\Helper::isPublicAccess()) {
  			// Disable encryption proxy to prevent recursive calls
  			$proxyStatus = \OC_FileProxy::$enabled;
  			\OC_FileProxy::$enabled = false;
  
  			$encryptedKey = $this->view->file_get_contents(
  				'/owncloud_private_key/' . $publicShareKeyId . '.private.key');
03e52840d   Kload   Init
98
  			$privateKey = Crypt::decryptPrivateKey($encryptedKey, '');
03e52840d   Kload   Init
99
  			$this->setPublicSharePrivateKey($privateKey);
6d9380f96   Cédric Dupont   Update sources OC...
100
  			$this->setInitialized(\OCA\Encryption\Session::INIT_SUCCESSFUL);
03e52840d   Kload   Init
101
102
103
104
105
  			\OC_FileProxy::$enabled = $proxyStatus;
  		}
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
106
  	 * Sets user private key to session
03e52840d   Kload   Init
107
108
109
110
111
112
  	 * @param string $privateKey
  	 * @return bool
  	 *
  	 * @note this should only be set on login
  	 */
  	public function setPrivateKey($privateKey) {
31b7f2792   Kload   Upgrade to ownclo...
113
  		\OC::$session->set('privateKey', $privateKey);
03e52840d   Kload   Init
114
115
116
117
118
119
  
  		return true;
  
  	}
  
  	/**
f7d878ff1   kload   [enh] Update to 7...
120
121
122
123
124
125
126
127
  	 * remove keys from session
  	 */
  	public function removeKeys() {
  		\OC::$session->remove('publicSharePrivateKey');
  		\OC::$session->remove('privateKey');
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
128
129
  	 * Sets status of encryption app
  	 * @param string $init INIT_SUCCESSFUL, INIT_EXECUTED, NOT_INITIALIZED
31b7f2792   Kload   Upgrade to ownclo...
130
131
132
133
134
135
136
137
138
139
140
  	 * @return bool
  	 *
  	 * @note this doesn not indicate of the init was successful, we just remeber the try!
  	 */
  	public function setInitialized($init) {
  
  		\OC::$session->set('encryptionInitialized', $init);
  
  		return true;
  
  	}
a293d369c   Kload   Update sources to...
141
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
142
  	 * remove encryption keys and init status from session
a293d369c   Kload   Update sources to...
143
144
145
146
147
  	 */
  	public function closeSession() {
  		\OC::$session->remove('encryptionInitialized');
  		\OC::$session->remove('privateKey');
  	}
31b7f2792   Kload   Upgrade to ownclo...
148
149
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
150
151
  	 * Gets status if we already tried to initialize the encryption app
  	 * @return string init status INIT_SUCCESSFUL, INIT_EXECUTED, NOT_INITIALIZED
31b7f2792   Kload   Upgrade to ownclo...
152
153
154
155
156
157
158
159
160
161
162
163
  	 *
  	 * @note this doesn not indicate of the init was successful, we just remeber the try!
  	 */
  	public function getInitialized() {
  		if (!is_null(\OC::$session->get('encryptionInitialized'))) {
  			return \OC::$session->get('encryptionInitialized');
  		} else {
  			return self::NOT_INITIALIZED;
  		}
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
164
165
  	 * Gets user or public share private key from session
  	 * @return string $privateKey The user's plaintext private key
03e52840d   Kload   Init
166
167
168
  	 *
  	 */
  	public function getPrivateKey() {
03e52840d   Kload   Init
169
170
171
172
  		// return the public share private key if this is a public access
  		if (\OCA\Encryption\Helper::isPublicAccess()) {
  			return $this->getPublicSharePrivateKey();
  		} else {
31b7f2792   Kload   Upgrade to ownclo...
173
174
  			if (!is_null(\OC::$session->get('privateKey'))) {
  				return \OC::$session->get('privateKey');
03e52840d   Kload   Init
175
176
177
178
179
180
181
  			} else {
  				return false;
  			}
  		}
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
182
  	 * Sets public user private key to session
03e52840d   Kload   Init
183
184
185
186
  	 * @param string $privateKey
  	 * @return bool
  	 */
  	public function setPublicSharePrivateKey($privateKey) {
31b7f2792   Kload   Upgrade to ownclo...
187
  		\OC::$session->set('publicSharePrivateKey', $privateKey);
03e52840d   Kload   Init
188
189
190
191
192
193
  
  		return true;
  
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
194
195
  	 * Gets public share private key from session
  	 * @return string $privateKey
03e52840d   Kload   Init
196
197
198
  	 *
  	 */
  	public function getPublicSharePrivateKey() {
31b7f2792   Kload   Upgrade to ownclo...
199
200
  		if (!is_null(\OC::$session->get('publicSharePrivateKey'))) {
  			return \OC::$session->get('publicSharePrivateKey');
03e52840d   Kload   Init
201
202
203
  		} else {
  			return false;
  		}
03e52840d   Kload   Init
204
205
206
207
  	}
  
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
208
209
  	 * Sets user legacy key to session
  	 * @param string $legacyKey
03e52840d   Kload   Init
210
211
212
  	 * @return bool
  	 */
  	public function setLegacyKey($legacyKey) {
31b7f2792   Kload   Upgrade to ownclo...
213
  		\OC::$session->set('legacyKey', $legacyKey);
03e52840d   Kload   Init
214
215
216
217
218
  
  		return true;
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
219
220
  	 * Gets user legacy key from session
  	 * @return string $legacyKey The user's plaintext legacy key
03e52840d   Kload   Init
221
222
223
  	 *
  	 */
  	public function getLegacyKey() {
31b7f2792   Kload   Upgrade to ownclo...
224
  		if (!is_null(\OC::$session->get('legacyKey'))) {
03e52840d   Kload   Init
225

31b7f2792   Kload   Upgrade to ownclo...
226
  			return \OC::$session->get('legacyKey');
03e52840d   Kload   Init
227
228
229
230
231
232
233
234
235
236
  
  		} else {
  
  			return false;
  
  		}
  
  	}
  
  }