2013-02-07 15:19:47 +01:00
|
|
|
/**
|
|
|
|
*
|
2014-02-17 18:57:38 +01:00
|
|
|
* Copyright the original author or authors
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
2013-02-07 15:19:47 +01:00
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2014-02-17 23:58:40 +01:00
|
|
|
package org.jivesoftware.smackx.privacy;
|
|
|
|
|
2014-02-15 22:35:38 +01:00
|
|
|
import org.jivesoftware.smackx.privacy.packet.PrivacyItem;
|
|
|
|
|
2014-02-17 23:58:40 +01:00
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A privacy list represents a list of contacts that is a read only class used to represent a set of allowed or blocked communications.
|
|
|
|
* Basically it can:<ul>
|
|
|
|
*
|
|
|
|
* <li>Handle many {@link org.jivesoftware.smackx.privacy.packet.PrivacyItem}.</li>
|
|
|
|
* <li>Answer if it is the default list.</li>
|
|
|
|
* <li>Answer if it is the active list.</li>
|
|
|
|
* </ul>
|
|
|
|
*
|
|
|
|
* {@link PrivacyItem Privacy Items} can handle different kind of blocking communications based on JID, group,
|
|
|
|
* subscription type or globally.
|
|
|
|
*
|
|
|
|
* @author Francisco Vives
|
|
|
|
*/
|
|
|
|
public class PrivacyList {
|
|
|
|
|
|
|
|
/** Holds if it is an active list or not **/
|
2014-03-10 14:45:17 +01:00
|
|
|
private final boolean isActiveList;
|
2014-02-17 23:58:40 +01:00
|
|
|
/** Holds if it is an default list or not **/
|
2014-03-10 14:45:17 +01:00
|
|
|
private final boolean isDefaultList;
|
2014-02-17 23:58:40 +01:00
|
|
|
/** Holds the list name used to print **/
|
2014-03-10 14:45:17 +01:00
|
|
|
private final String listName;
|
2014-03-10 18:31:45 +01:00
|
|
|
/** Holds the list of {@link PrivacyItem} */
|
2014-03-10 14:45:17 +01:00
|
|
|
private final List<PrivacyItem> items;
|
2015-03-17 11:33:02 +01:00
|
|
|
|
2014-02-17 23:58:40 +01:00
|
|
|
protected PrivacyList(boolean isActiveList, boolean isDefaultList,
|
|
|
|
String listName, List<PrivacyItem> privacyItems) {
|
|
|
|
super();
|
|
|
|
this.isActiveList = isActiveList;
|
|
|
|
this.isDefaultList = isDefaultList;
|
|
|
|
this.listName = listName;
|
|
|
|
this.items = privacyItems;
|
|
|
|
}
|
|
|
|
|
2014-03-10 14:45:17 +01:00
|
|
|
public String getName() {
|
|
|
|
return listName;
|
|
|
|
}
|
|
|
|
|
2014-02-17 23:58:40 +01:00
|
|
|
public boolean isActiveList() {
|
|
|
|
return isActiveList;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isDefaultList() {
|
|
|
|
return isDefaultList;
|
|
|
|
}
|
|
|
|
|
|
|
|
public List<PrivacyItem> getItems() {
|
|
|
|
return items;
|
|
|
|
}
|
|
|
|
|
2015-01-07 19:35:11 +01:00
|
|
|
@Override
|
|
|
|
public String toString() {
|
|
|
|
return "Privacy List: " + listName + "(active:" + isActiveList + ", default:" + isDefaultList + ")";
|
|
|
|
}
|
2014-02-17 23:58:40 +01:00
|
|
|
}
|