2012-07-04 15:16:02 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
OCP\JSON::checkAppEnabled('files_external');
|
2013-02-12 10:35:16 +00:00
|
|
|
OCP\JSON::callCheck();
|
2012-07-04 15:16:02 +00:00
|
|
|
|
2012-11-30 15:27:11 +00:00
|
|
|
if ( ! ($filename = $_FILES['rootcert_import']['name']) ) {
|
2014-02-19 16:07:29 +00:00
|
|
|
header('Location:' . OCP\Util::linkToRoute( "settings_personal" ));
|
2012-09-27 10:37:23 +00:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2012-10-10 11:18:36 +00:00
|
|
|
$fh = fopen($_FILES['rootcert_import']['tmp_name'], 'r');
|
|
|
|
$data = fread($fh, filesize($_FILES['rootcert_import']['tmp_name']));
|
2012-09-18 15:04:22 +00:00
|
|
|
fclose($fh);
|
2012-09-27 09:20:37 +00:00
|
|
|
$filename = $_FILES['rootcert_import']['name'];
|
2012-10-10 11:18:36 +00:00
|
|
|
|
|
|
|
$view = new \OC\Files\View('/'.\OCP\User::getUser().'/files_external/uploads');
|
2013-02-09 15:46:55 +00:00
|
|
|
if (!$view->file_exists('')) {
|
2012-12-03 17:02:22 +00:00
|
|
|
$view->mkdir('');
|
|
|
|
}
|
2012-07-04 15:16:02 +00:00
|
|
|
|
2012-09-27 09:20:37 +00:00
|
|
|
$isValid = openssl_pkey_get_public($data);
|
|
|
|
|
|
|
|
//maybe it was just the wrong file format, try to convert it...
|
|
|
|
if ($isValid == false) {
|
2012-10-10 11:18:36 +00:00
|
|
|
$data = chunk_split(base64_encode($data), 64, "\n");
|
2012-09-27 09:20:37 +00:00
|
|
|
$data = "-----BEGIN CERTIFICATE-----\n".$data."-----END CERTIFICATE-----\n";
|
|
|
|
$isValid = openssl_pkey_get_public($data);
|
2012-07-06 13:58:38 +00:00
|
|
|
}
|
|
|
|
|
2012-09-27 09:20:37 +00:00
|
|
|
// add the certificate if it could be verified
|
|
|
|
if ( $isValid ) {
|
2013-06-12 08:37:09 +00:00
|
|
|
// disable proxy to prevent multiple fopen calls
|
|
|
|
$proxyStatus = \OC_FileProxy::$enabled;
|
|
|
|
\OC_FileProxy::$enabled = false;
|
2012-09-27 09:20:37 +00:00
|
|
|
$view->file_put_contents($filename, $data);
|
|
|
|
OC_Mount_Config::createCertificateBundle();
|
2013-06-12 08:37:09 +00:00
|
|
|
\OC_FileProxy::$enabled = $proxyStatus;
|
2012-09-27 09:20:37 +00:00
|
|
|
} else {
|
2012-11-30 15:27:11 +00:00
|
|
|
OCP\Util::writeLog('files_external',
|
|
|
|
'Couldn\'t import SSL root certificate ('.$filename.'), allowed formats: PEM and DER',
|
|
|
|
OCP\Util::WARN);
|
2012-09-27 09:20:37 +00:00
|
|
|
}
|
2012-07-06 13:58:38 +00:00
|
|
|
|
2013-02-18 13:38:29 +00:00
|
|
|
header('Location:' . OCP\Util::linkToRoute( "settings_personal" ));
|
2012-07-04 15:16:02 +00:00
|
|
|
exit;
|