mirror of
https://github.com/Combodo/iTop.git
synced 2026-04-22 10:08:45 +02:00
N°1576 Portal: Security hardening.
SVN:trunk[5983]
This commit is contained in:
@@ -659,8 +659,9 @@ class BrowseBrickController extends BrickController
|
|||||||
if ($aLevelsProperties[$key][$sOptionalAttribute] !== null)
|
if ($aLevelsProperties[$key][$sOptionalAttribute] !== null)
|
||||||
{
|
{
|
||||||
$sPropertyName = substr($sOptionalAttribute, 0, -4);
|
$sPropertyName = substr($sOptionalAttribute, 0, -4);
|
||||||
|
$oAttDef = MetaModel::GetAttributeDef(get_class($value), $aLevelsProperties[$key][$sOptionalAttribute]);
|
||||||
|
|
||||||
$tmpAttValue = $value->Get($aLevelsProperties[$key][$sOptionalAttribute]);
|
$tmpAttValue = $value->GetAsHTML($aLevelsProperties[$key][$sOptionalAttribute]);
|
||||||
if($sOptionalAttribute === 'image_att')
|
if($sOptionalAttribute === 'image_att')
|
||||||
{
|
{
|
||||||
if (is_object($tmpAttValue) && !$tmpAttValue->IsEmpty())
|
if (is_object($tmpAttValue) && !$tmpAttValue->IsEmpty())
|
||||||
@@ -669,7 +670,7 @@ class BrowseBrickController extends BrickController
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$tmpAttValue = MetaModel::GetAttributeDef(get_class($value), $aLevelsProperties[$key][$sOptionalAttribute])->Get('default_image');
|
$tmpAttValue = $oAttDef->Get('default_image');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -683,7 +684,7 @@ class BrowseBrickController extends BrickController
|
|||||||
foreach ($aLevelsProperties[$key]['fields'] as $aField)
|
foreach ($aLevelsProperties[$key]['fields'] as $aField)
|
||||||
{
|
{
|
||||||
$oAttDef = MetaModel::GetAttributeDef(get_class($value), $aField['code']);
|
$oAttDef = MetaModel::GetAttributeDef(get_class($value), $aField['code']);
|
||||||
$aRow[$key]['fields'][$aField['code']] = $oAttDef->GetValueLabel($value->Get($aField['code']));
|
$aRow[$key]['fields'][$aField['code']] = $oAttDef->GetAsHTML($value->Get($aField['code']));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -755,8 +756,9 @@ class BrowseBrickController extends BrickController
|
|||||||
if ($aLevelsProperties[$aCurrentRowKeys[0]][$sOptionalAttribute] !== null)
|
if ($aLevelsProperties[$aCurrentRowKeys[0]][$sOptionalAttribute] !== null)
|
||||||
{
|
{
|
||||||
$sPropertyName = substr($sOptionalAttribute, 0, -4);
|
$sPropertyName = substr($sOptionalAttribute, 0, -4);
|
||||||
|
$oAttDef = MetaModel::GetAttributeDef(get_class($aCurrentRowValues[0]), $aLevelsProperties[$aCurrentRowKeys[0]][$sOptionalAttribute]);
|
||||||
|
|
||||||
$tmpAttValue = $aCurrentRowValues[0]->Get($aLevelsProperties[$aCurrentRowKeys[0]][$sOptionalAttribute]);
|
$tmpAttValue = $aCurrentRowValues[0]->GetAsHTML($aLevelsProperties[$aCurrentRowKeys[0]][$sOptionalAttribute]);
|
||||||
if($sOptionalAttribute === 'image_att')
|
if($sOptionalAttribute === 'image_att')
|
||||||
{
|
{
|
||||||
if (is_object($tmpAttValue) && !$tmpAttValue->IsEmpty())
|
if (is_object($tmpAttValue) && !$tmpAttValue->IsEmpty())
|
||||||
@@ -765,7 +767,7 @@ class BrowseBrickController extends BrickController
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$tmpAttValue = MetaModel::GetAttributeDef(get_class($aCurrentRowValues[0]), $aLevelsProperties[$aCurrentRowKeys[0]][$sOptionalAttribute])->Get('default_image');
|
$tmpAttValue = $oAttDef->Get('default_image');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -23,8 +23,7 @@ use Exception;
|
|||||||
use AttributeDate;
|
use AttributeDate;
|
||||||
use AttributeDateTime;
|
use AttributeDateTime;
|
||||||
use AttributeDefinition;
|
use AttributeDefinition;
|
||||||
use AttributeDuration;
|
use AttributeImage;
|
||||||
use AttributeSubItem;
|
|
||||||
use BinaryExpression;
|
use BinaryExpression;
|
||||||
use CMDBSource;
|
use CMDBSource;
|
||||||
use Combodo\iTop\Portal\Brick\AbstractBrick;
|
use Combodo\iTop\Portal\Brick\AbstractBrick;
|
||||||
@@ -237,7 +236,6 @@ class ManageBrickController extends BrickController
|
|||||||
return $oApp['twig']->render(static::EXCEL_EXPORT_TEMPLATE_PATH, $aData);
|
return $oApp['twig']->render(static::EXCEL_EXPORT_TEMPLATE_PATH, $aData);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param \Symfony\Component\HttpFoundation\Request $oRequest
|
* @param \Symfony\Component\HttpFoundation\Request $oRequest
|
||||||
* @param \Silex\Application $oApp
|
* @param \Silex\Application $oApp
|
||||||
@@ -586,7 +584,7 @@ class ManageBrickController extends BrickController
|
|||||||
$oAttDef = MetaModel::GetAttributeDef($sCurrentClass, $sItemAttr);
|
$oAttDef = MetaModel::GetAttributeDef($sCurrentClass, $sItemAttr);
|
||||||
if ($oAttDef->IsExternalKey())
|
if ($oAttDef->IsExternalKey())
|
||||||
{
|
{
|
||||||
$sValue = $oCurrentRow->Get($sItemAttr.'_friendlyname');
|
$sValue = $oCurrentRow->GetAsHTML($sItemAttr.'_friendlyname');
|
||||||
|
|
||||||
// Adding a view action on the external keys
|
// Adding a view action on the external keys
|
||||||
if ($oCurrentRow->Get($sItemAttr) !== $oAttDef->GetNullValue())
|
if ($oCurrentRow->Get($sItemAttr) !== $oAttDef->GetNullValue())
|
||||||
@@ -604,13 +602,22 @@ class ManageBrickController extends BrickController
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif ($oAttDef instanceof AttributeSubItem || $oAttDef instanceof AttributeDuration)
|
elseif ($oAttDef instanceof AttributeImage)
|
||||||
{
|
{
|
||||||
$sValue = $oAttDef->GetAsHTML($oCurrentRow->Get($sItemAttr));
|
$oOrmDoc = $oCurrentRow->Get($sItemAttr);
|
||||||
}
|
if (is_object($oOrmDoc) && !$oOrmDoc->IsEmpty())
|
||||||
|
{
|
||||||
|
$sUrl = $oApp['url_generator']->generate('p_object_document_display', array('sObjectClass' => get_class($oCurrentRow), 'sObjectId' => $oCurrentRow->GetKey(), 'sObjectField' => $sItemAttr, 'cache' => 86400));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$sUrl = $oAttDef->Get('default_image');
|
||||||
|
}
|
||||||
|
$sValue = '<img src="' . $sUrl . '" />';
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$sValue = $oAttDef->GetValueLabel($oCurrentRow->Get($sItemAttr));
|
$sValue = $oAttDef->GetAsHTML($oCurrentRow->Get($sItemAttr));
|
||||||
}
|
}
|
||||||
unset($oAttDef);
|
unset($oAttDef);
|
||||||
|
|
||||||
|
|||||||
@@ -40,6 +40,7 @@ use ListExpression;
|
|||||||
use ScalarExpression;
|
use ScalarExpression;
|
||||||
use DBObjectSet;
|
use DBObjectSet;
|
||||||
use AttributeEnum;
|
use AttributeEnum;
|
||||||
|
use AttributeImage;
|
||||||
use AttributeFinalClass;
|
use AttributeFinalClass;
|
||||||
use AttributeFriendlyName;
|
use AttributeFriendlyName;
|
||||||
use UserRights;
|
use UserRights;
|
||||||
@@ -1481,7 +1482,7 @@ class ObjectController extends AbstractController
|
|||||||
|
|
||||||
if ($oAttDef->IsExternalKey())
|
if ($oAttDef->IsExternalKey())
|
||||||
{
|
{
|
||||||
$aAttData['value'] = $oObject->Get($oAttDef->GetCode() . '_friendlyname');
|
$aAttData['value'] = $oObject->GetAsHTML($oAttDef->GetCode() . '_friendlyname');
|
||||||
|
|
||||||
// Checking if user can access object's external key
|
// Checking if user can access object's external key
|
||||||
if (SecurityHelper::IsActionAllowed($oApp, UR_ACTION_READ, $oAttDef->GetTargetClass()))
|
if (SecurityHelper::IsActionAllowed($oApp, UR_ACTION_READ, $oAttDef->GetTargetClass()))
|
||||||
@@ -1494,9 +1495,22 @@ class ObjectController extends AbstractController
|
|||||||
// We skip it
|
// We skip it
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
elseif ($oAttDef instanceof AttributeImage)
|
||||||
|
{
|
||||||
|
$oOrmDoc = $oObject->Get($oAttDef->GetCode());
|
||||||
|
if (is_object($oOrmDoc) && !$oOrmDoc->IsEmpty())
|
||||||
|
{
|
||||||
|
$sUrl = $oApp['url_generator']->generate('p_object_document_display', array('sObjectClass' => get_class($oObject), 'sObjectId' => $oObject->GetKey(), 'sObjectField' => $oAttDef->GetCode(), 'cache' => 86400));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$sUrl = $oAttDef->Get('default_image');
|
||||||
|
}
|
||||||
|
$aAttData['value'] = '<img src="' . $sUrl . '" />';
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$aAttData['value'] = $oAttDef->GetValueLabel($oObject->Get($oAttDef->GetCode()));
|
$aAttData['value'] = $oAttDef->GetAsHTML($oObject->Get($oAttDef->GetCode()));
|
||||||
|
|
||||||
if ($oAttDef instanceof AttributeFriendlyName)
|
if ($oAttDef instanceof AttributeFriendlyName)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -28,6 +28,8 @@ use AttributeText;
|
|||||||
* Description of TextAreaField
|
* Description of TextAreaField
|
||||||
*
|
*
|
||||||
* @author Guillaume Lajarige <guillaume.lajarige@combodo.com>
|
* @author Guillaume Lajarige <guillaume.lajarige@combodo.com>
|
||||||
|
* @package \Combodo\iTop\Form\Field
|
||||||
|
* @since 2.3.0
|
||||||
*/
|
*/
|
||||||
class TextAreaField extends TextField
|
class TextAreaField extends TextField
|
||||||
{
|
{
|
||||||
@@ -112,7 +114,7 @@ class TextAreaField extends TextField
|
|||||||
{
|
{
|
||||||
if ($this->GetFormat() == TextAreaField::ENUM_FORMAT_TEXT)
|
if ($this->GetFormat() == TextAreaField::ENUM_FORMAT_TEXT)
|
||||||
{
|
{
|
||||||
$sValue = $this->GetCurrentValue();
|
$sValue = \Str::pure2html($this->GetCurrentValue());
|
||||||
$sValue = AttributeText::RenderWikiHtml($sValue);
|
$sValue = AttributeText::RenderWikiHtml($sValue);
|
||||||
return "<div>".str_replace("\n", "<br>\n", $sValue).'</div>';
|
return "<div>".str_replace("\n", "<br>\n", $sValue).'</div>';
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -585,6 +585,7 @@ EOF
|
|||||||
);
|
);
|
||||||
|
|
||||||
// Target object others attributes
|
// Target object others attributes
|
||||||
|
// TODO: Support for AttriubteImage, AttributeBlob
|
||||||
foreach ($this->oField->GetAttributesToDisplay(true) as $sAttCode)
|
foreach ($this->oField->GetAttributesToDisplay(true) as $sAttCode)
|
||||||
{
|
{
|
||||||
if ($sAttCode !== 'id')
|
if ($sAttCode !== 'id')
|
||||||
@@ -607,7 +608,7 @@ EOF
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$aAttProperties['value'] = $oAttDef->GetValueLabel($oRemoteItem->Get($sAttCode));
|
$aAttProperties['value'] = $oAttDef->GetAsHTML($oRemoteItem->Get($sAttCode));
|
||||||
|
|
||||||
if ($oAttDef instanceof AttributeFriendlyName)
|
if ($oAttDef instanceof AttributeFriendlyName)
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user