| // Copyright (C) 2016 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| package com.google.gerrit.server.account; |
| |
| import com.google.gerrit.extensions.auth.oauth.OAuthToken; |
| import com.google.gerrit.extensions.restapi.AuthException; |
| import com.google.gerrit.extensions.restapi.ResourceNotFoundException; |
| import com.google.gerrit.extensions.restapi.RestReadView; |
| import com.google.gerrit.reviewdb.client.Account; |
| import com.google.gerrit.server.CurrentUser; |
| import com.google.gerrit.server.auth.oauth.OAuthTokenCache; |
| import com.google.gerrit.server.config.CanonicalWebUrl; |
| import com.google.inject.Inject; |
| import com.google.inject.Provider; |
| import com.google.inject.Singleton; |
| import java.net.URI; |
| import java.net.URISyntaxException; |
| import org.slf4j.Logger; |
| import org.slf4j.LoggerFactory; |
| |
| @Singleton |
| class GetOAuthToken implements RestReadView<AccountResource> { |
| |
| private static final String BEARER_TYPE = "bearer"; |
| private static final Logger log = LoggerFactory.getLogger(GetOAuthToken.class); |
| |
| private final Provider<CurrentUser> self; |
| private final OAuthTokenCache tokenCache; |
| private final Provider<String> canonicalWebUrlProvider; |
| |
| @Inject |
| GetOAuthToken( |
| Provider<CurrentUser> self, |
| OAuthTokenCache tokenCache, |
| @CanonicalWebUrl Provider<String> urlProvider) { |
| this.self = self; |
| this.tokenCache = tokenCache; |
| this.canonicalWebUrlProvider = urlProvider; |
| } |
| |
| @Override |
| public OAuthTokenInfo apply(AccountResource rsrc) |
| throws AuthException, ResourceNotFoundException { |
| if (self.get() != rsrc.getUser()) { |
| throw new AuthException("not allowed to get access token"); |
| } |
| Account a = rsrc.getUser().getAccount(); |
| OAuthToken accessToken = tokenCache.get(a.getId()); |
| if (accessToken == null) { |
| throw new ResourceNotFoundException(); |
| } |
| OAuthTokenInfo accessTokenInfo = new OAuthTokenInfo(); |
| accessTokenInfo.username = a.getUserName(); |
| accessTokenInfo.resourceHost = getHostName(canonicalWebUrlProvider.get()); |
| accessTokenInfo.accessToken = accessToken.getToken(); |
| accessTokenInfo.providerId = accessToken.getProviderId(); |
| accessTokenInfo.expiresAt = Long.toString(accessToken.getExpiresAt()); |
| accessTokenInfo.type = BEARER_TYPE; |
| return accessTokenInfo; |
| } |
| |
| private static String getHostName(String canonicalWebUrl) { |
| if (canonicalWebUrl == null) { |
| log.error("No canonicalWebUrl defined in gerrit.config, OAuth may not work properly"); |
| return null; |
| } |
| |
| try { |
| return new URI(canonicalWebUrl).getHost(); |
| } catch (URISyntaxException e) { |
| log.error("Invalid canonicalWebUrl '" + canonicalWebUrl + "'", e); |
| return null; |
| } |
| } |
| |
| public static class OAuthTokenInfo { |
| public String username; |
| public String resourceHost; |
| public String accessToken; |
| public String providerId; |
| public String expiresAt; |
| public String type; |
| } |
| } |