aboutsummaryrefslogtreecommitdiffstats
path: root/upstream/odl-aaa-moon/aaa/aaa-idmlight/src/test/java/org/opendaylight/aaa/idm/persistence/PasswordHashTest.java
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";
        }
    }
}