NavigationConfigForm: Require argument $type in method getShareConfig()
refs #10246
This commit is contained in:
parent
f60a8ef60d
commit
6fdfef4f4a
|
@ -157,10 +157,20 @@ class NavigationConfigForm extends ConfigForm
|
||||||
/**
|
/**
|
||||||
* Return the shared navigation configuration
|
* Return the shared navigation configuration
|
||||||
*
|
*
|
||||||
|
* @param string $type
|
||||||
|
*
|
||||||
* @return Config
|
* @return Config
|
||||||
*/
|
*/
|
||||||
public function getShareConfig()
|
public function getShareConfig($type = null)
|
||||||
{
|
{
|
||||||
|
if ($this->shareConfig === null) {
|
||||||
|
if ($type === null) {
|
||||||
|
throw new ProgrammingError('You need to pass a type if no share configuration is set');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->setShareConfig($this->getItemConfig($type));
|
||||||
|
}
|
||||||
|
|
||||||
return $this->shareConfig;
|
return $this->shareConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,10 +210,9 @@ class NavigationConfigForm extends ConfigForm
|
||||||
$children = $this->itemToLoad ? $this->getFlattenedChildren($this->itemToLoad) : array();
|
$children = $this->itemToLoad ? $this->getFlattenedChildren($this->itemToLoad) : array();
|
||||||
|
|
||||||
$names = array();
|
$names = array();
|
||||||
foreach ($this->getShareConfig() as $sectionName => $sectionConfig) {
|
foreach ($this->getShareConfig($type) as $sectionName => $sectionConfig) {
|
||||||
if (
|
if (
|
||||||
$sectionName !== $this->itemToLoad
|
$sectionName !== $this->itemToLoad
|
||||||
&& $sectionConfig->type === $type
|
|
||||||
&& $sectionConfig->owner === ($owner ?: $this->getUser()->getUsername())
|
&& $sectionConfig->owner === ($owner ?: $this->getUser()->getUsername())
|
||||||
&& !in_array($sectionName, $children, true)
|
&& !in_array($sectionName, $children, true)
|
||||||
) {
|
) {
|
||||||
|
@ -292,15 +301,15 @@ class NavigationConfigForm extends ConfigForm
|
||||||
if ((isset($data['users']) && $data['users']) || (isset($data['groups']) && $data['groups'])) {
|
if ((isset($data['users']) && $data['users']) || (isset($data['groups']) && $data['groups'])) {
|
||||||
if ($this->getUser()->can('application/share/navigation')) {
|
if ($this->getUser()->can('application/share/navigation')) {
|
||||||
$data['owner'] = $this->getUser()->getUsername();
|
$data['owner'] = $this->getUser()->getUsername();
|
||||||
$config = $this->getShareConfig();
|
$config = $this->getShareConfig($data['type']);
|
||||||
$shared = true;
|
$shared = true;
|
||||||
} else {
|
} else {
|
||||||
unset($data['users']);
|
unset($data['users']);
|
||||||
unset($data['groups']);
|
unset($data['groups']);
|
||||||
}
|
}
|
||||||
} elseif (isset($data['parent']) && $data['parent'] && $this->hasBeenShared($data['parent'])) {
|
} elseif (isset($data['parent']) && $data['parent'] && $this->hasBeenShared($data['parent'], $data['type'])) {
|
||||||
$data['owner'] = $this->getUser()->getUsername();
|
$data['owner'] = $this->getUser()->getUsername();
|
||||||
$config = $this->getShareConfig();
|
$config = $this->getShareConfig($data['type']);
|
||||||
$shared = true;
|
$shared = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -310,7 +319,7 @@ class NavigationConfigForm extends ConfigForm
|
||||||
if ($shared) {
|
if ($shared) {
|
||||||
$exists = $this->getUserConfig($data['type'])->hasSection($itemName);
|
$exists = $this->getUserConfig($data['type'])->hasSection($itemName);
|
||||||
} else {
|
} else {
|
||||||
$exists = (bool) $this->getShareConfig()
|
$exists = (bool) $this->getShareConfig($data['type'])
|
||||||
->select()
|
->select()
|
||||||
->where('name', $itemName)
|
->where('name', $itemName)
|
||||||
->where('owner', $this->getUser()->getUsername())
|
->where('owner', $this->getUser()->getUsername())
|
||||||
|
@ -774,12 +783,13 @@ class NavigationConfigForm extends ConfigForm
|
||||||
* Return whether the given navigation item has been shared
|
* Return whether the given navigation item has been shared
|
||||||
*
|
*
|
||||||
* @param string $name
|
* @param string $name
|
||||||
|
* @param string $type
|
||||||
*
|
*
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
protected function hasBeenShared($name)
|
protected function hasBeenShared($name, $type = null)
|
||||||
{
|
{
|
||||||
return $this->getConfigForItem($name) === $this->getShareConfig();
|
return $this->getShareConfig($type) === $this->getConfigForItem($name);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue