Google App Engine provides several useful services based on Google infrastructure. One example is the Users service, which lets your application integrate with Google user accounts. With the Users service, your users can employ the Google accounts they already have to sign in to your application.
The Users service makes it easy to personalize this application's greeting.
myapp/hello.go again, and replace its contents
with the following:
Reload the page in your browser. When running on the local development server, your application
displays the user
email@example.com, which is the only user supported when running on
the local development server.
When your application is running on production App Engine, however, users will be directed to the Google Accounts sign-in page, then redirected back to your application after successfully signing in or creating an account.
The Users API
Let's take a closer look at the new pieces:
appengine.NewContext function returns an
appengine.Context value associated with the current request.
This is an opaque value used by many functions in the Go App Engine SDK
to communicate with the App Engine service.
If the user is already signed in to your application,
returns a pointer to a
user.User value for the user. Otherwise, it
If the user has not signed in, redirect the user's browser to the Google account
sign-in screen by setting a
Location header and returning an HTTP
status code of 302 "Found".
The redirection includes the URL to this page (
the Google account sign-in mechanism will send the user back here after
signing in or registering for a new account.
user.LoginURL function returns an
as its second argument. Though an error is unlikely to occur here, it is good
practice to check it and display an error user, if appropriate
(in this case, with the
If the user has signed in, display a personalized message using the name
associated with the user's account. In this case, the
String method to
get the user's name in string form.
For more information about the Users API, see the Users reference.
Note: for specific paths that should be served only to logged in users,
login: required directive in the
the app.yaml reference
Our application can now greet visiting users by name. Let's add a feature that will let users greet each other.