mirror of
https://github.com/netzbegruenung/user_saml.git
synced 2024-05-11 05:06:06 +02:00
be6a8e97fe
- adds user_saml_configurations table and migrates existing configuration - Controller methods are added since appconfig endpoints cannot be used anymore. THIS IS A BREAKING CHANGE. - Frontend code is adjusted to use new endpoints. - security-sloWebServerDecode was changed from global to provider specific setting. It being global seemed to be unintended. A migration path is yet missing. Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
67 lines
2 KiB
PHP
67 lines
2 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (c) 2018 Robin Appelman <robin@icewind.nl>
|
|
*
|
|
* @license GNU AGPL version 3 or any later version
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program 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 program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
namespace OCA\User_SAML;
|
|
|
|
use OCA\DAV\Connector\Sabre\Auth;
|
|
use OCP\IConfig;
|
|
use OCP\ISession;
|
|
use Sabre\DAV\Server;
|
|
use Sabre\DAV\ServerPlugin;
|
|
use Sabre\HTTP\RequestInterface;
|
|
use Sabre\HTTP\ResponseInterface;
|
|
|
|
class DavPlugin extends ServerPlugin {
|
|
private $session;
|
|
private $config;
|
|
private $auth;
|
|
/** @var Server */
|
|
private $server;
|
|
private SAMLSettings $samlSettings;
|
|
|
|
public function __construct(ISession $session, IConfig $config, array $auth, SAMLSettings $samlSettings) {
|
|
$this->session = $session;
|
|
$this->config = $config;
|
|
$this->auth = $auth;
|
|
$this->samlSettings = $samlSettings;
|
|
}
|
|
|
|
|
|
public function initialize(Server $server) {
|
|
// before auth
|
|
$server->on('beforeMethod:*', [$this, 'beforeMethod'], 9);
|
|
$this->server = $server;
|
|
}
|
|
|
|
public function beforeMethod(RequestInterface $request, ResponseInterface $response) {
|
|
if (
|
|
$this->config->getAppValue('user_saml', 'type') === 'environment-variable' &&
|
|
!$this->session->exists('user_saml.samlUserData')
|
|
) {
|
|
$uidMapping = $this->samlSettings->get(1)['general-uid_mapping'];
|
|
if (isset($this->auth[$uidMapping])) {
|
|
$this->session->set(Auth::DAV_AUTHENTICATED, $this->auth[$uidMapping]);
|
|
$this->session->set('user_saml.samlUserData', $this->auth);
|
|
}
|
|
}
|
|
}
|
|
}
|