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.authorization.xacml.manager.api;
23  
24  import org.opencastproject.security.api.AccessControlList;
25  import org.opencastproject.util.NotFoundException;
26  
27  import java.util.List;
28  import java.util.Optional;
29  
30  /**
31   * ACL service API for managing ACLs.
32   */
33  public interface AclService {
34  
35    /**
36     * Return all ACLs of this organization.
37     */
38    List<ManagedAcl> getAcls();
39  
40    /**
41     * Return an ACL of an organization by its ID.
42     *
43     * @return <code>some</code> if the ACL could be found, <code>none</code> if the ACL with the given ID does not exist.
44     */
45    Optional<ManagedAcl> getAcl(long id);
46  
47    /**
48     * Update an existing ACL.
49     *
50     * @return true on a successful update, false if no ACL exists with the given ID.
51     */
52    boolean updateAcl(ManagedAcl acl);
53  
54    /**
55     * Create a new ACL.
56     *
57     * @return <code>some</code> if the new ACL could be created successfully, <code>none</code> if an ACL with the same
58     *         name already exists
59     */
60    Optional<ManagedAcl> createAcl(AccessControlList acl, String name);
61  
62    /**
63     * Delete an ACL by its ID.
64     *
65     * @return <code>true</code> if the ACL existed and could be deleted successfully, <code>false</code> if the ACL can't
66     *         be deleted because it still has active references on it.
67     * @throws NotFoundException
68     *           if the managed acl could not be found
69     * @throws AclServiceException
70     *           if exception occurred
71     */
72    boolean deleteAcl(long id) throws AclServiceException, NotFoundException;
73  }