Add an option to perform login on remote machines

If the user runs "nomulus -e [ENV] login --remote", an URL will be provided, the user then can visit the URL on any machine (not necessary where the command is run) and copy&paste back the authorization code to complete authorization.

This makes it easy to login on machines where local browsers are not easily accessible.

Also upgraded nebula lint version to 10.3.5.

-------------
Created by MOE: https://github.com/google/moe
MOE_MIGRATED_REVID=225198700
This commit is contained in:
jianglai 2018-12-12 09:26:33 -08:00
parent 4146e69d60
commit 377736e987
6 changed files with 39 additions and 16 deletions

View file

@ -14,10 +14,12 @@
package google.registry.tools;
import com.beust.jcommander.Parameter;
import com.beust.jcommander.Parameters;
import com.google.api.client.extensions.java6.auth.oauth2.AuthorizationCodeInstalledApp;
import com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver;
import com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow;
import com.google.api.client.googleapis.extensions.java6.auth.oauth2.GooglePromptReceiver;
import javax.inject.Inject;
/** Authorizes the nomulus tool for OAuth 2.0 access to remote resources. */
@ -27,9 +29,29 @@ final class LoginCommand implements Command {
@Inject GoogleAuthorizationCodeFlow flow;
@Inject @AuthModule.ClientScopeQualifier String clientScopeQualifier;
@Parameter(
names = "--remote",
description =
"Whether the command is run on a remote host where access to a browser is not available. "
+ "If set to true, a URL will be given and a code is expected to be entered after "
+ "the user completes authorization by visiting that URL.")
private boolean remote = false;
@Override
public void run() throws Exception {
new AuthorizationCodeInstalledApp(flow, new LocalServerReceiver())
.authorize(clientScopeQualifier);
AuthorizationCodeInstalledApp app;
if (remote) {
app =
new AuthorizationCodeInstalledApp(
flow,
new GooglePromptReceiver(),
url -> {
System.out.println("Please open the following address in your browser:");
System.out.println(" " + url);
});
} else {
app = new AuthorizationCodeInstalledApp(flow, new LocalServerReceiver());
}
app.authorize(clientScopeQualifier);
}
}