GreetingItem beachtet nun Berechtigungen für das IndexItem
git-svn-id: https://svn.libreccm.org/ccm/trunk@1129 8810af33-2d31-482b-a856-94f89814c4dfmaster
parent
596707a5e5
commit
8a437f3a3e
|
|
@ -39,6 +39,7 @@ import com.arsdigita.kernel.permissions.PermissionDescriptor;
|
|||
import com.arsdigita.kernel.permissions.PermissionService;
|
||||
import com.arsdigita.kernel.permissions.PrivilegeDescriptor;
|
||||
import com.arsdigita.london.navigation.Navigation;
|
||||
import com.arsdigita.web.LoginSignal;
|
||||
import com.arsdigita.xml.Element;
|
||||
|
||||
/**
|
||||
|
|
@ -51,6 +52,7 @@ import com.arsdigita.xml.Element;
|
|||
* ContentPage or extend the ContentPage.
|
||||
*
|
||||
* @author <a href="mailto:dominik@redhat.com">Dominik Kacprzak</a>
|
||||
* @author Jens Pelzetter (jensp)
|
||||
* @version $Id: GreetingItem.java 1473 2007-03-12 15:16:39Z chrisgilbert23 $
|
||||
*/
|
||||
public class GreetingItem extends AbstractComponent {
|
||||
|
|
@ -63,7 +65,7 @@ public class GreetingItem extends AbstractComponent {
|
|||
ContentItem item = (ContentItem) getObject();
|
||||
if (null == item || !item.isLive()) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
if (!ContentItem.VERSION.equals(item.getVersion())) {
|
||||
item = item.getLiveVersion();
|
||||
|
|
@ -81,19 +83,35 @@ public class GreetingItem extends AbstractComponent {
|
|||
// Note that the xml that is generated is only of use if you DO NOT CACHE index pages.
|
||||
// cg.
|
||||
|
||||
PermissionDescriptor edit = new PermissionDescriptor(PrivilegeDescriptor.
|
||||
get(SecurityManager.CMS_EDIT_ITEM), item, currentParty);
|
||||
PermissionDescriptor edit = new PermissionDescriptor(
|
||||
PrivilegeDescriptor.get(SecurityManager.CMS_EDIT_ITEM),
|
||||
item,
|
||||
currentParty);
|
||||
if (PermissionService.checkPermission(edit)) {
|
||||
content.addAttribute("canEdit", "true");
|
||||
}
|
||||
PermissionDescriptor publish = new PermissionDescriptor(PrivilegeDescriptor.
|
||||
get(SecurityManager.CMS_PUBLISH), item, currentParty);
|
||||
PermissionDescriptor publish = new PermissionDescriptor(
|
||||
PrivilegeDescriptor.get(SecurityManager.CMS_PUBLISH),
|
||||
item,
|
||||
currentParty);
|
||||
if (PermissionService.checkPermission(publish)) {
|
||||
content.addAttribute("canPublish", "true");
|
||||
}
|
||||
|
||||
ContentBundle bundle = (ContentBundle) item;
|
||||
/**
|
||||
* jensp 2011-10-02: GreetingItem/IndexItem was displayed even if the
|
||||
* current party has no access to the item.
|
||||
*/
|
||||
PermissionDescriptor read = new PermissionDescriptor(
|
||||
PrivilegeDescriptor.get(SecurityManager.CMS_READ_ITEM),
|
||||
item,
|
||||
currentParty);
|
||||
if (!PermissionService.checkPermission(read)) {
|
||||
throw new LoginSignal(request);
|
||||
}
|
||||
|
||||
ContentBundle bundle = (ContentBundle) item;
|
||||
|
||||
/* Fix by Jens Pelzetter, 2009-08-28
|
||||
* bundle.getPrimaryInstance() does not care about the preferred
|
||||
* languages
|
||||
|
|
@ -103,15 +121,14 @@ public class GreetingItem extends AbstractComponent {
|
|||
* Fixed by using negotiate() instead, which takes the locale
|
||||
* send by the User Client in account and tries to find a suitable
|
||||
* language version.
|
||||
*/
|
||||
//ContentItem baseItem = bundle.getPrimaryInstance();
|
||||
*/ //ContentItem baseItem = bundle.getPrimaryInstance();
|
||||
ContentItem baseItem = bundle.getInstance(GlobalizationHelper.
|
||||
getNegotiatedLocale().getLanguage());
|
||||
// If there is no matching language version for this content item
|
||||
if (baseItem == null) {
|
||||
// get the primary instance instead (fallback)
|
||||
baseItem = bundle.getPrimaryInstance();
|
||||
}
|
||||
}
|
||||
Element itemEl = content.newChildElement("cms:item",
|
||||
CMS.CMS_XML_NS);
|
||||
|
||||
|
|
@ -119,25 +136,26 @@ public class GreetingItem extends AbstractComponent {
|
|||
//XML generation extendable (use another renderer etc.)
|
||||
/*ContentItemXMLRenderer renderer =
|
||||
new ContentItemXMLRenderer(itemEl);
|
||||
|
||||
|
||||
renderer.setWrapAttributes(true);
|
||||
renderer.setWrapRoot(false);
|
||||
renderer.setWrapObjects(false);
|
||||
|
||||
|
||||
renderer.walk(baseItem, SimpleXMLGenerator.ADAPTER_CONTEXT);*/
|
||||
|
||||
generateGreetingItemXml(itemEl, baseItem);
|
||||
|
||||
for(ExtraXMLGenerator generator : baseItem.getExtraXMLGenerators()) {
|
||||
|
||||
for (ExtraXMLGenerator generator : baseItem.getExtraXMLGenerators()) {
|
||||
try {
|
||||
generator.generateXML(baseItem, content, new PageState(null, request,
|
||||
response));
|
||||
generator.generateXML(baseItem, content, new PageState(null,
|
||||
request,
|
||||
response));
|
||||
} catch (ServletException ex) {
|
||||
s_log.error(ex);
|
||||
}
|
||||
}
|
||||
|
||||
return content;
|
||||
|
||||
return content;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
|||
Loading…
Reference in New Issue