73abb9659e6da6a01d363eea381e6baa1140cb3f
[iotivity.git] / cloud / account / src / main / java / org / iotivity / cloud / accountserver / oauth / Github.java
1 /*
2  * //******************************************************************
3  * //
4  * // Copyright 2016 Samsung Electronics All Rights Reserved.
5  * //
6  * //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
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  * //
20  * //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
21  */
22 package org.iotivity.cloud.accountserver.oauth;
23
24 import java.util.HashMap;
25
26 import org.apache.oltu.oauth2.client.OAuthClient;
27 import org.apache.oltu.oauth2.client.URLConnectionClient;
28 import org.apache.oltu.oauth2.client.request.OAuthBearerClientRequest;
29 import org.apache.oltu.oauth2.client.request.OAuthClientRequest;
30 import org.apache.oltu.oauth2.client.response.GitHubTokenResponse;
31 import org.apache.oltu.oauth2.client.response.OAuthResourceResponse;
32 import org.apache.oltu.oauth2.common.OAuth;
33 import org.apache.oltu.oauth2.common.OAuthProviderType;
34 import org.apache.oltu.oauth2.common.exception.OAuthProblemException;
35 import org.apache.oltu.oauth2.common.exception.OAuthSystemException;
36 import org.apache.oltu.oauth2.common.message.types.GrantType;
37 import org.iotivity.cloud.accountserver.db.TokenTable;
38 import org.iotivity.cloud.accountserver.db.UserTable;
39 import org.iotivity.cloud.base.exception.ServerException.InternalServerErrorException;
40 import org.iotivity.cloud.util.JSONUtil;
41 import org.iotivity.cloud.util.Log;;
42
43 /**
44  *
45  * This class provides a sample to make .jar that communicates with OAuth2
46  * provider.
47  *
48  */
49 public class Github implements OAuthProvider {
50
51     // do not use 'client_id' and 'secret' variables.
52     // should use values that are obtained from github.
53     final static private String client_id    = "ea9c18f540323b0213d0";
54     final static private String secret       = "4bc0cd9fe21269507eb8eba3a32664a0f598dbc9";
55     final static private String resource_url = "https://api.github.com/user";
56
57     @Override
58     public TokenTable requestAccessTokenInfo(String authCode, Object options) {
59
60         TokenTable tokenInfo = new TokenTable();
61
62         try {
63
64             OAuthClientRequest request = OAuthClientRequest
65                     .tokenProvider(OAuthProviderType.GITHUB)
66                     .setGrantType(GrantType.AUTHORIZATION_CODE)
67                     .setClientId(client_id).setClientSecret(secret)
68                     .setCode(authCode).buildBodyMessage();
69
70             OAuthClient oAuthClient = new OAuthClient(
71                     new URLConnectionClient());
72             GitHubTokenResponse oAuthResponse = oAuthClient.accessToken(request,
73                     GitHubTokenResponse.class);
74
75             tokenInfo.setAccesstoken(oAuthResponse.getAccessToken());
76             tokenInfo.setRefreshtoken(oAuthResponse.getRefreshToken());
77
78             // in Github, tokens don't have to expire.
79             tokenInfo.setExpiredtime(-1);
80
81         } catch (OAuthSystemException | OAuthProblemException e) {
82             e.printStackTrace();
83             throw new InternalServerErrorException(
84                     "OAuth provider(Github) error");
85         }
86
87         return tokenInfo;
88     }
89
90     @Override
91     public TokenTable requestRefreshTokenInfo(String refreshToken) {
92
93         TokenTable tokenInfo = new TokenTable();
94
95         return tokenInfo;
96     }
97
98     @Override
99     public UserTable requestGetUserInfo(String accessToken, Object options) {
100
101         String response = null;
102         UserTable userInfo = new UserTable();
103
104         if (accessToken == null) {
105             Log.w("accessToken is null!");
106             return null;
107         }
108
109         try {
110
111             OAuthClientRequest request = new OAuthBearerClientRequest(
112                     resource_url).setAccessToken(accessToken)
113                             .buildQueryMessage();
114
115             OAuthClient oAuthClient = new OAuthClient(
116                     new URLConnectionClient());
117             OAuthResourceResponse resourceResponse = oAuthClient.resource(
118                     request, OAuth.HttpMethod.GET, OAuthResourceResponse.class);
119
120             response = resourceResponse.getBody();
121             Log.d("response: " + response);
122
123         } catch (OAuthSystemException | OAuthProblemException e) {
124             e.printStackTrace();
125             throw new InternalServerErrorException(
126                     "OAuth provider(Github) error");
127         }
128
129         String userIdKey = "login";
130         JSONUtil<HashMap<String, String>> util = new JSONUtil<>();
131         HashMap<String, String> parsedData = util.parseJSON(response,
132                 HashMap.class);
133
134         if (parsedData == null) {
135             Log.d("parsedData is null!");
136             return null;
137         }
138
139         String userId = parsedData.get(userIdKey);
140         userInfo.setUserid(userId);
141
142         return userInfo;
143     }
144 }