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    /**
60     * @return the groups
61     */
62    public List<JaxbGroup> getGroups() {
63      return groups;
64    }
65  
66    /**
67     * @param roles
68     *          the roles to set
69     */
70    public void setRoles(List<JaxbGroup> roles) {
71      this.groups = roles;
72    }
73  
74    public void add(Group group) {
75      if (group instanceof JaxbGroup) {
76        groups.add((JaxbGroup) group);
77      } else {
78        groups.add(JaxbGroup.fromGroup(group));
79      }
80    }
81  
82  }