blob: 44fadf7af72237fe4a5416b01b815cb404974c1d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/*
* Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.aaa.idm.persistence;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import org.junit.Before;
import org.junit.Test;
import org.mockito.Mockito;
import org.opendaylight.aaa.api.IDMStoreException;
import org.opendaylight.aaa.api.IIDMStore;
import org.opendaylight.aaa.api.PasswordCredentials;
import org.opendaylight.aaa.api.SHA256Calculator;
import org.opendaylight.aaa.api.model.Domain;
import org.opendaylight.aaa.api.model.Grant;
import org.opendaylight.aaa.api.model.Grants;
import org.opendaylight.aaa.api.model.Role;
import org.opendaylight.aaa.api.model.User;
import org.opendaylight.aaa.api.model.Users;
import org.opendaylight.aaa.idm.IdmLightProxy;
import org.opendaylight.yang.gen.v1.config.aaa.authn.idmlight.rev151204.AAAIDMLightModule;
/*
* @Author - Sharon Aicler (saichler@cisco.com)
*/
public class PasswordHashTest {
@Before
public void before() throws IDMStoreException{
IIDMStore store = Mockito.mock(IIDMStore.class);
AAAIDMLightModule.setStore(store);
Domain domain = new Domain();
domain.setName("sdn");
domain.setDomainid("sdn");
Mockito.when(store.readDomain("sdn")).thenReturn(domain);
Creds c = new Creds();
Users users = new Users();
User user = new User();
user.setName("admin");
user.setUserid(c.username());
user.setDomainid("sdn");
user.setSalt("ABCD");
user.setPassword(SHA256Calculator.getSHA256(c.password(),user.getSalt()));
List<User> lu = new LinkedList<>();
lu.add(user);
users.setUsers(lu);
Grants grants = new Grants();
Grant grant = new Grant();
List<Grant> g = new ArrayList<>();
g.add(grant);
grant.setDomainid("sdn");
grant.setRoleid("admin");
grant.setUserid("admin");
grants.setGrants(g);
Role role = new Role();
role.setRoleid("admin");
role.setName("admin");
Mockito.when(store.readRole("admin")).thenReturn(role);
Mockito.when(store.getUsers(c.username(), c.domain())).thenReturn(users);
Mockito.when(store.getGrants(c.domain(), c.username())).thenReturn(grants);
}
@Test
public void testPasswordHash(){
IdmLightProxy proxy = new IdmLightProxy();
proxy.authenticate(new Creds());
}
private static class Creds implements PasswordCredentials {
@Override
public String username() {
return "admin";
}
@Override
public String password() {
return "admin";
}
@Override
public String domain() {
return "sdn";
}
}
}
|