| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 1 | package de.ids_mannheim.korap.web.service; |
| 2 | |
| 3 | import de.ids_mannheim.korap.config.AuthCodeInfo; |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 4 | import de.ids_mannheim.korap.config.BeanConfigTest; |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 5 | import de.ids_mannheim.korap.config.ClientInfo; |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 6 | import de.ids_mannheim.korap.config.ContextHolder; |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 7 | import de.ids_mannheim.korap.exceptions.KustvaktException; |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 8 | import de.ids_mannheim.korap.handlers.OAuth2Handler; |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 9 | import de.ids_mannheim.korap.interfaces.EncryptionIface; |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 10 | import de.ids_mannheim.korap.interfaces.db.PersistenceClient; |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 11 | import de.ids_mannheim.korap.user.TokenContext; |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 12 | import org.junit.Assert; |
| 13 | import org.junit.BeforeClass; |
| 14 | import org.junit.Test; |
| 15 | |
| Michael Hanl | cedf721 | 2016-05-28 10:43:09 +0200 | [diff] [blame] | 16 | import static org.junit.Assert.assertNotNull; |
| Michael Hanl | 33829ec | 2016-05-28 17:03:38 +0200 | [diff] [blame] | 17 | import static org.junit.Assert.assertNull; |
| Michael Hanl | cedf721 | 2016-05-28 10:43:09 +0200 | [diff] [blame] | 18 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 19 | /** |
| 20 | * @author hanl |
| 21 | * @date 13/05/2015 |
| 22 | */ |
| 23 | |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 24 | public class OAuth2HandlerTest extends BeanConfigTest { |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 25 | |
| 26 | private static ClientInfo info; |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 27 | |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 28 | private static final String SCOPES = "search preferences queries account"; |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 29 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 30 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 31 | @BeforeClass |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 32 | public static void setup () throws Exception { |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 33 | // BeanConfiguration.loadClasspathContext("default-config.xml"); |
| 34 | // handler = new OAuth2Handler( |
| 35 | // BeanConfiguration.getKustvaktContext().getPersistenceClient()); |
| 36 | // crypto = BeanConfiguration.getKustvaktContext().getEncryption(); |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 37 | // info = new ClientInfo(crypto.createID(), crypto.createToken()); |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 38 | // info.setConfidential(true); |
| 39 | // //todo: support for subdomains?! |
| 40 | // info.setUrl("http://localhost:8080/api/v0.1"); |
| 41 | // info.setRedirect_uri("testwebsite/login"); |
| 42 | // |
| 43 | // helper = TestHelper.newInstance(); |
| 44 | // helper.setupAccount(); |
| 45 | // PersistenceClient cl = helper.getBean(ContextHolder.KUSTVAKT_DB); |
| 46 | // handler = new OAuth2Handler(cl); |
| 47 | // handler.registerClient(info, helper.getUser()); |
| 48 | // crypto = helper.getBean(ContextHolder.KUSTVAKT_ENCRYPTION); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 49 | } |
| 50 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 51 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 52 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 53 | public void testStoreAuthorizationCodeThrowsNoException () |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 54 | throws KustvaktException { |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 55 | String auth_code = helper().getContext().getEncryption().createToken(); |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 56 | AuthCodeInfo codeInfo = new AuthCodeInfo(info.getClient_id(), auth_code); |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 57 | codeInfo.setScopes(SCOPES); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 58 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 59 | OAuth2Handler handler = new OAuth2Handler(helper().getContext() |
| 60 | .getPersistenceClient()); |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 61 | handler.authorize(codeInfo, helper().getUser()); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 62 | codeInfo = handler.getAuthorization(auth_code); |
| Michael Hanl | cedf721 | 2016-05-28 10:43:09 +0200 | [diff] [blame] | 63 | assertNotNull("client is null!", codeInfo); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 64 | } |
| 65 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 66 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 67 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 68 | public void testAuthorizationCodeRemoveThrowsNoException () |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 69 | throws KustvaktException { |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 70 | String auth_code = helper().getContext().getEncryption().createToken(); |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 71 | AuthCodeInfo codeInfo = new AuthCodeInfo(info.getClient_id(), auth_code); |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 72 | codeInfo.setScopes(SCOPES); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 73 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 74 | OAuth2Handler handler = new OAuth2Handler(helper().getContext() |
| 75 | .getPersistenceClient()); |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 76 | handler.authorize(codeInfo, helper().getUser()); |
| 77 | String t = helper().getContext().getEncryption().createToken(); |
| 78 | String refresh = helper().getContext().getEncryption().createToken(); |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 79 | handler.addToken(codeInfo.getCode(), t, refresh, 7200); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 80 | |
| 81 | TokenContext ctx = handler.getContext(t); |
| Michael Hanl | cedf721 | 2016-05-28 10:43:09 +0200 | [diff] [blame] | 82 | assertNotNull("context is null", ctx); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 83 | |
| 84 | AuthCodeInfo c2 = handler.getAuthorization(codeInfo.getCode()); |
| Michael Hanl | 33829ec | 2016-05-28 17:03:38 +0200 | [diff] [blame] | 85 | assertNull("clearing authorization failed", c2); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 86 | } |
| 87 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 88 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 89 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 90 | public void testTokenEndpointRedirect () { |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 91 | |
| 92 | } |
| 93 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 94 | |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 95 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 96 | public void testStoreAccessCodeViaAuthCodeThrowsNoException () { |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 97 | String auth_code = helper().getContext().getEncryption().createToken(); |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 98 | AuthCodeInfo codeInfo = new AuthCodeInfo(info.getClient_id(), auth_code); |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 99 | codeInfo.setScopes(SCOPES); |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 100 | |
| 101 | } |
| 102 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 103 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 104 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 105 | public void testDeleteAccessCodesByUserDeleteCascade () { |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 106 | |
| 107 | } |
| 108 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 109 | |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 110 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 111 | public void testAccessTokenbyUserDeleteCascade () { |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 112 | |
| 113 | } |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 114 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 115 | |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 116 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 117 | public void testRefreshToken () { |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 118 | |
| 119 | } |
| 120 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 121 | |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 122 | // fixme: exception thrown?! |
| 123 | @Test |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 124 | public void testAccessTokenExpired () { |
| Michael Hanl | 482f30d | 2015-09-25 12:39:46 +0200 | [diff] [blame] | 125 | |
| 126 | } |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 127 | |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 128 | |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 129 | @Override |
| Michael Hanl | 8abaf9e | 2016-05-23 16:46:35 +0200 | [diff] [blame] | 130 | public void initMethod () throws KustvaktException { |
| Michael Hanl | daf8660 | 2016-05-12 14:31:52 +0200 | [diff] [blame] | 131 | helper().setupAccount(); |
| 132 | |
| 133 | EncryptionIface crypto = helper().getContext().getEncryption(); |
| 134 | info = new ClientInfo(crypto.createID(), crypto.createToken()); |
| 135 | info.setConfidential(true); |
| 136 | //todo: support for subdomains?! |
| 137 | info.setUrl("http://localhost:8080/api/v0.1"); |
| 138 | info.setRedirect_uri("testwebsite/login"); |
| 139 | PersistenceClient cl = helper().getBean(ContextHolder.KUSTVAKT_DB); |
| 140 | OAuth2Handler handler = new OAuth2Handler(cl); |
| 141 | handler.registerClient(info, helper().getUser()); |
| 142 | } |
| Michael Hanl | e25dea2 | 2015-09-24 19:37:56 +0200 | [diff] [blame] | 143 | } |