CCM NG/ccm-cms:

- Privileges from the folder are now applied to new content items 
- Privilieges from the folder are not applied to new assets
- Some improvments for the structure of the asset forms



git-svn-id: https://svn.libreccm.org/ccm/ccm_ng@4883 8810af33-2d31-482b-a856-94f89814c4df
ccm-docs
jensp 2017-07-24 15:22:10 +00:00
parent 18a361da2c
commit 1b7b03a481
31 changed files with 1822 additions and 649 deletions

View File

@ -77,6 +77,9 @@
<Logger name="org.libreccm.ui.admin.usersgroupsroles.RolesController" <Logger name="org.libreccm.ui.admin.usersgroupsroles.RolesController"
level="debug"> level="debug">
</Logger> </Logger>
<Logger name="org.librecms.contentsection.AssetRepository"
level="debug">
</Logger>
<Logger name="org.librecms.contentsection.ContentSectionSetup" <Logger name="org.librecms.contentsection.ContentSectionSetup"
level="debug"> level="debug">
</Logger> </Logger>

View File

@ -47,25 +47,29 @@ import org.librecms.contentsection.AssetRepository;
import java.util.Optional; import java.util.Optional;
import org.libreccm.categorization.CategoryManager;
import org.libreccm.core.UnexpectedErrorException; import org.libreccm.core.UnexpectedErrorException;
import org.librecms.assets.AssetL10NManager; import org.librecms.assets.AssetL10NManager;
import org.librecms.contentsection.Folder; import org.librecms.contentsection.AssetManager;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
import java.util.Objects;
import java.util.TooManyListenersException; import java.util.TooManyListenersException;
/** /**
* Basic Form for manipulating assets.
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
* @param <T> The type of the asset.
*/ */
public abstract class AssetForm extends Form implements FormInitListener, public abstract class AbstractAssetForm<T extends Asset>
FormProcessListener, extends Form implements FormInitListener,
FormSubmissionListener { FormProcessListener,
FormSubmissionListener {
private static final String ASSET_TITLE = "asset-title"; private static final String ASSET_TITLE = "asset-name";
private static final String ASSET_NAME = "asset-title";
private final AssetPane assetPane; private final AssetPane assetPane;
private final SingleSelectionModel<Long> selectionModel; private final SingleSelectionModel<Long> selectionModel;
@ -78,10 +82,11 @@ public abstract class AssetForm extends Form implements FormInitListener,
private SingleSelect addLocaleSelect; private SingleSelect addLocaleSelect;
private Submit addLocaleSubmit; private Submit addLocaleSubmit;
private TextField name;
private TextField title; private TextField title;
private SaveCancelSection saveCancelSection; private SaveCancelSection saveCancelSection;
public AssetForm(final AssetPane assetPane) { public AbstractAssetForm(final AssetPane assetPane) {
super("asset-form", new ColumnPanel(1)); super("asset-form", new ColumnPanel(1));
this.assetPane = assetPane; this.assetPane = assetPane;
@ -98,7 +103,7 @@ public abstract class AssetForm extends Form implements FormInitListener,
@Override @Override
public void prepare(final PrintEvent event) { public void prepare(final PrintEvent event) {
final PageState state = event.getPageState(); final PageState state = event.getPageState();
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<T> selectedAsset = getSelectedAsset(state);
final Label target = (Label) event.getTarget(); final Label target = (Label) event.getTarget();
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
target.setLabel(new GlobalizedMessage( target.setLabel(new GlobalizedMessage(
@ -121,8 +126,7 @@ public abstract class AssetForm extends Form implements FormInitListener,
public void prepare(final PrintEvent event) { public void prepare(final PrintEvent event) {
final PageState state = event.getPageState(); final PageState state = event.getPageState();
final Optional<Asset> selectedAsset final Optional<T> selectedAsset = getSelectedAsset(state);
= getSelectedAsset(state);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
final SingleSelect target = (SingleSelect) event final SingleSelect target = (SingleSelect) event
.getTarget(); .getTarget();
@ -196,8 +200,7 @@ public abstract class AssetForm extends Form implements FormInitListener,
public void prepare(final PrintEvent event) { public void prepare(final PrintEvent event) {
final PageState state = event.getPageState(); final PageState state = event.getPageState();
final Optional<Asset> selectedAsset final Optional<T> selectedAsset = getSelectedAsset(state);
= getSelectedAsset(state);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
final SingleSelect target = (SingleSelect) event final SingleSelect target = (SingleSelect) event
.getTarget(); .getTarget();
@ -232,6 +235,11 @@ public abstract class AssetForm extends Form implements FormInitListener,
addLocalePanel.add(addLocaleSubmit); addLocalePanel.add(addLocaleSubmit);
add(addLocalePanel); add(addLocalePanel);
add(new Label(new GlobalizedMessage("cms.ui.asset.name",
CmsConstants.CMS_BUNDLE)));
name = new TextField(ASSET_NAME);
add(name);
add(new Label(new GlobalizedMessage("cms.ui.asset.title", add(new Label(new GlobalizedMessage("cms.ui.asset.title",
CmsConstants.CMS_BUNDLE))); CmsConstants.CMS_BUNDLE)));
title = new TextField(ASSET_TITLE); title = new TextField(ASSET_TITLE);
@ -255,7 +263,8 @@ public abstract class AssetForm extends Form implements FormInitListener,
return (String) title.getValue(state); return (String) title.getValue(state);
} }
protected Optional<Asset> getSelectedAsset(final PageState state) { @SuppressWarnings("unchecked")
protected Optional<T> getSelectedAsset(final PageState state) {
if (selectionModel.getSelectedKey(state) == null) { if (selectionModel.getSelectedKey(state) == null) {
return Optional.empty(); return Optional.empty();
@ -268,7 +277,17 @@ public abstract class AssetForm extends Form implements FormInitListener,
.orElseThrow(() -> new IllegalArgumentException(String. .orElseThrow(() -> new IllegalArgumentException(String.
format("No asset with ID %d in the database.", format("No asset with ID %d in the database.",
selectionModel.getSelectedKey(state)))); selectionModel.getSelectedKey(state))));
return Optional.of(asset); if (getAssetClass().isAssignableFrom(asset.getClass())) {
return Optional.of((T) asset);
} else {
throw new UnexpectedErrorException(String
.format(
"The requested asset is not of the type expected by "
+ "this form. Expected type is \"%s\". "
+ "Type of asset: \"%s\".",
getAssetClass().getName(),
asset.getClass().getName()));
}
} }
} }
@ -277,7 +296,7 @@ public abstract class AssetForm extends Form implements FormInitListener,
final PageState state = event.getPageState(); final PageState state = event.getPageState();
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<T> selectedAsset = getSelectedAsset(state);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
@ -312,8 +331,12 @@ public abstract class AssetForm extends Form implements FormInitListener,
} }
} }
protected String getTitleValue(final PageState state) {
return (String) title.getValue(state);
}
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<T> selectedAsset) {
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
@ -336,18 +359,9 @@ public abstract class AssetForm extends Form implements FormInitListener,
if (showLocaleSubmit.isSelected(state)) { if (showLocaleSubmit.isSelected(state)) {
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<T> selectedAsset = getSelectedAsset(state);
initForm(state, selectedAsset); initForm(state, selectedAsset);
// if (selectedAsset.isPresent()) {
//
// title.setValue(state,
// selectedAsset
// .get()
// .getTitle()
// .getValue(getSelectedLocale(state)));
// showLocale(state);
// }
return; return;
} }
@ -356,52 +370,77 @@ public abstract class AssetForm extends Form implements FormInitListener,
.findBean(AssetL10NManager.class); .findBean(AssetL10NManager.class);
final Locale add = new Locale((String) addLocaleSelect final Locale add = new Locale((String) addLocaleSelect
.getValue(state)); .getValue(state));
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<T> selectedAsset = getSelectedAsset(state);
l10nManager.addLanguage(selectedAsset.get(), add); l10nManager.addLanguage(selectedAsset.get(), add);
} }
if (saveCancelSection.getSaveButton().isSelected(state)) { if (saveCancelSection.getSaveButton().isSelected(state)) {
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<T> selectedAsset = getSelectedAsset(state);
final Asset asset; final Asset asset;
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
asset = selectedAsset.get(); asset = selectedAsset.get();
updateAsset(asset, event); // updateAsset(asset, event);
asset.setDisplayName((String) name.getValue(state));
asset.getTitle().addValue(getSelectedLocale(state),
(String) title.getValue(state));
// final AssetRepository assetRepo = cdiUtil
// .findBean(AssetRepository.class);
// assetRepo.save(asset);
} else { } else {
asset = createAsset(event); asset = createAsset(event);
updateAsset(asset, event);
} }
asset.getTitle().addValue(getSelectedLocale(state), updateAsset(asset, event);
(String) title.getValue(state));
final AssetRepository assetRepo = cdiUtil final AssetRepository assetRepo = cdiUtil
.findBean(AssetRepository.class); .findBean(AssetRepository.class);
assetRepo.save(asset); assetRepo.save(asset);
if (!selectedAsset.isPresent()) { // if (!selectedAsset.isPresent()) {
//Set display name // //Set display name
asset.setDisplayName((String) title.getValue(state)); // asset.setDisplayName((String) title.getValue(state));
assetRepo.save(asset); // assetRepo.save(asset);
//
//Add new asset to currently selected folder // //Add new asset to currently selected folder
final Folder selectedFolder = assetPane // final Folder selectedFolder = assetPane
.getFolderSelectionModel() // .getFolderSelectionModel()
.getSelectedObject(state); // .getSelectedObject(state);
final CategoryManager categoryManager = cdiUtil // final CategoryManager categoryManager = cdiUtil
.findBean(CategoryManager.class); // .findBean(CategoryManager.class);
categoryManager.addObjectToCategory( // categoryManager.addObjectToCategory(
asset, // asset,
selectedFolder, // selectedFolder,
CmsConstants.CATEGORIZATION_TYPE_FOLDER); // CmsConstants.CATEGORIZATION_TYPE_FOLDER);
} // }
assetPane.browseMode(state); assetPane.browseMode(state);
} }
} }
protected abstract Class<T> getAssetClass();
protected abstract void showLocale(final PageState state); protected abstract void showLocale(final PageState state);
protected abstract Asset createAsset(final FormSectionEvent event) protected final T createAsset(final FormSectionEvent event)
throws FormProcessException; throws FormProcessException {
Objects.requireNonNull(event);
final PageState state = event.getPageState();
final CdiUtil cdiUtil = CdiUtil.createCdiUtil();
final AssetManager assetManager = cdiUtil.findBean(AssetManager.class);
return assetManager.createAsset((String) name.getValue(state),
(String) title.getValue(state),
getSelectedLocale(state),
assetPane
.getFolderSelectionModel()
.getSelectedObject(state),
getAssetClass());
}
protected abstract void updateAsset(final Asset asset, protected abstract void updateAsset(final Asset asset,
final FormSectionEvent event) final FormSectionEvent event)

View File

@ -22,10 +22,12 @@ import javax.enterprise.context.RequestScoped;
/** /**
* *
* Controller for the asset forms
*
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
@RequestScoped @RequestScoped
public class AssetFormController { class AssetFormController {

View File

@ -536,7 +536,7 @@ public class AssetPane extends LayoutPanel implements Resettable {
.findBean(AssetTypesManager.class); .findBean(AssetTypesManager.class);
final AssetTypeInfo typeInfo = typesManager final AssetTypeInfo typeInfo = typesManager
.getAssetTypeInfo(selectedAssetType); .getAssetTypeInfo(selectedAssetType);
final Class<? extends AssetForm> assetForm = typeInfo final Class<? extends AbstractAssetForm> assetForm = typeInfo
.getAssetForm(); .getAssetForm();
try { try {
return assetForm return assetForm

View File

@ -26,7 +26,7 @@ import com.arsdigita.bebop.Text;
import com.arsdigita.bebop.event.FormSectionEvent; import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.bebop.form.TextArea; import com.arsdigita.bebop.form.TextArea;
import com.arsdigita.cms.ui.FileUploadSection; import com.arsdigita.cms.ui.FileUploadSection;
import com.arsdigita.cms.ui.assets.AssetForm; import com.arsdigita.cms.ui.assets.AbstractAssetForm;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.globalization.GlobalizedMessage; import com.arsdigita.globalization.GlobalizedMessage;
@ -45,8 +45,10 @@ import org.librecms.contentsection.Asset;
* Base form for assets which extend {@link BinaryAsset}. * Base form for assets which extend {@link BinaryAsset}.
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
* @param <T> Type of binary asset
*/ */
public abstract class BinaryAssetForm extends AssetForm { public abstract class AbstractBinaryAssetForm<T extends BinaryAsset>
extends AbstractAssetForm<T> {
private TextArea description; private TextArea description;
private Text fileName; private Text fileName;
@ -54,7 +56,7 @@ public abstract class BinaryAssetForm extends AssetForm {
private Text size; private Text size;
private FileUploadSection fileUpload; private FileUploadSection fileUpload;
public BinaryAssetForm(final AssetPane assetPane) { public AbstractBinaryAssetForm(final AssetPane assetPane) {
super(assetPane); super(assetPane);
} }
@ -101,7 +103,7 @@ public abstract class BinaryAssetForm extends AssetForm {
@Override @Override
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<T> selectedAsset) {
super.initForm(state, selectedAsset); super.initForm(state, selectedAsset);
@ -140,7 +142,7 @@ public abstract class BinaryAssetForm extends AssetForm {
@Override @Override
protected void showLocale(final PageState state) { protected void showLocale(final PageState state) {
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<T> selectedAsset = getSelectedAsset(state);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
if (!(getSelectedAsset(state).get() instanceof BinaryAsset)) { if (!(getSelectedAsset(state).get() instanceof BinaryAsset)) {
@ -158,27 +160,27 @@ public abstract class BinaryAssetForm extends AssetForm {
} }
@Override // @Override
protected Asset createAsset(final FormSectionEvent event) // protected Asset createAsset(final FormSectionEvent event)
throws FormProcessException { // throws FormProcessException {
//
// Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// final BinaryAsset binaryAsset = createBinaryAsset(state);
//
// binaryAsset
// .getDescription()
// .addValue(getSelectedLocale(state),
// (String) description.getValue(state));
//
// setFileData(event, binaryAsset);
//
// return binaryAsset;
// }
Objects.requireNonNull(event); // protected abstract BinaryAsset createBinaryAsset(final PageState state);
final PageState state = event.getPageState();
final BinaryAsset binaryAsset = createBinaryAsset(state);
binaryAsset
.getDescription()
.addValue(getSelectedLocale(state),
(String) description.getValue(state));
setFileData(event, binaryAsset);
return binaryAsset;
}
protected abstract BinaryAsset createBinaryAsset(final PageState state);
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,

View File

@ -0,0 +1,171 @@
/*
* Copyright (C) 2017 LibreCCM Foundation.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA
*/
package com.arsdigita.cms.ui.assets.forms;
import com.arsdigita.bebop.FormData;
import com.arsdigita.bebop.FormProcessException;
import com.arsdigita.bebop.Label;
import com.arsdigita.bebop.PageState;
import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.bebop.event.FormValidationListener;
import com.arsdigita.bebop.form.TextArea;
import com.arsdigita.bebop.form.TextField;
import com.arsdigita.cms.ui.assets.AbstractAssetForm;
import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.globalization.GlobalizedMessage;
import org.librecms.CmsConstants;
import org.librecms.assets.Bookmark;
import org.librecms.contentsection.Asset;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Objects;
import java.util.Optional;
/**
* Abstract base form for all forms for {@link BookmarkAsset}s.
*
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
* @param <T> Type of the Bookmark Asset.
*/
public abstract class AbstractBookmarkForm<T extends Bookmark>
extends AbstractAssetForm<T> {
private TextArea description;
private TextField url;
public AbstractBookmarkForm(final AssetPane assetPane) {
super(assetPane);
}
@Override
protected void addWidgets() {
add(new Label(
new GlobalizedMessage("cms.ui.assets.bookmark.description",
CmsConstants.CMS_BUNDLE)));
description = new TextArea("bookmark-description");
add(description);
add(new Label(new GlobalizedMessage("cms.ui.assets.bookmark.url",
CmsConstants.CMS_BUNDLE)));
url = new TextField("bookmark-url");
add(url);
addValidationListener(new FormValidationListener() {
@Override
public void validate(final FormSectionEvent event)
throws FormProcessException {
final PageState state = event.getPageState();
final FormData data = event.getFormData();
try {
new URL((String) url.getValue(state));
} catch (MalformedURLException ex) {
data.addError(new GlobalizedMessage(
"cms.ui.assets.bookmark.url.malformed",
CmsConstants.CMS_BUNDLE));
}
}
});
}
@Override
protected void initForm(final PageState state,
final Optional<T> selectedAsset) {
if (selectedAsset.isPresent()) {
if (!(selectedAsset.get() instanceof Bookmark)) {
throw new IllegalArgumentException(String.format(
"The provided asset must be an instanceof of class '%s' or "
+ "an subclass but is an instanceof of class '%s'.",
Bookmark.class.getName(),
selectedAsset.get().getClass().getName()));
}
final Bookmark bookmark = selectedAsset.get();
description.setValue(state,
bookmark
.getDescription()
.getValue(getSelectedLocale(state)));
url.setValue(state, bookmark.getUrl());
}
}
@Override
protected void showLocale(final PageState state) {
final Optional<T> selectedAsset = getSelectedAsset(state);
if (selectedAsset.isPresent()) {
if (!(getSelectedAsset(state).get() instanceof Bookmark)) {
throw new IllegalArgumentException(
"Selected asset is not a bookmark");
}
final Bookmark bookmark = selectedAsset.get();
description.setValue(state,
bookmark
.getDescription()
.getValue(getSelectedLocale(state)));
}
}
protected void updateData(final Bookmark bookmark,
final PageState state) {
bookmark
.getDescription()
.addValue(getSelectedLocale(state),
(String) description.getValue(state));
bookmark.setUrl((String) url.getValue(state));
}
@Override
protected void updateAsset(final Asset asset,
final FormSectionEvent event)
throws FormProcessException {
Objects.requireNonNull(asset);
Objects.requireNonNull(event);
final PageState state = event.getPageState();
if (!(asset instanceof Bookmark)) {
throw new IllegalArgumentException(String.format(
"Provided asset is not an instance of class (or sub class of) "
+ "'%s' but is an instance of class '%s'",
Bookmark.class.getName(),
asset.getClass().getName()));
}
final Bookmark bookmark = (Bookmark) asset;
updateData(bookmark, state);
}
}

View File

@ -25,11 +25,11 @@ import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.cms.ui.assets.AssetSearchWidget; import com.arsdigita.cms.ui.assets.AssetSearchWidget;
import com.arsdigita.globalization.GlobalizedMessage; import com.arsdigita.globalization.GlobalizedMessage;
import org.libreccm.cdi.utils.CdiUtil; import org.libreccm.cdi.utils.CdiUtil;
import org.librecms.CmsConstants; import org.librecms.CmsConstants;
import org.librecms.assets.AudioAsset; import org.librecms.assets.AudioAsset;
import org.librecms.assets.BinaryAsset; import org.librecms.assets.BinaryAsset;
import org.librecms.assets.Image;
import org.librecms.assets.LegalMetadata; import org.librecms.assets.LegalMetadata;
import org.librecms.contentsection.Asset; import org.librecms.contentsection.Asset;
import org.librecms.contentsection.AssetRepository; import org.librecms.contentsection.AssetRepository;
@ -39,8 +39,9 @@ import java.util.Optional;
/** /**
* *
* @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a> * @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a>
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class AudioForm extends BinaryAssetForm { public class AudioForm extends AbstractBinaryAssetForm<AudioAsset> {
private AssetSearchWidget assetSearchWidget; private AssetSearchWidget assetSearchWidget;
@ -61,13 +62,14 @@ public class AudioForm extends BinaryAssetForm {
} }
@Override @Override
protected void initForm(PageState state, Optional<Asset> selectedAsset) { protected void initForm(final PageState state,
final Optional<AudioAsset> selectedAsset) {
super.initForm(state, selectedAsset); super.initForm(state, selectedAsset);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
final AudioAsset audioAsset = (AudioAsset) selectedAsset.get(); final AudioAsset audioAsset = selectedAsset.get();
final LegalMetadata legalMetadata = audioAsset final LegalMetadata legalMetadata = audioAsset
.getLegalMetadata(); .getLegalMetadata();
@ -78,17 +80,22 @@ public class AudioForm extends BinaryAssetForm {
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) protected Class<AudioAsset> getAssetClass() {
throws FormProcessException { return AudioAsset.class;
final AudioAsset audioAsset = (AudioAsset) super.createAsset(event);
final PageState state = event.getPageState();
updateData(audioAsset, state);
return audioAsset;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event)
// throws FormProcessException {
//
// final AudioAsset audioAsset = (AudioAsset) super.createAsset(event);
//
// final PageState state = event.getPageState();
//
// updateData(audioAsset, state);
//
// return audioAsset;
// }
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,
@ -122,8 +129,8 @@ public class AudioForm extends BinaryAssetForm {
} }
} }
@Override // @Override
protected BinaryAsset createBinaryAsset(final PageState state) { // protected BinaryAsset createBinaryAsset(final PageState state) {
return new AudioAsset(); // return new AudioAsset();
} // }
} }

View File

@ -18,168 +18,159 @@
*/ */
package com.arsdigita.cms.ui.assets.forms; package com.arsdigita.cms.ui.assets.forms;
import com.arsdigita.bebop.FormData;
import com.arsdigita.bebop.FormProcessException;
import com.arsdigita.bebop.Label;
import com.arsdigita.bebop.PageState;
import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.bebop.event.FormValidationListener;
import com.arsdigita.bebop.form.TextArea; import com.arsdigita.bebop.form.TextArea;
import com.arsdigita.bebop.form.TextField; import com.arsdigita.bebop.form.TextField;
import com.arsdigita.cms.ui.assets.AssetForm;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.globalization.GlobalizedMessage;
import org.librecms.CmsConstants;
import org.librecms.assets.Bookmark; import org.librecms.assets.Bookmark;
import org.librecms.contentsection.Asset;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Objects;
import java.util.Optional;
/** /**
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class BookmarkForm extends AssetForm { public class BookmarkForm extends AbstractBookmarkForm<Bookmark> {
private TextArea description; // private TextArea description;
private TextField url; // private TextField url;
public BookmarkForm(final AssetPane assetPane) { public BookmarkForm(final AssetPane assetPane) {
super(assetPane); super(assetPane);
} }
@Override // @Override
protected void addWidgets() { // protected void addWidgets() {
//
add(new Label( // add(new Label(
new GlobalizedMessage("cms.ui.assets.bookmark.description", // new GlobalizedMessage("cms.ui.assets.bookmark.description",
CmsConstants.CMS_BUNDLE))); // CmsConstants.CMS_BUNDLE)));
description = new TextArea("bookmark-description"); // description = new TextArea("bookmark-description");
add(description); // add(description);
//
add(new Label(new GlobalizedMessage("cms.ui.assets.bookmark.url", // add(new Label(new GlobalizedMessage("cms.ui.assets.bookmark.url",
CmsConstants.CMS_BUNDLE))); // CmsConstants.CMS_BUNDLE)));
url = new TextField("bookmark-url"); // url = new TextField("bookmark-url");
add(url); // add(url);
//
addValidationListener(new FormValidationListener() { // addValidationListener(new FormValidationListener() {
//
@Override // @Override
public void validate(final FormSectionEvent event) // public void validate(final FormSectionEvent event)
throws FormProcessException { // throws FormProcessException {
//
final PageState state = event.getPageState(); // final PageState state = event.getPageState();
final FormData data = event.getFormData(); // final FormData data = event.getFormData();
//
try { // try {
new URL((String) url.getValue(state)); // new URL((String) url.getValue(state));
} catch (MalformedURLException ex) { // } catch (MalformedURLException ex) {
data.addError(new GlobalizedMessage( // data.addError(new GlobalizedMessage(
"cms.ui.assets.bookmark.url.malformed", // "cms.ui.assets.bookmark.url.malformed",
CmsConstants.CMS_BUNDLE)); // CmsConstants.CMS_BUNDLE));
} // }
} // }
//
}); // });
//
} // }
//
// @Override
// protected void initForm(final PageState state,
// final Optional<Bookmark> selectedAsset) {
//
// if (selectedAsset.isPresent()) {
//
// if (!(selectedAsset.get() instanceof Bookmark)) {
// throw new IllegalArgumentException(String.format(
// "The provided asset must be an instanceof of class '%s' or "
// + "an subclass but is an instanceof of class '%s'.",
// Bookmark.class.getName(),
// selectedAsset.get().getClass().getName()));
// }
//
// final Bookmark bookmark = selectedAsset.get();
//
// description.setValue(state,
// bookmark
// .getDescription()
// .getValue(getSelectedLocale(state)));
// url.setValue(state, bookmark.getUrl());
//
// }
//
// }
//
// @Override
// protected void showLocale(final PageState state) {
// final Optional<Bookmark> selectedAsset = getSelectedAsset(state);
//
// if (selectedAsset.isPresent()) {
// if (!(getSelectedAsset(state).get() instanceof Bookmark)) {
// throw new IllegalArgumentException(
// "Selected asset is not a bookmark");
// }
//
// final Bookmark bookmark = selectedAsset.get();
//
// description.setValue(state,
// bookmark
// .getDescription()
// .getValue(getSelectedLocale(state)));
// }
// }
@Override @Override
protected void initForm(final PageState state, @SuppressWarnings("unchecked")
final Optional<Asset> selectedAsset) { protected Class<Bookmark> getAssetClass() {
return Bookmark.class;
if (selectedAsset.isPresent()) {
if (!(selectedAsset.get() instanceof Bookmark)) {
throw new IllegalArgumentException(String.format(
"The provided asset must be an instanceof of class '%s' or "
+ "an subclass but is an instanceof of class '%s'.",
Bookmark.class.getName(),
selectedAsset.get().getClass().getName()));
}
final Bookmark bookmark = (Bookmark) selectedAsset.get();
description.setValue(state,
bookmark
.getDescription()
.getValue(getSelectedLocale(state)));
url.setValue(state, bookmark.getUrl());
}
}
@Override
protected void showLocale(final PageState state) {
final Optional<Asset> selectedAsset = getSelectedAsset(state);
if (selectedAsset.isPresent()) {
if (!(getSelectedAsset(state).get() instanceof Bookmark)) {
throw new IllegalArgumentException(
"Selected asset is not a bookmark");
}
final Bookmark bookmark = (Bookmark) selectedAsset.get();
description.setValue(state,
bookmark
.getDescription()
.getValue(getSelectedLocale(state)));
}
}
@Override
protected Asset createAsset(final FormSectionEvent event)
throws FormProcessException {
Objects.requireNonNull(event);
final PageState state = event.getPageState();
final Bookmark bookmark = new Bookmark();
updateData(bookmark, state);
return bookmark;
}
protected void updateData(final Bookmark bookmark,
final PageState state) {
bookmark
.getDescription()
.addValue(getSelectedLocale(state),
(String) description.getValue(state));
bookmark.setUrl((String) url.getValue(state));
} }
// @Override
@Override // protected Asset createAsset(final FormSectionEvent event)
protected void updateAsset(final Asset asset, // throws FormProcessException {
final FormSectionEvent event) //
throws FormProcessException { // Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// final Bookmark bookmark = new Bookmark();
//
// updateData(bookmark, state);
//
// return bookmark;
// }
Objects.requireNonNull(asset); // protected void updateData(final Bookmark bookmark,
Objects.requireNonNull(event); // final PageState state) {
// bookmark
final PageState state = event.getPageState(); // .getDescription()
// .addValue(getSelectedLocale(state),
if (!(asset instanceof Bookmark)) { // (String) description.getValue(state));
throw new IllegalArgumentException(String.format( //
"Provided asset is not an instance of class (or sub class of) " // bookmark.setUrl((String) url.getValue(state));
+ "'%s' but is an instance of class '%s'", // }
Bookmark.class.getName(), //
asset.getClass().getName())); //
} // @Override
// protected void updateAsset(final Asset asset,
final Bookmark bookmark = (Bookmark) asset; // final FormSectionEvent event)
// throws FormProcessException {
updateData(bookmark, state); //
} // Objects.requireNonNull(asset);
// Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// if (!(asset instanceof Bookmark)) {
// throw new IllegalArgumentException(String.format(
// "Provided asset is not an instance of class (or sub class of) "
// + "'%s' but is an instance of class '%s'",
// Bookmark.class.getName(),
// asset.getClass().getName()));
// }
//
// final Bookmark bookmark = (Bookmark) asset;
//
// updateData(bookmark, state);
// }
} }

View File

@ -18,13 +18,13 @@
*/ */
package com.arsdigita.cms.ui.assets.forms; package com.arsdigita.cms.ui.assets.forms;
import com.arsdigita.bebop.FormProcessException;
import com.arsdigita.bebop.Label; import com.arsdigita.bebop.Label;
import com.arsdigita.bebop.PageState; import com.arsdigita.bebop.PageState;
import com.arsdigita.bebop.event.FormSectionEvent; import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.cms.ui.assets.AssetSearchWidget; import com.arsdigita.cms.ui.assets.AssetSearchWidget;
import com.arsdigita.globalization.GlobalizedMessage; import com.arsdigita.globalization.GlobalizedMessage;
import org.libreccm.cdi.utils.CdiUtil; import org.libreccm.cdi.utils.CdiUtil;
import org.librecms.CmsConstants; import org.librecms.CmsConstants;
import org.librecms.assets.Bookmark; import org.librecms.assets.Bookmark;
@ -41,7 +41,8 @@ import java.util.Optional;
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
* @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a> * @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a>
*/ */
public class ExternalAudioAssetForm extends BookmarkForm { public class ExternalAudioAssetForm
extends AbstractBookmarkForm<ExternalAudioAsset> {
private AssetSearchWidget assetSearchWidget; private AssetSearchWidget assetSearchWidget;
@ -63,13 +64,12 @@ public class ExternalAudioAssetForm extends BookmarkForm {
@Override @Override
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<ExternalAudioAsset> selectedAsset) {
super.initForm(state, selectedAsset); super.initForm(state, selectedAsset);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
final ExternalAudioAsset externalAudioAsset final ExternalAudioAsset externalAudioAsset
= (ExternalAudioAsset) selectedAsset = (ExternalAudioAsset) selectedAsset.get();
.get();
final LegalMetadata legalMetadata = externalAudioAsset final LegalMetadata legalMetadata = externalAudioAsset
.getLegalMetadata(); .getLegalMetadata();
@ -80,21 +80,25 @@ public class ExternalAudioAssetForm extends BookmarkForm {
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) protected Class<ExternalAudioAsset> getAssetClass() {
throws FormProcessException { return ExternalAudioAsset.class;
Objects.requireNonNull(event);
final PageState state = event.getPageState();
final ExternalAudioAsset externalAudioAsset = new ExternalAudioAsset();
updateData((Bookmark) externalAudioAsset, state);
updateData(externalAudioAsset, state);
return externalAudioAsset;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event)
// throws FormProcessException {
//
// Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// final ExternalAudioAsset externalAudioAsset = new ExternalAudioAsset();
//
// updateData((Bookmark) externalAudioAsset, state);
// updateData(externalAudioAsset, state);
//
// return externalAudioAsset;
// }
protected void updateData(final ExternalAudioAsset externalAudioAsset, protected void updateData(final ExternalAudioAsset externalAudioAsset,
final PageState state) { final PageState state) {
@ -114,14 +118,14 @@ public class ExternalAudioAssetForm extends BookmarkForm {
} }
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,
final FormSectionEvent event) { final FormSectionEvent event) {
Objects.requireNonNull(asset); Objects.requireNonNull(asset);
Objects.requireNonNull(event); Objects.requireNonNull(event);
final PageState state = event.getPageState(); final PageState state = event.getPageState();
if (!(asset instanceof ExternalAudioAsset)) { if (!(asset instanceof ExternalAudioAsset)) {
throw new IllegalArgumentException(String.format( throw new IllegalArgumentException(String.format(
"Provided asset is not an instance of class (or sub class of) " "Provided asset is not an instance of class (or sub class of) "

View File

@ -18,7 +18,6 @@
*/ */
package com.arsdigita.cms.ui.assets.forms; package com.arsdigita.cms.ui.assets.forms;
import com.arsdigita.bebop.FormProcessException;
import com.arsdigita.bebop.Label; import com.arsdigita.bebop.Label;
import com.arsdigita.bebop.PageState; import com.arsdigita.bebop.PageState;
import com.arsdigita.bebop.event.FormSectionEvent; import com.arsdigita.bebop.event.FormSectionEvent;
@ -42,7 +41,8 @@ import org.librecms.contentsection.AssetRepository;
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class ExternalVideoAssetForm extends BookmarkForm { public class ExternalVideoAssetForm
extends AbstractBookmarkForm<ExternalVideoAsset> {
private AssetSearchWidget assetSearchWidget; private AssetSearchWidget assetSearchWidget;
@ -64,7 +64,7 @@ public class ExternalVideoAssetForm extends BookmarkForm {
@Override @Override
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<ExternalVideoAsset> selectedAsset) {
super.initForm(state, selectedAsset); super.initForm(state, selectedAsset);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
@ -81,20 +81,25 @@ public class ExternalVideoAssetForm extends BookmarkForm {
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) protected Class<ExternalVideoAsset> getAssetClass() {
throws FormProcessException { return ExternalVideoAsset.class;
Objects.requireNonNull(event);
final PageState state = event.getPageState();
final ExternalVideoAsset externalVideoAsset = new ExternalVideoAsset();
updateData((Bookmark) externalVideoAsset, state);
updateData(externalVideoAsset, state);
return externalVideoAsset;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event)
// throws FormProcessException {
//
// Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// final ExternalVideoAsset externalVideoAsset = new ExternalVideoAsset();
//
// updateData((Bookmark) externalVideoAsset, state);
// updateData(externalVideoAsset, state);
//
// return externalVideoAsset;
// }
protected void updateData(final ExternalVideoAsset externalVideoAsset, protected void updateData(final ExternalVideoAsset externalVideoAsset,
final PageState state) { final PageState state) {

View File

@ -27,17 +27,22 @@ import org.librecms.assets.FileAsset;
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class FileAssetForm extends BinaryAssetForm { public class FileAssetForm extends AbstractBinaryAssetForm<FileAsset> {
public FileAssetForm(final AssetPane assetPane) { public FileAssetForm(final AssetPane assetPane) {
super(assetPane); super(assetPane);
} }
@Override @Override
protected BinaryAsset createBinaryAsset(final PageState state) { protected Class<FileAsset> getAssetClass() {
return new FileAsset(); return FileAsset.class;
} }
// @Override
// protected BinaryAsset createBinaryAsset(final PageState state) {
// return new FileAsset();
// }
} }

View File

@ -40,8 +40,9 @@ import java.util.Optional;
/** /**
* *
* @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a> * @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a>
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class ImageForm extends BinaryAssetForm { public class ImageForm extends AbstractBinaryAssetForm<Image> {
private TextField width; private TextField width;
private TextField height; private TextField height;
@ -55,7 +56,7 @@ public class ImageForm extends BinaryAssetForm {
protected void addWidgets() { protected void addWidgets() {
super.addWidgets(); super.addWidgets();
width = new TextField("width-text"); width = new TextField("width-text");
height = new TextField("height-text"); height = new TextField("height-text");
assetSearchWidget = new AssetSearchWidget("legal-metadata", assetSearchWidget = new AssetSearchWidget("legal-metadata",
@ -81,14 +82,14 @@ public class ImageForm extends BinaryAssetForm {
} }
@Override @Override
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<Image> selectedAsset) {
super.initForm(state, selectedAsset); super.initForm(state, selectedAsset);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
Image image = (Image) selectedAsset.get(); final Image image = selectedAsset.get();
width.setValue(state, width.setValue(state,
Long.toString(image.getWidth())); Long.toString(image.getWidth()));
@ -103,22 +104,35 @@ public class ImageForm extends BinaryAssetForm {
} }
} }
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) protected Class<Image> getAssetClass() {
throws FormProcessException { return Image.class;
final Image image = (Image) super.createAsset(event);
final PageState state = event.getPageState();
image.setHeight(Long.parseLong((String) height.getValue(state)));
image.setWidth(Long.parseLong((String) width.getValue(state)));
updateData(image, state);
return image;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event)
// throws FormProcessException {
//
// final Image image = (Image) super.createAsset(event);
//
// final PageState state = event.getPageState();
//
// image.setDisplayName(getTitleValue(state)
// .toLowerCase()
// .replace(" ", "-"));
//
// if (height.getValue(state) != null) {
// image.setHeight(Long.parseLong((String) height.getValue(state)));
// }
// if (width.getValue(state) != null) {
// image.setWidth(Long.parseLong((String) width.getValue(state)));
// }
// updateData(image, state);
//
// return image;
// }
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,
final FormSectionEvent event) final FormSectionEvent event)
@ -154,9 +168,9 @@ public class ImageForm extends BinaryAssetForm {
} }
} }
@Override // @Override
protected BinaryAsset createBinaryAsset(final PageState state) { // protected BinaryAsset createBinaryAsset(final PageState state) {
return new Image(); // return new Image();
} // }
} }

View File

@ -24,7 +24,7 @@ import com.arsdigita.bebop.Label;
import com.arsdigita.bebop.PageState; import com.arsdigita.bebop.PageState;
import com.arsdigita.bebop.event.FormSectionEvent; import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.bebop.form.TextArea; import com.arsdigita.bebop.form.TextArea;
import com.arsdigita.cms.ui.assets.AssetForm; import com.arsdigita.cms.ui.assets.AbstractAssetForm;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.globalization.GlobalizedMessage; import com.arsdigita.globalization.GlobalizedMessage;
@ -39,7 +39,7 @@ import java.util.Optional;
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class LegalMetadataForm extends AssetForm { public class LegalMetadataForm extends AbstractAssetForm<LegalMetadata> {
private TextArea rightsHolder; private TextArea rightsHolder;
private TextArea rights; private TextArea rights;
@ -84,7 +84,7 @@ public class LegalMetadataForm extends AssetForm {
@Override @Override
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<LegalMetadata> selectedAsset) {
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
@ -96,8 +96,7 @@ public class LegalMetadataForm extends AssetForm {
selectedAsset.get().getClass().getName())); selectedAsset.get().getClass().getName()));
} }
final LegalMetadata legalMetadata = (LegalMetadata) selectedAsset final LegalMetadata legalMetadata = selectedAsset.get();
.get();
rightsHolder.setValue(state, legalMetadata.getRightsHolder()); rightsHolder.setValue(state, legalMetadata.getRightsHolder());
rights.setValue(state, rights.setValue(state,
@ -112,7 +111,7 @@ public class LegalMetadataForm extends AssetForm {
@Override @Override
protected void showLocale(final PageState state) { protected void showLocale(final PageState state) {
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<LegalMetadata> selectedAsset = getSelectedAsset(state);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
if (!(getSelectedAsset(state).get() instanceof LegalMetadata)) { if (!(getSelectedAsset(state).get() instanceof LegalMetadata)) {
@ -120,8 +119,7 @@ public class LegalMetadataForm extends AssetForm {
"Selected asset is not a legal metadata"); "Selected asset is not a legal metadata");
} }
final LegalMetadata legalMetadata = (LegalMetadata) selectedAsset. final LegalMetadata legalMetadata = selectedAsset.get();
get();
rights.setValue(state, rights.setValue(state,
legalMetadata legalMetadata
@ -131,33 +129,37 @@ public class LegalMetadataForm extends AssetForm {
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) protected Class<LegalMetadata> getAssetClass() {
throws FormProcessException { return LegalMetadata.class;
Objects.requireNonNull(event);
final PageState state = event.getPageState();
final LegalMetadata legalMetadata = new LegalMetadata();
legalMetadata.setRightsHolder((String) rightsHolder.getValue(state));
legalMetadata.getRights().addValue(getSelectedLocale(state),
(String) rights.getValue(state));
legalMetadata.setPublisher((String) publisher.getValue(state));
legalMetadata.setCreator((String) creator.getValue(state));
return legalMetadata;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event)
// throws FormProcessException {
//
// Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// final LegalMetadata legalMetadata = new LegalMetadata();
//
// legalMetadata.setRightsHolder((String) rightsHolder.getValue(state));
// legalMetadata.getRights().addValue(getSelectedLocale(state),
// (String) rights.getValue(state));
//
// legalMetadata.setPublisher((String) publisher.getValue(state));
// legalMetadata.setCreator((String) creator.getValue(state));
//
// return legalMetadata;
// }
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,
final FormSectionEvent event) final FormSectionEvent event)
throws FormProcessException { throws FormProcessException {
Objects.requireNonNull(asset); Objects.requireNonNull(asset);
Objects.requireNonNull(event); Objects.requireNonNull(event);
final PageState state = event.getPageState(); final PageState state = event.getPageState();
if (!(asset instanceof LegalMetadata)) { if (!(asset instanceof LegalMetadata)) {

View File

@ -23,11 +23,13 @@ import com.arsdigita.bebop.Label;
import com.arsdigita.bebop.PageState; import com.arsdigita.bebop.PageState;
import com.arsdigita.bebop.event.FormSectionEvent; import com.arsdigita.bebop.event.FormSectionEvent;
import com.arsdigita.bebop.form.TextArea; import com.arsdigita.bebop.form.TextArea;
import com.arsdigita.cms.ui.assets.AssetForm; import com.arsdigita.cms.ui.assets.AbstractAssetForm;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.globalization.GlobalizedMessage; import com.arsdigita.globalization.GlobalizedMessage;
import java.util.Objects; import java.util.Objects;
import java.util.Optional; import java.util.Optional;
import org.librecms.CmsConstants; import org.librecms.CmsConstants;
import org.librecms.assets.SideNote; import org.librecms.assets.SideNote;
import org.librecms.contentsection.Asset; import org.librecms.contentsection.Asset;
@ -36,7 +38,7 @@ import org.librecms.contentsection.Asset;
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
public class SideNoteForm extends AssetForm { public class SideNoteForm extends AbstractAssetForm<SideNote> {
private TextArea text; private TextArea text;
@ -55,7 +57,7 @@ public class SideNoteForm extends AssetForm {
@Override @Override
protected void initForm(final PageState state, protected void initForm(final PageState state,
final Optional<Asset> selectedAsset) { final Optional<SideNote> selectedAsset) {
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
if (!(selectedAsset.get() instanceof SideNote)) { if (!(selectedAsset.get() instanceof SideNote)) {
@ -66,8 +68,8 @@ public class SideNoteForm extends AssetForm {
selectedAsset.get().getClass().getName())); selectedAsset.get().getClass().getName()));
} }
final SideNote sideNote = (SideNote) selectedAsset.get(); final SideNote sideNote = selectedAsset.get();
text.setValue(state, text.setValue(state,
sideNote sideNote
.getText() .getText()
@ -79,7 +81,7 @@ public class SideNoteForm extends AssetForm {
@Override @Override
protected void showLocale(final PageState state) { protected void showLocale(final PageState state) {
final Optional<Asset> selectedAsset = getSelectedAsset(state); final Optional<SideNote> selectedAsset = getSelectedAsset(state);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
if (!(selectedAsset.get() instanceof SideNote)) { if (!(selectedAsset.get() instanceof SideNote)) {
@ -90,7 +92,7 @@ public class SideNoteForm extends AssetForm {
selectedAsset.get().getClass().getName())); selectedAsset.get().getClass().getName()));
} }
final SideNote sideNote = (SideNote) selectedAsset.get(); final SideNote sideNote =selectedAsset.get();
text.setValue(state, text.setValue(state,
sideNote sideNote
@ -100,23 +102,30 @@ public class SideNoteForm extends AssetForm {
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) throws protected Class<SideNote> getAssetClass() {
FormProcessException { return SideNote.class;
Objects.requireNonNull(event);
final PageState state = event.getPageState();
final SideNote sideNote = new SideNote();
sideNote
.getText()
.addValue(getSelectedLocale(state),
(String) text.getValue(state));
return sideNote;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event) throws
// FormProcessException {
//
// Objects.requireNonNull(event);
//
// final PageState state = event.getPageState();
//
// final SideNote sideNote = new SideNote();
//
// sideNote
// .getText()
// .addValue(getSelectedLocale(state),
// (String) text.getValue(state));
//
// return sideNote;
// }
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,
final FormSectionEvent event) final FormSectionEvent event)

View File

@ -26,9 +26,9 @@ import com.arsdigita.bebop.form.TextField;
import com.arsdigita.cms.ui.assets.AssetPane; import com.arsdigita.cms.ui.assets.AssetPane;
import com.arsdigita.cms.ui.assets.AssetSearchWidget; import com.arsdigita.cms.ui.assets.AssetSearchWidget;
import com.arsdigita.globalization.GlobalizedMessage; import com.arsdigita.globalization.GlobalizedMessage;
import org.libreccm.cdi.utils.CdiUtil; import org.libreccm.cdi.utils.CdiUtil;
import org.librecms.CmsConstants; import org.librecms.CmsConstants;
import org.librecms.assets.BinaryAsset;
import org.librecms.assets.VideoAsset; import org.librecms.assets.VideoAsset;
import org.librecms.assets.LegalMetadata; import org.librecms.assets.LegalMetadata;
import org.librecms.contentsection.Asset; import org.librecms.contentsection.Asset;
@ -39,8 +39,10 @@ import java.util.Optional;
/** /**
* *
* @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a> * @author <a href="mailto:yannick.buelter@yabue.de">Yannick Bülter</a>
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*
*/ */
public class VideoForm extends BinaryAssetForm { public class VideoForm extends AbstractBinaryAssetForm<VideoAsset> {
private TextField width; private TextField width;
private TextField height; private TextField height;
@ -77,13 +79,14 @@ public class VideoForm extends BinaryAssetForm {
} }
@Override @Override
protected void initForm(PageState state, Optional<Asset> selectedAsset) { protected void initForm(final PageState state,
final Optional<VideoAsset> selectedAsset) {
super.initForm(state, selectedAsset); super.initForm(state, selectedAsset);
if (selectedAsset.isPresent()) { if (selectedAsset.isPresent()) {
VideoAsset video = (VideoAsset) selectedAsset.get(); final VideoAsset video = selectedAsset.get();
width.setValue(state, width.setValue(state,
Long.toString(video.getWidth())); Long.toString(video.getWidth()));
@ -98,20 +101,27 @@ public class VideoForm extends BinaryAssetForm {
} }
@Override @Override
protected Asset createAsset(final FormSectionEvent event) protected Class<VideoAsset> getAssetClass() {
throws FormProcessException { return VideoAsset.class;
final VideoAsset video = (VideoAsset) super.createAsset(event);
final PageState state = event.getPageState();
video.setHeight(Long.parseLong((String) height.getValue(state)));
video.setWidth(Long.parseLong((String) width.getValue(state)));
updateData(video, state);
return video;
} }
// @Override
// protected Asset createAsset(final FormSectionEvent event)
// throws FormProcessException {
//
// final VideoAsset video = (VideoAsset) super.createAsset(event);
//
// final PageState state = event.getPageState();
//
// video.setHeight(Long.parseLong((String) height.getValue(state)));
// video.setWidth(Long.parseLong((String) width.getValue(state)));
// updateData(video, state);
//
// return video;
// }
@Override @Override
protected void updateAsset(final Asset asset, protected void updateAsset(final Asset asset,
final FormSectionEvent event) final FormSectionEvent event)
@ -147,8 +157,8 @@ public class VideoForm extends BinaryAssetForm {
} }
} }
@Override // @Override
protected BinaryAsset createBinaryAsset(final PageState state) { // protected BinaryAsset createBinaryAsset(final PageState state) {
return new VideoAsset(); // return new VideoAsset();
} // }
} }

View File

@ -18,7 +18,7 @@
*/ */
package org.librecms.assets; package org.librecms.assets;
import com.arsdigita.cms.ui.assets.AssetForm; import com.arsdigita.cms.ui.assets.AbstractAssetForm;
import java.lang.annotation.ElementType; import java.lang.annotation.ElementType;
import java.lang.annotation.Retention; import java.lang.annotation.Retention;
@ -50,7 +50,7 @@ public @interface AssetType {
* @return The form for editing and creating assets of the annotated sub * @return The form for editing and creating assets of the annotated sub
* class {@link org.librecms.contentsection.Asset}. * class {@link org.librecms.contentsection.Asset}.
*/ */
Class<? extends AssetForm> assetForm(); Class<? extends AbstractAssetForm> assetForm();
/** /**
* The key for the localised label of the asset type. If not set the default * The key for the localised label of the asset type. If not set the default

View File

@ -18,7 +18,7 @@
*/ */
package org.librecms.assets; package org.librecms.assets;
import com.arsdigita.cms.ui.assets.AssetForm; import com.arsdigita.cms.ui.assets.AbstractAssetForm;
import org.librecms.contentsection.Asset; import org.librecms.contentsection.Asset;
@ -59,7 +59,7 @@ public class AssetTypeInfo {
/** /**
* The form for editing and creating asset of the type described. * The form for editing and creating asset of the type described.
*/ */
private Class<? extends AssetForm> assetForm; private Class<? extends AbstractAssetForm> assetForm;
public String getLabelBundle() { public String getLabelBundle() {
return labelBundle; return labelBundle;
@ -101,11 +101,11 @@ public class AssetTypeInfo {
this.assetClass = assetClass; this.assetClass = assetClass;
} }
public Class<? extends AssetForm> getAssetForm() { public Class<? extends AbstractAssetForm> getAssetForm() {
return assetForm; return assetForm;
} }
public void setAssetForm(final Class<? extends AssetForm> assetForm) { public void setAssetForm(final Class<? extends AbstractAssetForm> assetForm) {
this.assetForm = assetForm; this.assetForm = assetForm;
} }

View File

@ -259,6 +259,25 @@ import static org.librecms.CmsConstants.*;
+ " OR true = :isSystemUser OR true = :isAdmin" + " OR true = :isSystemUser OR true = :isAdmin"
+ ")") + ")")
, ,
@NamedQuery(
name = "Asset.findByNameInFolder",
query = "SELECT DISTINCT a "
+ "FROM Asset a "
+ "JOIN a.categories c "
+ "LEFT JOIN a.permissions p "
+ "WHERE c.category = :folder "
+ "AND c.type = '" + CATEGORIZATION_TYPE_FOLDER + "' "
+ "AND a.displayName = :name "
+ "AND ("
+ " ("
+ " p.grantee IN :roles "
+ " AND p.grantedPrivilege = '"
+ AssetPrivileges.VIEW + "'"
+ " ) "
+ " OR true = :isSystemUser OR true = :isAdmin"
+ " )"
)
,
@NamedQuery( @NamedQuery(
name = "Asset.countInFolder", name = "Asset.countInFolder",
query = "SELECT COUNT(DISTINCT a) " query = "SELECT COUNT(DISTINCT a) "

View File

@ -45,6 +45,7 @@ import java.util.Objects;
import org.libreccm.categorization.ObjectNotAssignedToCategoryException; import org.libreccm.categorization.ObjectNotAssignedToCategoryException;
import org.libreccm.core.UnexpectedErrorException; import org.libreccm.core.UnexpectedErrorException;
import org.libreccm.l10n.LocalizedString; import org.libreccm.l10n.LocalizedString;
import org.libreccm.security.PermissionManager;
import java.beans.BeanInfo; import java.beans.BeanInfo;
import java.beans.IntrospectionException; import java.beans.IntrospectionException;
@ -52,6 +53,7 @@ import java.beans.Introspector;
import java.beans.PropertyDescriptor; import java.beans.PropertyDescriptor;
import java.lang.reflect.InvocationTargetException; import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -69,9 +71,6 @@ public class AssetManager {
private static final Logger LOGGER = LogManager. private static final Logger LOGGER = LogManager.
getLogger(AssetManager.class); getLogger(AssetManager.class);
@Inject
private EntityManager entityManager;
@Inject @Inject
private AssetRepository assetRepo; private AssetRepository assetRepo;
@ -82,7 +81,47 @@ public class AssetManager {
private FolderRepository folderRepo; private FolderRepository folderRepo;
@Inject @Inject
private FolderManager folderManager; private PermissionManager permissionManager;
@Transactional(Transactional.TxType.REQUIRED)
public <T extends Asset> T createAsset(final String name,
final String title,
final Locale locale,
final Folder folder,
final Class<T> assetType) {
Objects.requireNonNull(name);
Objects.requireNonNull(title);
Objects.requireNonNull(locale);
Objects.requireNonNull(folder);
Objects.requireNonNull(assetType);
if (name.trim().isEmpty()) {
throw new IllegalArgumentException(
"The name of an asset can't be empty.");
}
if (title.trim().isEmpty()) {
throw new IllegalArgumentException(
"The title of an asset can't be empty.");
}
final T asset;
try {
asset = assetType.newInstance();
} catch (IllegalAccessException | InstantiationException ex) {
throw new UnexpectedErrorException(ex);
}
asset.setDisplayName(name);
asset.getTitle().addValue(locale, title);
assetRepo.save(asset);
categoryManager.addObjectToCategory(asset, folder);
permissionManager.copyPermissions(folder, asset, true);
return asset;
}
/** /**
* Makes an {@link Asset} a shared {@code Asset} by adding it to an asset * Makes an {@link Asset} a shared {@code Asset} by adding it to an asset
@ -468,7 +507,7 @@ public class AssetManager {
} else { } else {
sectionName = "?"; sectionName = "?";
} }
return String.format("%s:/%s", sectionName, path); return String.format("%s:/%s", sectionName, path);
} else { } else {
return String.format("/%s", path); return String.format("/%s", path);

View File

@ -18,10 +18,14 @@
*/ */
package org.librecms.contentsection; package org.librecms.contentsection;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.libreccm.auditing.AbstractAuditedEntityRepository; import org.libreccm.auditing.AbstractAuditedEntityRepository;
import org.libreccm.categorization.Categorization;
import org.libreccm.categorization.Category; import org.libreccm.categorization.Category;
import org.libreccm.categorization.CategoryManager; import org.libreccm.categorization.CategoryManager;
import org.libreccm.categorization.ObjectNotAssignedToCategoryException; import org.libreccm.categorization.ObjectNotAssignedToCategoryException;
import org.libreccm.core.CcmObject;
import org.libreccm.core.CcmObjectRepository; import org.libreccm.core.CcmObjectRepository;
import org.libreccm.core.UnexpectedErrorException; import org.libreccm.core.UnexpectedErrorException;
import org.libreccm.security.AuthorizationRequired; import org.libreccm.security.AuthorizationRequired;
@ -54,6 +58,9 @@ import javax.transaction.Transactional;
public class AssetRepository public class AssetRepository
extends AbstractAuditedEntityRepository<Long, Asset> { extends AbstractAuditedEntityRepository<Long, Asset> {
private static final Logger LOGGER = LogManager
.getLogger(AssetRepository.class);
@Inject @Inject
private Shiro shiro; private Shiro shiro;
@ -69,6 +76,9 @@ public class AssetRepository
@Inject @Inject
private CategoryManager categoryManager; private CategoryManager categoryManager;
@Inject
private FolderRepository folderRepo;
@Inject @Inject
private AssetManager assetManager; private AssetManager assetManager;
@ -523,6 +533,86 @@ public class AssetRepository
return query.getResultList(); return query.getResultList();
} }
@Transactional(Transactional.TxType.REQUIRED)
public Optional<Asset> findByNameInFolder(final Folder folder,
final String name) {
final TypedQuery<Asset> query = getEntityManager()
.createNamedQuery("Asset.findByNameInFolder",
Asset.class)
.setParameter("folder", folder)
.setParameter("name", name);
// setAuthorizationParameters(query);
try {
return Optional.of(query.getSingleResult());
} catch (NoResultException ex) {
return Optional.empty();
}
}
@Transactional(Transactional.TxType.REQUIRED)
public Optional<Asset> findByPath(final String path) {
//The last token is the name of the asset itself. Remove this part and
//get the folder containing the asset using the FolderRepository.
final String normalizedPath = PathUtil.normalizePath(path);
final int lastTokenStart = normalizedPath.lastIndexOf('/');
final String folderPath = normalizedPath.substring(0, lastTokenStart);
final String assetName = normalizedPath.substring(lastTokenStart + 1);
final Optional<Folder> folder = folderRepo.findByPath(
folderPath, FolderType.ASSETS_FOLDER);
if (folder.isPresent()) {
return findByNameInFolder(folder.get(), assetName);
} else {
return Optional.empty();
}
}
@Transactional(Transactional.TxType.REQUIRED)
public Optional<Asset> findByPath(final ContentSection section,
final String path) {
//The last token is the name of the asset itself. Remove this part an get
//the folder containing the asset using the FolderRepository.
final String normalizedPath = PathUtil.normalizePath(path);
final int lastTokenStart = normalizedPath.lastIndexOf('/');
final String assetName;
final Optional<Folder> folder;
if (lastTokenStart < 0) {
assetName = normalizedPath;
folder = folderRepo
.findById(section.getRootAssetsFolder().getObjectId());
} else {
final String folderPath = normalizedPath
.substring(0, lastTokenStart);
assetName = normalizedPath.substring(lastTokenStart + 1);
folder = folderRepo
.findByPath(section, folderPath, FolderType.ASSETS_FOLDER);
}
if (folder.isPresent()) {
LOGGER.debug("transaction is active? {}",
entityManager.isJoinedToTransaction());
LOGGER.debug("Folder for path {} found...", path);
// LOGGER.debug("Assets in the folder:");
// final Folder theFolder = folderRepo
// .findById(folder.get().getObjectId())
// .orElseThrow(() -> new IllegalArgumentException());
for (final Categorization categorization : folder.get().getObjects()) {
LOGGER.debug(" {}",
categorization.getCategorizedObject()
.getDisplayName());
}
return findByNameInFolder(folder.get(), assetName);
} else {
return Optional.empty();
}
}
/** /**
* Counts the assets of a specific type which name starts with a provided * Counts the assets of a specific type which name starts with a provided
* string in a specific folder. * string in a specific folder.

View File

@ -233,9 +233,9 @@ import static org.librecms.CmsConstants.*;
+ " ELSE '" + ItemPrivileges.VIEW_PUBLISHED + "' " + " ELSE '" + ItemPrivileges.VIEW_PUBLISHED + "' "
+ " END" + " END"
+ " )" + " )"
+ " )" + " )"
+ " OR true = :isSystemUser OR true = :isAdmin" + " OR true = :isSystemUser OR true = :isAdmin"
+ " )") + " )")
, ,
@NamedQuery( @NamedQuery(
name = "ContentItem.countByNameInFolder", name = "ContentItem.countByNameInFolder",

View File

@ -18,8 +18,6 @@
*/ */
package org.librecms.contentsection; package org.librecms.contentsection;
import com.arsdigita.kernel.KernelConfig;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
@ -70,6 +68,7 @@ import javax.persistence.TypedQuery;
import javax.transaction.Transactional; import javax.transaction.Transactional;
import org.libreccm.security.PermissionChecker; import org.libreccm.security.PermissionChecker;
import org.libreccm.security.PermissionManager;
import org.librecms.contentsection.privileges.TypePrivileges; import org.librecms.contentsection.privileges.TypePrivileges;
/** /**
@ -77,48 +76,48 @@ import org.librecms.contentsection.privileges.TypePrivileges;
* *
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a> * @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/ */
@RequestScoped @RequestScoped
public class ContentItemManager { public class ContentItemManager {
private static final Logger LOGGER = LogManager.getLogger( private static final Logger LOGGER = LogManager.getLogger(
ContentItemManager.class); ContentItemManager.class);
@Inject @Inject
private EntityManager entityManager; private AssetManager assetManager;
@Inject
private ConfigurationManager confManager;
@Inject @Inject
private CategoryManager categoryManager; private CategoryManager categoryManager;
@Inject @Inject
private FolderManager folderManager; private ContentItemRepository contentItemRepo;
@Inject @Inject
private ContentSectionManager sectionManager; private ContentSectionManager sectionManager;
@Inject
private ContentItemRepository contentItemRepo;
@Inject @Inject
private ContentTypeRepository typeRepo; private ContentTypeRepository typeRepo;
@Inject @Inject
private LifecycleManager lifecycleManager; private EntityManager entityManager;
@Inject @Inject
private WorkflowManager workflowManager; private FolderManager folderManager;
@Inject @Inject
private FolderRepository folderRepo; private FolderRepository folderRepo;
@Inject @Inject
private AssetManager assetManager; private LifecycleManager lifecycleManager;
@Inject @Inject
private PermissionChecker permissionChecker; private PermissionChecker permissionChecker;
@Inject
private PermissionManager permissionManager;
@Inject
private WorkflowManager workflowManager;
/** /**
* Creates a new content item in the provided content section and folder * Creates a new content item in the provided content section and folder
* with the default workflow for the content type of the item. * with the default workflow for the content type of the item.
@ -319,9 +318,6 @@ public class ContentItemManager {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
final KernelConfig kernelConfig = confManager.findConfiguration(
KernelConfig.class);
item.setDisplayName(name); item.setDisplayName(name);
item.getName().addValue(locale, item.getName().addValue(locale,
name); name);
@ -351,6 +347,8 @@ public class ContentItemManager {
if (item.getWorkflow() != null) { if (item.getWorkflow() != null) {
workflowManager.start(item.getWorkflow()); workflowManager.start(item.getWorkflow());
} }
permissionManager.copyPermissions(folder, item, true);
return item; return item;
} }
@ -537,8 +535,8 @@ public class ContentItemManager {
source = (LocalizedString) readMethod.invoke(draftItem); source = (LocalizedString) readMethod.invoke(draftItem);
target = (LocalizedString) readMethod.invoke(copy); target = (LocalizedString) readMethod.invoke(copy);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -550,8 +548,8 @@ public class ContentItemManager {
try { try {
linkedItem = (ContentItem) readMethod.invoke(draftItem); linkedItem = (ContentItem) readMethod.invoke(draftItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -561,8 +559,8 @@ public class ContentItemManager {
try { try {
writeMethod.invoke(copy, linkedDraftItem); writeMethod.invoke(copy, linkedDraftItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
} else if (propType != null } else if (propType != null
@ -573,8 +571,8 @@ public class ContentItemManager {
source = (List<Object>) readMethod.invoke(draftItem); source = (List<Object>) readMethod.invoke(draftItem);
target = (List<Object>) readMethod.invoke(copy); target = (List<Object>) readMethod.invoke(copy);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -588,8 +586,8 @@ public class ContentItemManager {
source = (Map<Object, Object>) readMethod.invoke(draftItem); source = (Map<Object, Object>) readMethod.invoke(draftItem);
target = (Map<Object, Object>) readMethod.invoke(copy); target = (Map<Object, Object>) readMethod.invoke(copy);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -603,8 +601,8 @@ public class ContentItemManager {
source = (Set<Object>) readMethod.invoke(draftItem); source = (Set<Object>) readMethod.invoke(draftItem);
target = (Set<Object>) readMethod.invoke(copy); target = (Set<Object>) readMethod.invoke(copy);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -615,8 +613,8 @@ public class ContentItemManager {
value = readMethod.invoke(draftItem); value = readMethod.invoke(draftItem);
writeMethod.invoke(copy, value); writeMethod.invoke(copy, value);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
} }
@ -785,8 +783,8 @@ public class ContentItemManager {
sourceStr = (LocalizedString) readMethod.invoke(source); sourceStr = (LocalizedString) readMethod.invoke(source);
targetStr = (LocalizedString) readMethod.invoke(target); targetStr = (LocalizedString) readMethod.invoke(target);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new UnexpectedErrorException(ex); throw new UnexpectedErrorException(ex);
} }
@ -797,8 +795,8 @@ public class ContentItemManager {
value = readMethod.invoke(source); value = readMethod.invoke(source);
writeMethod.invoke(target, value); writeMethod.invoke(target, value);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new UnexpectedErrorException(ex); throw new UnexpectedErrorException(ex);
} }
} }
@ -922,8 +920,8 @@ public class ContentItemManager {
source = (LocalizedString) readMethod.invoke(draftItem); source = (LocalizedString) readMethod.invoke(draftItem);
target = (LocalizedString) readMethod.invoke(liveItem); target = (LocalizedString) readMethod.invoke(liveItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -934,8 +932,8 @@ public class ContentItemManager {
try { try {
linkedItem = (ContentItem) readMethod.invoke(draftItem); linkedItem = (ContentItem) readMethod.invoke(draftItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -949,8 +947,8 @@ public class ContentItemManager {
linkedDraftItem, ContentItem.class); linkedDraftItem, ContentItem.class);
writeMethod.invoke(liveItem, linkedLiveItem); writeMethod.invoke(liveItem, linkedLiveItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
} }
@ -962,8 +960,8 @@ public class ContentItemManager {
source = (List<Object>) readMethod.invoke(draftItem); source = (List<Object>) readMethod.invoke(draftItem);
target = (List<Object>) readMethod.invoke(liveItem); target = (List<Object>) readMethod.invoke(liveItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -977,8 +975,8 @@ public class ContentItemManager {
source = (Map<Object, Object>) readMethod.invoke(draftItem); source = (Map<Object, Object>) readMethod.invoke(draftItem);
target = (Map<Object, Object>) readMethod.invoke(liveItem); target = (Map<Object, Object>) readMethod.invoke(liveItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -992,8 +990,8 @@ public class ContentItemManager {
source = (Set<Object>) readMethod.invoke(draftItem); source = (Set<Object>) readMethod.invoke(draftItem);
target = (Set<Object>) readMethod.invoke(liveItem); target = (Set<Object>) readMethod.invoke(liveItem);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
@ -1004,8 +1002,8 @@ public class ContentItemManager {
value = readMethod.invoke(item); value = readMethod.invoke(item);
writeMethod.invoke(liveItem, value); writeMethod.invoke(liveItem, value);
} catch (IllegalAccessException } catch (IllegalAccessException
| IllegalArgumentException | IllegalArgumentException
| InvocationTargetException ex) { | InvocationTargetException ex) {
throw new RuntimeException(ex); throw new RuntimeException(ex);
} }
} }

View File

@ -410,7 +410,7 @@ public class ContentItemRepository
@Transactional(Transactional.TxType.REQUIRED) @Transactional(Transactional.TxType.REQUIRED)
public Optional<ContentItem> findByPath(final String path) { public Optional<ContentItem> findByPath(final String path) {
//The last token is the name of the item itself. Remove this part an get //The last token is the name of the item itself. Remove this part and get
//the folder containing the item using the FolderRepository. //the folder containing the item using the FolderRepository.
final String normalizedPath = PathUtil.normalizePath(path); final String normalizedPath = PathUtil.normalizePath(path);
final int lastTokenStart = normalizedPath.lastIndexOf('/'); final int lastTokenStart = normalizedPath.lastIndexOf('/');

View File

@ -34,16 +34,15 @@ public final class PathUtil {
* *
* The method does the following: * The method does the following:
* <ul> * <ul>
* <li>Replace all "<code>.</code>" in the path with a slash.</li>
* <li>If the first character is a slash remove the character.</li> * <li>If the first character is a slash remove the character.</li>
* <li>If the last character is a slash remove the character.</li> * <li>If the last character is a slash remove the character.</li>
* </ul> * </ul>
* *
* @param path * @param path The path to normalise.
* @return * @return The normalised path
*/ */
protected static final String normalizePath(final String path) { protected static final String normalizePath(final String path) {
String normalizedPath = path.replace('.', '/'); String normalizedPath = path;
if (normalizedPath.charAt(0) == '/') { if (normalizedPath.charAt(0) == '/') {
normalizedPath = normalizedPath.substring(1); normalizedPath = normalizedPath.substring(1);
} }

View File

@ -37,6 +37,7 @@ public class ContentSections extends Application{
final Set<Class<?>> classes = new HashSet<>(); final Set<Class<?>> classes = new HashSet<>();
classes.add(Assets.class); classes.add(Assets.class);
classes.add(Images.class);
return classes; return classes;
} }

View File

@ -0,0 +1,110 @@
/*
* Copyright (C) 2017 LibreCCM Foundation.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA
*/
package org.librecms.contentsection.rs;
import org.librecms.assets.Image;
import org.librecms.contentsection.Asset;
import org.librecms.contentsection.AssetRepository;
import org.librecms.contentsection.ContentSection;
import org.librecms.contentsection.ContentSectionRepository;
import java.util.Optional;
import javax.enterprise.context.RequestScoped;
import javax.inject.Inject;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.core.Response;
/**
*
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
*/
@RequestScoped
@Path("/{content-section}/images/")
public class Images {
@Inject
private ContentSectionRepository sectionRepo;
@Inject
private AssetRepository assetRepo;
@GET
@Path("/{path:.+}")
public Response getImage(
@PathParam("content-section") final String sectionName,
@PathParam("path") final String path) {
final Optional<ContentSection> section = sectionRepo
.findByLabel(sectionName);
if (!section.isPresent()) {
return Response
.status(Response.Status.NOT_FOUND)
.entity(String.format("No content section \"%s\" available.",
sectionName))
.build();
}
final Optional<Asset> asset = assetRepo.findByPath(section.get(),
path);
if (asset.isPresent()) {
if (asset.get() instanceof Image) {
final Image image = (Image) asset.get();
final byte[] data = image.getData();
return Response
.ok(String.format(
"Requested image \"%s\" in content section \"%s\"",
path,
section.get().getLabel()),
"text/plain")
.build();
} else {
return Response
.status(Response.Status.NOT_FOUND)
.entity(String
.format("The asset found at the requested path \"%s\" "
+ "is not an image.",
path))
.build();
}
} else {
return Response
.status(Response.Status.NOT_FOUND)
.entity(String
.format("The requested image \"%s\" does not exist.",
path))
.build();
}
// final Response.ResponseBuilder builder = Response
// .ok(String.format(
// "Requested image \"%s\" from folder \"%s\" in content section \"%s\"",
// imageName,
// folderPath,
// section.get().getLabel()),
// "text/plain");
//
// return builder.build();
}
}

View File

@ -221,11 +221,14 @@ public class ContentItemManagerTest {
value = "datasets/org/librecms/contentsection/" value = "datasets/org/librecms/contentsection/"
+ "ContentItemManagerTest/after-create-contentitem.xml", + "ContentItemManagerTest/after-create-contentitem.xml",
excludeColumns = {"categorization_id", excludeColumns = {"categorization_id",
"creation_date",
"id", "id",
"inherited_from_id",
"item_uuid", "item_uuid",
"lifecycle_id", "lifecycle_id",
"object_id", "object_id",
"object_order", "object_order",
"permission_id",
"phase_id", "phase_id",
"rev", "rev",
"task_assignment_id", "task_assignment_id",
@ -391,11 +394,14 @@ public class ContentItemManagerTest {
+ "ContentItemManagerTest/" + "ContentItemManagerTest/"
+ "after-create-contentitem-with-workflow.xml", + "after-create-contentitem-with-workflow.xml",
excludeColumns = {"categorization_id", excludeColumns = {"categorization_id",
"creation_date",
"id", "id",
"inherited_from_id",
"item_uuid", "item_uuid",
"lifecycle_id", "lifecycle_id",
"object_id", "object_id",
"object_order", "object_order",
"permission_id",
"phase_id", "phase_id",
"rev", "rev",
"task_id", "task_id",

View File

@ -749,341 +749,614 @@
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4120" <ccm_core.permissions permission_id="-4120"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4130" <ccm_core.permissions permission_id="-4130"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4140" <ccm_core.permissions permission_id="-4140"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4150" <ccm_core.permissions permission_id="-4150"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4210" <ccm_core.permissions permission_id="-4210"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4220" <ccm_core.permissions permission_id="-4220"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4230" <ccm_core.permissions permission_id="-4230"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4240" <ccm_core.permissions permission_id="-4240"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4250" <ccm_core.permissions permission_id="-4250"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4260" <ccm_core.permissions permission_id="-4260"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4270" <ccm_core.permissions permission_id="-4270"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4310" <ccm_core.permissions permission_id="-4310"
granted_privilege="administer_roles" granted_privilege="administer_roles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4320" <ccm_core.permissions permission_id="-4320"
granted_privilege="administer_workflow" granted_privilege="administer_workflow"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4330" <ccm_core.permissions permission_id="-4330"
granted_privilege="administer_lifecyles" granted_privilege="administer_lifecyles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4340" <ccm_core.permissions permission_id="-4340"
granted_privilege="administer_categories" granted_privilege="administer_categories"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4350" <ccm_core.permissions permission_id="-4350"
granted_privilege="administer_content_types" granted_privilege="administer_content_types"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4360" <ccm_core.permissions permission_id="-4360"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4370" <ccm_core.permissions permission_id="-4370"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4380" <ccm_core.permissions permission_id="-4380"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4390" <ccm_core.permissions permission_id="-4390"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4400" <ccm_core.permissions permission_id="-4400"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4410" <ccm_core.permissions permission_id="-4410"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4420" <ccm_core.permissions permission_id="-4420"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4430" <ccm_core.permissions permission_id="-4430"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4510" <ccm_core.permissions permission_id="-4510"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4520" <ccm_core.permissions permission_id="-4520"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4530" <ccm_core.permissions permission_id="-4530"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4540" <ccm_core.permissions permission_id="-4540"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4550" <ccm_core.permissions permission_id="-4550"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4560" <ccm_core.permissions permission_id="-4560"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4570" <ccm_core.permissions permission_id="-4570"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4580" <ccm_core.permissions permission_id="-4580"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4610" <ccm_core.permissions permission_id="-4610"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3600" grantee_id="-3600"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4710" <ccm_core.permissions permission_id="-4710"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4720" <ccm_core.permissions permission_id="-4720"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4730" <ccm_core.permissions permission_id="-4730"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4740" <ccm_core.permissions permission_id="-4740"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4750" <ccm_core.permissions permission_id="-4750"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4810" <ccm_core.permissions permission_id="-4810"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4820" <ccm_core.permissions permission_id="-4820"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4830" <ccm_core.permissions permission_id="-4830"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4840" <ccm_core.permissions permission_id="-4840"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4850" <ccm_core.permissions permission_id="-4850"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4860" <ccm_core.permissions permission_id="-4860"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4870" <ccm_core.permissions permission_id="-4870"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4910" <ccm_core.permissions permission_id="-4910"
granted_privilege="administer_roles" granted_privilege="administer_roles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4920" <ccm_core.permissions permission_id="-4920"
granted_privilege="administer_workflow" granted_privilege="administer_workflow"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4930" <ccm_core.permissions permission_id="-4930"
granted_privilege="administer_lifecyles" granted_privilege="administer_lifecyles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4940" <ccm_core.permissions permission_id="-4940"
granted_privilege="administer_categories" granted_privilege="administer_categories"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4950" <ccm_core.permissions permission_id="-4950"
granted_privilege="administer_content_types" granted_privilege="administer_content_types"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4960" <ccm_core.permissions permission_id="-4960"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4970" <ccm_core.permissions permission_id="-4970"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4980" <ccm_core.permissions permission_id="-4980"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4990" <ccm_core.permissions permission_id="-4990"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5000" <ccm_core.permissions permission_id="-5000"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5010" <ccm_core.permissions permission_id="-5010"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5020" <ccm_core.permissions permission_id="-5020"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5030" <ccm_core.permissions permission_id="-5030"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5110" <ccm_core.permissions permission_id="-5110"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5120" <ccm_core.permissions permission_id="-5120"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5130" <ccm_core.permissions permission_id="-5130"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5140" <ccm_core.permissions permission_id="-5140"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5150" <ccm_core.permissions permission_id="-5150"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5160" <ccm_core.permissions permission_id="-5160"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5170" <ccm_core.permissions permission_id="-5170"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5180" <ccm_core.permissions permission_id="-5180"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5210" <ccm_core.permissions permission_id="-5210"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3600" grantee_id="-3600"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-411010"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-412020"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-413030"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-414040"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-415050"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-421010"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-422020"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-423030"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-424040"
granted_privilege="approve_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-425050"
granted_privilege="delete_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-426060"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-427070"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-436060"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-437070"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-438080"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-439090"
granted_privilege="approve_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-440000"
granted_privilege="publish_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-441010"
granted_privilege="delete_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-442020"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-443030"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-451010"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-452020"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-453030"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-454040"
granted_privilege="approve_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-455050"
granted_privilege="publish_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-456060"
granted_privilege="delete_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-457070"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-458080"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-461010"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3600"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
</dataset> </dataset>

View File

@ -765,341 +765,612 @@
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4120" <ccm_core.permissions permission_id="-4120"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4130" <ccm_core.permissions permission_id="-4130"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4140" <ccm_core.permissions permission_id="-4140"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4150" <ccm_core.permissions permission_id="-4150"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4210" <ccm_core.permissions permission_id="-4210"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4220" <ccm_core.permissions permission_id="-4220"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4230" <ccm_core.permissions permission_id="-4230"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4240" <ccm_core.permissions permission_id="-4240"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4250" <ccm_core.permissions permission_id="-4250"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4260" <ccm_core.permissions permission_id="-4260"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4270" <ccm_core.permissions permission_id="-4270"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4310" <ccm_core.permissions permission_id="-4310"
granted_privilege="administer_roles" granted_privilege="administer_roles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4320" <ccm_core.permissions permission_id="-4320"
granted_privilege="administer_workflow" granted_privilege="administer_workflow"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4330" <ccm_core.permissions permission_id="-4330"
granted_privilege="administer_lifecyles" granted_privilege="administer_lifecyles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4340" <ccm_core.permissions permission_id="-4340"
granted_privilege="administer_categories" granted_privilege="administer_categories"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4350" <ccm_core.permissions permission_id="-4350"
granted_privilege="administer_content_types" granted_privilege="administer_content_types"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4360" <ccm_core.permissions permission_id="-4360"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4370" <ccm_core.permissions permission_id="-4370"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4380" <ccm_core.permissions permission_id="-4380"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4390" <ccm_core.permissions permission_id="-4390"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4400" <ccm_core.permissions permission_id="-4400"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4410" <ccm_core.permissions permission_id="-4410"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4420" <ccm_core.permissions permission_id="-4420"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4430" <ccm_core.permissions permission_id="-4430"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4510" <ccm_core.permissions permission_id="-4510"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4520" <ccm_core.permissions permission_id="-4520"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4530" <ccm_core.permissions permission_id="-4530"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4540" <ccm_core.permissions permission_id="-4540"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4550" <ccm_core.permissions permission_id="-4550"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4560" <ccm_core.permissions permission_id="-4560"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4570" <ccm_core.permissions permission_id="-4570"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4580" <ccm_core.permissions permission_id="-4580"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4610" <ccm_core.permissions permission_id="-4610"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3600" grantee_id="-3600"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4710" <ccm_core.permissions permission_id="-4710"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4720" <ccm_core.permissions permission_id="-4720"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4730" <ccm_core.permissions permission_id="-4730"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4740" <ccm_core.permissions permission_id="-4740"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4750" <ccm_core.permissions permission_id="-4750"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4810" <ccm_core.permissions permission_id="-4810"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4820" <ccm_core.permissions permission_id="-4820"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4830" <ccm_core.permissions permission_id="-4830"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4840" <ccm_core.permissions permission_id="-4840"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4850" <ccm_core.permissions permission_id="-4850"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4860" <ccm_core.permissions permission_id="-4860"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4870" <ccm_core.permissions permission_id="-4870"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4910" <ccm_core.permissions permission_id="-4910"
granted_privilege="administer_roles" granted_privilege="administer_roles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4920" <ccm_core.permissions permission_id="-4920"
granted_privilege="administer_workflow" granted_privilege="administer_workflow"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4930" <ccm_core.permissions permission_id="-4930"
granted_privilege="administer_lifecyles" granted_privilege="administer_lifecyles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4940" <ccm_core.permissions permission_id="-4940"
granted_privilege="administer_categories" granted_privilege="administer_categories"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4950" <ccm_core.permissions permission_id="-4950"
granted_privilege="administer_content_types" granted_privilege="administer_content_types"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4960" <ccm_core.permissions permission_id="-4960"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4970" <ccm_core.permissions permission_id="-4970"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4980" <ccm_core.permissions permission_id="-4980"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4990" <ccm_core.permissions permission_id="-4990"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5000" <ccm_core.permissions permission_id="-5000"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5010" <ccm_core.permissions permission_id="-5010"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5020" <ccm_core.permissions permission_id="-5020"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5030" <ccm_core.permissions permission_id="-5030"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5110" <ccm_core.permissions permission_id="-5110"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5120" <ccm_core.permissions permission_id="-5120"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5130" <ccm_core.permissions permission_id="-5130"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5140" <ccm_core.permissions permission_id="-5140"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5150" <ccm_core.permissions permission_id="-5150"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5160" <ccm_core.permissions permission_id="-5160"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5170" <ccm_core.permissions permission_id="-5170"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5180" <ccm_core.permissions permission_id="-5180"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5210" <ccm_core.permissions permission_id="-5210"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3600" grantee_id="-3600"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-411010"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-412020"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-413030"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-414040"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-415050"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3200"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-421010"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-422020"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-423030"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-424040"
granted_privilege="approve_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-425050"
granted_privilege="delete_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-426060"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-427070"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3300"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-436060"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-437070"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-438080"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-439090"
granted_privilege="approve_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-440000"
granted_privilege="publish_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-441010"
granted_privilege="delete_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-442020"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-443030"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3400"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-451010"
granted_privilege="categorize_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-452020"
granted_privilege="create_new_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-453030"
granted_privilege="edit_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-454040"
granted_privilege="approve_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-455050"
granted_privilege="publish_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-456060"
granted_privilege="delete_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-457070"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-458080"
granted_privilege="preview_items"
object_id="-12100"
grantee_id="-3500"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
<ccm_core.permissions permission_id="-461010"
granted_privilege="view_published_items"
object_id="-12100"
grantee_id="-3600"
creation_date="2016-07-15"
inherited="true"
inherited_from_id="-2100" />
</dataset> </dataset>

View File

@ -686,341 +686,409 @@
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4120" <ccm_core.permissions permission_id="-4120"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4130" <ccm_core.permissions permission_id="-4130"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4140" <ccm_core.permissions permission_id="-4140"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4150" <ccm_core.permissions permission_id="-4150"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4210" <ccm_core.permissions permission_id="-4210"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4220" <ccm_core.permissions permission_id="-4220"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4230" <ccm_core.permissions permission_id="-4230"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4240" <ccm_core.permissions permission_id="-4240"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4250" <ccm_core.permissions permission_id="-4250"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4260" <ccm_core.permissions permission_id="-4260"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4270" <ccm_core.permissions permission_id="-4270"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4310" <ccm_core.permissions permission_id="-4310"
granted_privilege="administer_roles" granted_privilege="administer_roles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4320" <ccm_core.permissions permission_id="-4320"
granted_privilege="administer_workflow" granted_privilege="administer_workflow"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4330" <ccm_core.permissions permission_id="-4330"
granted_privilege="administer_lifecyles" granted_privilege="administer_lifecyles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4340" <ccm_core.permissions permission_id="-4340"
granted_privilege="administer_categories" granted_privilege="administer_categories"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4350" <ccm_core.permissions permission_id="-4350"
granted_privilege="administer_content_types" granted_privilege="administer_content_types"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4360" <ccm_core.permissions permission_id="-4360"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4370" <ccm_core.permissions permission_id="-4370"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4380" <ccm_core.permissions permission_id="-4380"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4390" <ccm_core.permissions permission_id="-4390"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4400" <ccm_core.permissions permission_id="-4400"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4410" <ccm_core.permissions permission_id="-4410"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4420" <ccm_core.permissions permission_id="-4420"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4430" <ccm_core.permissions permission_id="-4430"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4510" <ccm_core.permissions permission_id="-4510"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4520" <ccm_core.permissions permission_id="-4520"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4530" <ccm_core.permissions permission_id="-4530"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4540" <ccm_core.permissions permission_id="-4540"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4550" <ccm_core.permissions permission_id="-4550"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4560" <ccm_core.permissions permission_id="-4560"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4570" <ccm_core.permissions permission_id="-4570"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4580" <ccm_core.permissions permission_id="-4580"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2100" object_id="-2100"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4610" <ccm_core.permissions permission_id="-4610"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2100" object_id="-2100"
grantee_id="-3600" grantee_id="-3600"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4710" <ccm_core.permissions permission_id="-4710"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4720" <ccm_core.permissions permission_id="-4720"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4730" <ccm_core.permissions permission_id="-4730"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4740" <ccm_core.permissions permission_id="-4740"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4750" <ccm_core.permissions permission_id="-4750"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3200" grantee_id="-3200"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4810" <ccm_core.permissions permission_id="-4810"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4820" <ccm_core.permissions permission_id="-4820"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4830" <ccm_core.permissions permission_id="-4830"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4840" <ccm_core.permissions permission_id="-4840"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4850" <ccm_core.permissions permission_id="-4850"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4860" <ccm_core.permissions permission_id="-4860"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4870" <ccm_core.permissions permission_id="-4870"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3300" grantee_id="-3300"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4910" <ccm_core.permissions permission_id="-4910"
granted_privilege="administer_roles" granted_privilege="administer_roles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4920" <ccm_core.permissions permission_id="-4920"
granted_privilege="administer_workflow" granted_privilege="administer_workflow"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4930" <ccm_core.permissions permission_id="-4930"
granted_privilege="administer_lifecyles" granted_privilege="administer_lifecyles"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4940" <ccm_core.permissions permission_id="-4940"
granted_privilege="administer_categories" granted_privilege="administer_categories"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4950" <ccm_core.permissions permission_id="-4950"
granted_privilege="administer_content_types" granted_privilege="administer_content_types"
object_id="-1100" object_id="-1100"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4960" <ccm_core.permissions permission_id="-4960"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4970" <ccm_core.permissions permission_id="-4970"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4980" <ccm_core.permissions permission_id="-4980"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-4990" <ccm_core.permissions permission_id="-4990"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5000" <ccm_core.permissions permission_id="-5000"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5010" <ccm_core.permissions permission_id="-5010"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5020" <ccm_core.permissions permission_id="-5020"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5030" <ccm_core.permissions permission_id="-5030"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3400" grantee_id="-3400"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5110" <ccm_core.permissions permission_id="-5110"
granted_privilege="categorize_items" granted_privilege="categorize_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5120" <ccm_core.permissions permission_id="-5120"
granted_privilege="create_new_items" granted_privilege="create_new_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5130" <ccm_core.permissions permission_id="-5130"
granted_privilege="edit_items" granted_privilege="edit_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5140" <ccm_core.permissions permission_id="-5140"
granted_privilege="approve_items" granted_privilege="approve_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5150" <ccm_core.permissions permission_id="-5150"
granted_privilege="publish_items" granted_privilege="publish_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5160" <ccm_core.permissions permission_id="-5160"
granted_privilege="delete_items" granted_privilege="delete_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5170" <ccm_core.permissions permission_id="-5170"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5180" <ccm_core.permissions permission_id="-5180"
granted_privilege="preview_items" granted_privilege="preview_items"
object_id="-2300" object_id="-2300"
grantee_id="-3500" grantee_id="-3500"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
<ccm_core.permissions permission_id="-5210" <ccm_core.permissions permission_id="-5210"
granted_privilege="view_published_items" granted_privilege="view_published_items"
object_id="-2300" object_id="-2300"
grantee_id="-3600" grantee_id="-3600"
creation_date="2016-07-15"/> creation_date="2016-07-15"
inherited="false" />
</dataset> </dataset>

View File

@ -129,14 +129,18 @@ public class PermissionManager {
* @param grantee The role to which the privilege is granted. * @param grantee The role to which the privilege is granted.
* @param object The object on which the privilege is granted. * @param object The object on which the privilege is granted.
* *
* @return The newly granted permission. If there is also none inherited
* permission granting the provided {@code privilege} on the
* provided {@code object} the return value is {@code null}.
*
* @see RecursivePermissions * @see RecursivePermissions
*/ */
@AuthorizationRequired @AuthorizationRequired
@RequiresPrivilege(CoreConstants.PRIVILEGE_ADMIN) @RequiresPrivilege(CoreConstants.PRIVILEGE_ADMIN)
@Transactional(Transactional.TxType.REQUIRED) @Transactional(Transactional.TxType.REQUIRED)
public void grantPrivilege(final String privilege, public Permission grantPrivilege(final String privilege,
final Role grantee, final Role grantee,
final CcmObject object) { final CcmObject object) {
if (privilege == null || privilege.isEmpty()) { if (privilege == null || privilege.isEmpty()) {
throw new IllegalArgumentException( throw new IllegalArgumentException(
"Can't grant a permission without a privilege."); "Can't grant a permission without a privilege.");
@ -156,7 +160,9 @@ public class PermissionManager {
revokePrivilege(privilege, grantee, object); revokePrivilege(privilege, grantee, object);
} }
if (!existsPermission(privilege, grantee, object)) { if (existsPermission(privilege, grantee, object)) {
return null;
} else {
final Permission permission = new Permission(); final Permission permission = new Permission();
permission.setGrantee(grantee); permission.setGrantee(grantee);
permission.setGrantedPrivilege(privilege); permission.setGrantedPrivilege(privilege);
@ -166,6 +172,8 @@ public class PermissionManager {
entityManager.persist(permission); entityManager.persist(permission);
grantRecursive(privilege, grantee, object, object.getClass(), object); grantRecursive(privilege, grantee, object, object.getClass(), object);
return permission;
} }
} }
@ -485,14 +493,35 @@ public class PermissionManager {
* permissions. * permissions.
* *
* *
* @param source * @param source The source object from which the permissions are copied.
* @param target * @param target The target object to which the permissions are copied.
*/ */
@AuthorizationRequired @AuthorizationRequired
@RequiresPrivilege(CoreConstants.PRIVILEGE_ADMIN) @RequiresPrivilege(CoreConstants.PRIVILEGE_ADMIN)
@Transactional(Transactional.TxType.REQUIRED) @Transactional(Transactional.TxType.REQUIRED)
public void copyPermissions(final CcmObject source, public void copyPermissions(final CcmObject source,
final CcmObject target) { final CcmObject target) {
copyPermissions(source, target, false);
}
/**
* Copy the permissions from on {@link CcmObject} to another. The
* permissions granted on the {@code target} object will not be removed.
* Instead the permissions from {@code source} object are added the the
* permissions. This variant is should only be used to copy permissions from
* a parent object (like a category) to a new or newly assigned object.
*
* @param source The source object from which the permissions are copied.
* @param target The target object to which the permissions are copied.
* @param inherited Value for the {@link Permission#inherited} field of the
* copied permission.
*/
@AuthorizationRequired
@RequiresPrivilege(CoreConstants.PRIVILEGE_ADMIN)
@Transactional(Transactional.TxType.REQUIRED)
public void copyPermissions(final CcmObject source,
final CcmObject target,
final boolean inherited) {
if (source == null) { if (source == null) {
throw new IllegalArgumentException( throw new IllegalArgumentException(
"Can't copy permissions from source NULL."); "Can't copy permissions from source NULL.");
@ -509,9 +538,15 @@ public class PermissionManager {
final List<Permission> result = query.getResultList(); final List<Permission> result = query.getResultList();
for (final Permission permission : result) { for (final Permission permission : result) {
grantPrivilege(permission.getGrantedPrivilege(), final Permission granted = grantPrivilege(
permission.getGrantee(), permission.getGrantedPrivilege(),
target); permission.getGrantee(),
target);
granted.setInherited(inherited);
if (inherited) {
granted.setInheritedFrom(source);
}
entityManager.merge(granted);
} }
} }