* app.yaml: update to go112 Make the required changes to use go112 due to the deprecation of Go 1.9. Migration doc: - https://cloud.google.com/appengine/docs/standard/go111/go-differences References: - https://github.com/GoogleCloudPlatform/govanityurls/issues/29#issuecomment-506538041 - https://github.com/etcd-io/maintainers/issues/17 * go.mod: initial commit Migrate this project to use go.mod and update the README. This is part of the recommended steps to runtime: go111 and beyond. https://cloud.google.com/appengine/docs/standard/go111/go-differences * vendor: add dependent packages Add all dependencies for the project via vendoring for offline builds. * travis.yml: drop go 1.6 for 1.12 Go 1.6 is too old to have a number of builtin packages for the latest appengine package. Remove and update to match app engine version: 1.12. * appengine.go: remove unused file From the go111 migration doc: "The appengine build tag is deprecated and will not be used when building your app for deployment. Ensure your code still functions correctly without it being set." https://cloud.google.com/appengine/docs/standard/go111/go-differences * main: respect PORT environment variable The go111 runtime should use the PORT variable to decide the listening http port. "PORT The port that receives HTTP requests." https://cloud.google.com/appengine/docs/standard/go111/runtime
56 lines
1.8 KiB
Go
56 lines
1.8 KiB
Go
// Copyright 2011 Google Inc. All rights reserved.
|
|
// Use of this source code is governed by the Apache 2.0
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package internal
|
|
|
|
import (
|
|
"os"
|
|
|
|
netcontext "golang.org/x/net/context"
|
|
)
|
|
|
|
var (
|
|
// This is set to true in identity_classic.go, which is behind the appengine build tag.
|
|
// The appengine build tag is set for the first generation runtimes (<= Go 1.9) but not
|
|
// the second generation runtimes (>= Go 1.11), so this indicates whether we're on a
|
|
// first-gen runtime. See IsStandard below for the second-gen check.
|
|
appengineStandard bool
|
|
|
|
// This is set to true in identity_flex.go, which is behind the appenginevm build tag.
|
|
appengineFlex bool
|
|
)
|
|
|
|
// AppID is the implementation of the wrapper function of the same name in
|
|
// ../identity.go. See that file for commentary.
|
|
func AppID(c netcontext.Context) string {
|
|
return appID(FullyQualifiedAppID(c))
|
|
}
|
|
|
|
// IsStandard is the implementation of the wrapper function of the same name in
|
|
// ../appengine.go. See that file for commentary.
|
|
func IsStandard() bool {
|
|
// appengineStandard will be true for first-gen runtimes (<= Go 1.9) but not
|
|
// second-gen (>= Go 1.11).
|
|
return appengineStandard || IsSecondGen()
|
|
}
|
|
|
|
// IsStandard is the implementation of the wrapper function of the same name in
|
|
// ../appengine.go. See that file for commentary.
|
|
func IsSecondGen() bool {
|
|
// Second-gen runtimes set $GAE_ENV so we use that to check if we're on a second-gen runtime.
|
|
return os.Getenv("GAE_ENV") == "standard"
|
|
}
|
|
|
|
// IsFlex is the implementation of the wrapper function of the same name in
|
|
// ../appengine.go. See that file for commentary.
|
|
func IsFlex() bool {
|
|
return appengineFlex
|
|
}
|
|
|
|
// IsAppEngine is the implementation of the wrapper function of the same name in
|
|
// ../appengine.go. See that file for commentary.
|
|
func IsAppEngine() bool {
|
|
return IsStandard() || IsFlex()
|
|
}
|