/**
* Licensed to Apereo under one or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information regarding copyright ownership. Apereo
* licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use
* this file except in compliance with the License. You may obtain a copy of the License at the
* following location:
*
* <p>http://www.apache.org/licenses/LICENSE-2.0
*
* <p>Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apereo.portal.layout.dlm.providers;
import java.util.List;
import javax.persistence.Cacheable;
import javax.persistence.Column;
import javax.persistence.Entity;
import org.apereo.portal.fragment.subscribe.IUserFragmentSubscription;
import org.apereo.portal.fragment.subscribe.dao.IUserFragmentSubscriptionDao;
import org.apereo.portal.layout.dlm.Evaluator;
import org.apereo.portal.layout.dlm.EvaluatorFactory;
import org.apereo.portal.layout.dlm.FragmentDefinition;
import org.apereo.portal.security.IPerson;
import org.apereo.portal.spring.locator.UserFragmentSubscriptionDaoLocator;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.QName;
import org.hibernate.annotations.Cache;
import org.hibernate.annotations.CacheConcurrencyStrategy;
/**
* SubscribedTabEvaluator is a DLM evaluator that determines if a given fragment is in the specified
* IPerson's fragment subscription list. This evaluator also performs a real-time permissions lookup
* to ensure that the user is still permissioned to be include the fragment.
*
*/
@Entity
@Cacheable
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public class SubscribedTabEvaluator extends Evaluator {
@Column(name = "OWNER_ID")
private final String ownerId;
@SuppressWarnings("unused")
private SubscribedTabEvaluator() {
this.ownerId = null;
}
/**
* Construct a new SubscribedTabEvaluator for the specified fragment owner.
*
* @param ownerId
*/
public SubscribedTabEvaluator(String ownerId) {
this.ownerId = ownerId;
}
@Override
public Class<? extends EvaluatorFactory> getFactoryClass() {
return SubscribedTabEvaluatorFactory.class;
}
@Override
public boolean isApplicable(IPerson person) {
IUserFragmentSubscriptionDao userFragmentInfoDao =
UserFragmentSubscriptionDaoLocator.getUserIdentityStore();
// get the list of current fragment subscriptions for this person
List<IUserFragmentSubscription> fragments = userFragmentInfoDao.getUserFragmentInfo(person);
// iterate through the subscription list to determine if the
// specified person is actively subscribed to the fragment associated
// with this evaluator instance
for (IUserFragmentSubscription fragment : fragments) {
if (fragment.isActive() && fragment.getFragmentOwner().equals(ownerId)) {
return true;
}
}
return false;
}
@Override
public void toElement(Element parent) {
// Assertions.
if (parent == null) {
String msg = "Argument 'parent' cannot be null.";
throw new IllegalArgumentException(msg);
}
Element rslt = null;
QName q = new QName("audience", FragmentDefinition.NAMESPACE);
rslt = DocumentHelper.createElement(q);
rslt.addAttribute("evaluatorFactory", this.getFactoryClass().getName());
parent.add(rslt);
}
@Override
public String getSummary() {
return "(OPT-IN USERS)";
}
}