Refactor logging to use slf4j
[iotivity.git] / cloud / account / src / main / java / org / iotivity / cloud / accountserver / oauth / Google.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.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
28 import org.apache.oltu.oauth2.client.OAuthClient;
29 import org.apache.oltu.oauth2.client.URLConnectionClient;
30 import org.apache.oltu.oauth2.client.request.OAuthBearerClientRequest;
31 import org.apache.oltu.oauth2.client.request.OAuthClientRequest;
32 import org.apache.oltu.oauth2.client.response.OAuthAccessTokenResponse;
33 import org.apache.oltu.oauth2.client.response.OAuthJSONAccessTokenResponse;
34 import org.apache.oltu.oauth2.client.response.OAuthResourceResponse;
35 import org.apache.oltu.oauth2.common.OAuth;
36 import org.apache.oltu.oauth2.common.OAuthProviderType;
37 import org.apache.oltu.oauth2.common.exception.OAuthProblemException;
38 import org.apache.oltu.oauth2.common.exception.OAuthSystemException;
39 import org.apache.oltu.oauth2.common.message.types.GrantType;
40 import org.iotivity.cloud.accountserver.db.TokenTable;
41 import org.iotivity.cloud.accountserver.db.UserTable;
42 import org.iotivity.cloud.base.exception.ServerException.InternalServerErrorException;
43 import org.iotivity.cloud.util.JSONUtil;
44
45 /**
46  *
47  * This class provides a sample to make .jar that communicates with OAuth2
48  * provider.
49  *
50  */
51 public class Google implements OAuthProvider {
52
53     private final static Logger Log          = LoggerFactory.getLogger(Google.class);
54     // do not use 'client_id' and 'secret' variables.
55     // should use values that are obtained from github.
56     final static private String client_id    = "447649044559-f9r5sl6op3kkk0312u384o4g6hhucje1.apps.googleusercontent.com";
57     final static private String secret       = "LyTe5_EQkv8-v9Zbq20PSCLR";
58     final static private String redirect_url = "http://www.example.com/oauth2callback";
59     final static private String resource_url = "https://www.googleapis.com/userinfo/v2/me";
60
61     @Override
62     public TokenTable requestAccessTokenInfo(String authCode, Object options) {
63
64         TokenTable tokenInfo = new TokenTable();
65
66         if (authCode == null) {
67
68             Log.warn("authCode is null!");
69             return tokenInfo;
70         }
71
72         try {
73
74             OAuthClientRequest request = OAuthClientRequest
75                     .tokenProvider(OAuthProviderType.GOOGLE)
76                     .setGrantType(GrantType.AUTHORIZATION_CODE)
77                     .setClientId(client_id).setClientSecret(secret)
78                     .setCode(authCode).setRedirectURI(redirect_url)
79                     .buildBodyMessage();
80
81             OAuthClient oauthClient = new OAuthClient(
82                     new URLConnectionClient());
83
84             OAuthAccessTokenResponse oauthResponse = null;
85             Class<? extends OAuthAccessTokenResponse> cl = OAuthJSONAccessTokenResponse.class;
86
87             oauthResponse = oauthClient.accessToken(request, cl);
88
89             Log.debug("OAuth response: " + oauthResponse.getBody());
90
91             tokenInfo.setAccesstoken(oauthResponse.getAccessToken());
92             tokenInfo.setRefreshtoken(oauthResponse.getRefreshToken());
93             tokenInfo.setExpiredtime(oauthResponse.getExpiresIn());
94
95         } catch (OAuthSystemException | OAuthProblemException e) {
96
97             e.printStackTrace();
98             throw new InternalServerErrorException(
99                     "OAuth provider(Google) error");
100         }
101
102         return tokenInfo;
103     }
104
105     @Override
106     public TokenTable requestRefreshTokenInfo(String refreshToken) {
107
108         TokenTable tokenInfo = new TokenTable();
109
110         if (refreshToken == null) {
111
112             Log.warn("refreshToken is null!");
113             return tokenInfo;
114         }
115
116         try {
117
118             OAuthClientRequest request = OAuthClientRequest
119                     .tokenProvider(OAuthProviderType.GOOGLE)
120                     .setGrantType(GrantType.REFRESH_TOKEN)
121                     .setClientId(client_id).setClientSecret(secret)
122                     .setRefreshToken(refreshToken).buildBodyMessage();
123
124             OAuthClient oauthClient = new OAuthClient(
125                     new URLConnectionClient());
126
127             OAuthAccessTokenResponse oauthResponse = null;
128             Class<? extends OAuthAccessTokenResponse> cl = OAuthJSONAccessTokenResponse.class;
129
130             oauthResponse = oauthClient.accessToken(request, cl);
131
132             Log.debug("OAuth response: " + oauthResponse.getBody());
133
134             tokenInfo.setAccesstoken(oauthResponse.getAccessToken());
135             // Google provides refreshToken in one time.
136             tokenInfo.setRefreshtoken(refreshToken);
137             tokenInfo.setExpiredtime(oauthResponse.getExpiresIn());
138
139         } catch (OAuthSystemException | OAuthProblemException e) {
140
141             e.printStackTrace();
142             throw new InternalServerErrorException(
143                     "OAuth provider(Google) error");
144         }
145
146         return tokenInfo;
147     }
148
149     @Override
150     public UserTable requestGetUserInfo(String accessToken, Object options) {
151
152         UserTable userInfo = new UserTable();
153
154         if (accessToken == null) {
155             Log.warn("accessToken is null!");
156             return userInfo;
157         }
158
159         String response = null;
160
161         try {
162
163             OAuthClientRequest request = new OAuthBearerClientRequest(
164                     resource_url).setAccessToken(accessToken)
165                             .buildQueryMessage();
166
167             OAuthClient oAuthClient = new OAuthClient(
168                     new URLConnectionClient());
169             OAuthResourceResponse resourceResponse = oAuthClient.resource(
170                     request, OAuth.HttpMethod.GET, OAuthResourceResponse.class);
171
172             response = resourceResponse.getBody();
173             Log.debug("response: " + response);
174
175         } catch (OAuthSystemException | OAuthProblemException e) {
176             e.printStackTrace();
177             throw new InternalServerErrorException(
178                     "OAuth provider(Github) error");
179         }
180
181         String userIdKey = "name";
182
183         JSONUtil<HashMap<String, String>> util = new JSONUtil<>();
184         HashMap<String, String> parsedData = util.parseJSON(response,
185                 HashMap.class);
186
187         if (parsedData == null) {
188             Log.debug("parsedData is null!");
189             return userInfo;
190         }
191
192         String userId = parsedData.get(userIdKey);
193         userInfo.setUserid(userId);
194
195         return userInfo;
196     }
197 }