Adding UI extensibility
[aai/sparky-be.git] / src / main / java / org / onap / aai / sparky / editattributes / UserAuthorizationReader.java
1 /**
2  * ============LICENSE_START=======================================================
3  * org.onap.aai
4  * ================================================================================
5  * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6  * Copyright © 2017 Amdocs
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *       http://www.apache.org/licenses/LICENSE-2.0
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,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END=========================================================
20  *
21  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
22  */
23 package org.onap.aai.sparky.editattributes;
24
25 import java.io.File;
26 import java.io.IOException;
27 import java.nio.file.Files;
28 import java.util.ArrayList;
29 import java.util.List;
30 import java.util.stream.Collectors;
31 import java.util.stream.Stream;
32
33 /**
34  * Reads user IDs from a file. Each line in the user authorization file should contain a single user
35  * ID. For example,
36  *
37  * <pre>
38  * user1
39  * user2
40  * </pre>
41  */
42 public class UserAuthorizationReader {
43
44   private File userAuthorizationFile;
45
46   /**
47    * Set the user authorization file.
48    *
49    * @param file a user authorization file
50    */
51   public UserAuthorizationReader(File file) {
52     this.userAuthorizationFile = file;
53   }
54
55   /**
56    * Gets user IDs from a file.
57    *
58    * @return a list of user IDs
59    * @throws IOException if there is a problem reading the user configuration file
60    */
61   public List<String> getUsers() throws IOException {
62     List<String> userList = new ArrayList<>();
63     try (Stream<String> stream = Files.lines(getUserAuthorizationFile().toPath())) {
64       userList.addAll(stream.map(String::trim).collect(Collectors.toList()));
65     }
66     return userList;
67   }
68
69   // Getters and setters
70   public File getUserAuthorizationFile() {
71     return userAuthorizationFile;
72   }
73
74   public void setUserAuthorizationFile(File file) {
75     this.userAuthorizationFile = file;
76   }
77 }