2 * Copyright (c) 2015 Huawei, Inc. and others. All rights reserved.
\r
4 * This program and the accompanying materials are made available under the
\r
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
\r
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
\r
8 package org.opendaylight.nemo.user.tenantmanager;
\r
10 import com.google.common.base.Optional;
\r
11 import com.google.common.util.concurrent.FutureCallback;
\r
12 import com.google.common.util.concurrent.Futures;
\r
13 import com.google.common.util.concurrent.CheckedFuture;
\r
14 import com.google.common.util.concurrent.ListenableFuture;
\r
15 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
\r
16 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
\r
17 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
\r
18 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
\r
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.common.rev151010.UserId;
\r
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.RegisterUserInput;
\r
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.Users;
\r
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.User;
\r
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.UserBuilder;
\r
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.UserKey;
\r
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.user.rev151010.UserRoles;
\r
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.user.rev151010.user.roles.UserRole;
\r
27 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
\r
28 import org.slf4j.Logger;
\r
29 import org.slf4j.LoggerFactory;
\r
31 import java.util.List;
\r
35 * Created by z00293636 on 2015/8/29.
\r
38 /* maintain tenant information, including how many tenants are active, their information */
\r
39 public class TenantManage {
\r
40 private static final Logger LOG = LoggerFactory.getLogger(TenantManage.class);
\r
41 private DataBroker dataBroker;
\r
42 private List<UserRole> userRoleList;
\r
43 private List<User> usersList ;
\r
46 public TenantManage(DataBroker dataBroker)
\r
48 this.dataBroker = dataBroker;
\r
51 private void setUserRoleList(List<UserRole> userRoleList)
\r
53 this.userRoleList = userRoleList;
\r
56 private void setUserList(List<User> userList)
\r
58 this.usersList = userList;
\r
61 private void setUser(User user)
\r
66 public List<UserRole> getUserRoleList()
\r
68 return userRoleList;
\r
71 public List<User> getUsersList()
\r
76 public User getUser()
\r
81 public void fetchUserRoles(){
\r
83 InstanceIdentifier<UserRoles> userRolesInsId = InstanceIdentifier.builder(UserRoles.class).build();
\r
84 ListenableFuture<Optional<UserRoles>> userRolesFuture = this.dataBroker.newReadOnlyTransaction().read(LogicalDatastoreType.CONFIGURATION, userRolesInsId);
\r
85 Futures.addCallback(userRolesFuture, new FutureCallback<Optional<UserRoles>>() {
\r
87 public void onSuccess(Optional<UserRoles> result)
\r
89 setUserRoleList(result.get().getUserRole());
\r
94 public void onFailure(Throwable t)
\r
96 LOG.error("Can not read role information.", t);
\r
104 public void fetchUsers(){
\r
105 InstanceIdentifier<Users> usersInsId = InstanceIdentifier.builder(Users.class).build();
\r
106 ListenableFuture<Optional<Users>> usersFuture = dataBroker.newReadOnlyTransaction().read(LogicalDatastoreType.CONFIGURATION, usersInsId);
\r
107 Futures.addCallback(usersFuture, new FutureCallback<Optional<Users>>() {
\r
109 public void onSuccess(Optional<Users> result)
\r
111 setUserList(result.get().getUser());
\r
116 public void onFailure(Throwable t)
\r
118 LOG.error("Can not read users information.", t);
\r
126 public void fetchVNSpace(UserId userId)
\r
129 if (getUsersList() != null)
\r
131 for (User user : getUsersList())
\r
133 if (user.getUserId().equals(userId))
\r
143 public void addUser(RegisterUserInput registerUserInput){
\r
144 WriteTransaction t = dataBroker.newWriteOnlyTransaction();
\r
145 if (registerUserInput.getUserId() != null)
\r
147 User user = new UserBuilder(registerUserInput).build();
\r
148 // UserBuilder userBuilder = new UserBuilder();
\r
149 // userBuilder.setUserId(registerUserInput.getUserId());
\r
150 // userBuilder.setUserName(registerUserInput.getUserName());
\r
151 // userBuilder.setUserPassword(registerUserInput.getUserPassword());
\r
152 // userBuilder.setUserRole(registerUserInput.getUserRole());
\r
154 // User user = userBuilder.build();
\r
155 UserKey userKey = new UserKey(registerUserInput.getUserId());
\r
157 InstanceIdentifier<User> userid = InstanceIdentifier.builder(Users.class).child(User.class, userKey).build();
\r
159 t.put(LogicalDatastoreType.CONFIGURATION, userid, user,true);
\r
160 CheckedFuture<Void, TransactionCommitFailedException> f = t.submit();
\r
161 Futures.addCallback(f, new FutureCallback<Void>() {
\r
163 public void onFailure(Throwable t) {
\r
164 LOG.error("Could not write endpoint base container", t);
\r
168 public void onSuccess(Void result) {
\r