View Javadoc
1   /*
2    * Licensed to The Apereo Foundation under one or more contributor license
3    * agreements. See the NOTICE file distributed with this work for additional
4    * information regarding copyright ownership.
5    *
6    *
7    * The Apereo Foundation licenses this file to you under the Educational
8    * Community License, Version 2.0 (the "License"); you may not use this file
9    * except in compliance with the License. You may obtain a copy of the License
10   * at:
11   *
12   *   http://opensource.org/licenses/ecl2.txt
13   *
14   * Unless required by applicable law or agreed to in writing, software
15   * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
16   * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
17   * License for the specific language governing permissions and limitations under
18   * the License.
19   *
20   */
21  
22  package org.opencastproject.security.api;
23  
24  import java.util.ArrayList;
25  import java.util.Collection;
26  import java.util.List;
27  
28  import javax.xml.bind.annotation.XmlAccessType;
29  import javax.xml.bind.annotation.XmlAccessorType;
30  import javax.xml.bind.annotation.XmlElement;
31  import javax.xml.bind.annotation.XmlRootElement;
32  import javax.xml.bind.annotation.XmlType;
33  
34  /**
35   * A wrapper for group collections.
36   */
37  @XmlAccessorType(XmlAccessType.NONE)
38  @XmlType(name = "groups", namespace = "http://org.opencastproject.security")
39  @XmlRootElement(name = "groups", namespace = "http://org.opencastproject.security")
40  public class JaxbGroupList {
41  
42    /** A list of groups. */
43    @XmlElement(name = "group")
44    protected List<JaxbGroup> groups = new ArrayList<JaxbGroup>();
45  
46    public JaxbGroupList() {
47    }
48  
49    public JaxbGroupList(JaxbGroup group) {
50      groups.add(group);
51    }
52  
53    public JaxbGroupList(Collection<JaxbGroup> groups) {
54      for (JaxbGroup group : groups)
55        groups.add(group);
56    }
57  
58    /**
59     * @return the groups
60     */
61    public List<JaxbGroup> getGroups() {
62      return groups;
63    }
64  
65    /**
66     * @param roles
67     *          the roles to set
68     */
69    public void setRoles(List<JaxbGroup> roles) {
70      this.groups = roles;
71    }
72  
73    public void add(Group group) {
74      if (group instanceof JaxbGroup) {
75        groups.add((JaxbGroup) group);
76      } else {
77        groups.add(JaxbGroup.fromGroup(group));
78      }
79    }
80  
81  }