Commit a3e678cc authored by Ad Schellevis's avatar Ad Schellevis Committed by Franco Fichtner

(mvc) add AuthenticationServerField type to model, to select authentication...

(mvc) add AuthenticationServerField type to model, to select authentication servers (which only exists in the legacy data)

(cherry picked from commit 4b5245be)
parent a96cbb5e
<?php
/**
* Copyright (C) 2015 Deciso B.V.
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
* OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
*/
namespace OPNsense\Base\FieldTypes;
use Phalcon\Validation\Validator\InclusionIn;
use OPNsense\Core\Config;
use OPNsense\Auth;
use OPNsense\Base\Validators\CsvListValidator;
/**
* Class AuthenticationServerField field type to select usable authentication servers,
* currently this is kind of a backward compatibility package to glue legacy authentication servers into the model.
* The concept of authentication servers is not likely to change in the near future.
* @package OPNsense\Base\FieldTypes
*/
class AuthenticationServerField extends BaseField
{
/**
* @var bool marks if this is a data node or a container
*/
protected $internalIsContainer = false;
/**
* @var array collected options
*/
private static $internalOptionList = array();
/**
* @var array filters to use on the authservers list
*/
private $internalFilters = array();
/**
* @var string key to use for option selections, to prevent excessive reloading
*/
private $internalCacheKey = '*';
/**
* @var bool field may contain multiple servers at once
*/
private $internalMultiSelect = false;
/**
* generate validation data (list of AuthServers)
*/
public function eventPostLoading()
{
if (!array_key_exists($this->internalCacheKey, self::$internalOptionList)) {
self::$internalOptionList[$this->internalCacheKey] = array();
$authFactory = new \OPNsense\Auth\AuthenticationFactory;
$allAuthServers = $authFactory->listServers();
foreach ($allAuthServers as $key => $value) {
// use filters to determine relevance
$isMatched = true;
foreach ($this->internalFilters as $filterKey => $filterData) {
if (isset($value[$filterKey])) {
$fieldData = $value[$filterKey];
} else {
// not found, might be a boolean.
$fieldData = "0";
}
if (!preg_match($filterData, $fieldData)) {
$isMatched = false;
}
}
if ($isMatched) {
self::$internalOptionList[$this->internalCacheKey][$key] = $key;
}
}
}
}
/**
* set filters to use (in regex) per field, all tags are combined
* and cached for the next object using the same filters
* @param $filters filters to use
*/
public function setFilters($filters)
{
if (is_array($filters)) {
$this->internalFilters = $filters;
$this->internalCacheKey = md5(serialize($this->internalFilters));
}
}
/**
* select if multiple authentication servers may be selected at once
* @param $value boolean value Y/N
*/
public function setmultiple($value)
{
if (trim(strtoupper($value)) == "Y") {
$this->internalMultiSelect = true;
} else {
$this->internalMultiSelect = false;
}
}
/**
* get valid options, descriptions and selected value
* @return array
*/
public function getNodeData()
{
$result = array();
// if authentication server is not required and single, add empty option
if (!$this->internalIsRequired && !$this->internalMultiSelect) {
$result[""] = array("value"=>"none", "selected" => 0);
}
// explode authentication servers
$authservers = explode(',', $this->internalValue);
foreach (self::$internalOptionList[$this->internalCacheKey] as $optKey => $optValue) {
if (in_array($optKey, $authservers)) {
$selected = 1;
} else {
$selected = 0;
}
$result[$optKey] = array("value"=>$optValue, "selected" => $selected);
}
return $result;
}
/**
* retrieve field validators for this field type
* @return array returns Text/regex validator
*/
public function getValidators()
{
if ($this->internalValidationMessage == null) {
$msg = "please specify a valid authentication server";
} else {
$msg = $this->internalValidationMessage;
}
if (($this->internalIsRequired == true || $this->internalValue != null)) {
if ($this->internalMultiSelect) {
// field may contain more than one authentication server
return array(new CsvListValidator(array('message' => $msg,
'domain'=>array_keys(self::$internalOptionList[$this->internalCacheKey]))));
} else {
// single authentication server selection
return array(new InclusionIn(array('message' => $msg,
'domain'=>array_keys(self::$internalOptionList[$this->internalCacheKey]))));
}
} else {
// empty field and not required, skip this validation.
return array();
}
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment