config/const.go (106 lines of code) (raw):
// Copyright 2016 Google, Inc.
//
// 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 config provides variables used in configuring the behavior of the app.
package config
import (
"context"
"fmt"
"regexp"
"runtime/debug"
"strings"
"golang.org/x/oauth2/google"
)
const (
// GCRCredHelperClientID is the client_id to be used when performing the
// OAuth2 Authorization Code grant flow.
// See https://developers.google.com/identity/protocols/OAuth2InstalledApp
GCRCredHelperClientID = "99426463878-o7n0bshgue20tdpm25q4at0vs2mr4utq.apps.googleusercontent.com"
// GCRCredHelperClientNotSoSecret is the client_secret to be used when
// performing the OAuth2 Authorization Code grant flow.
// See https://developers.google.com/identity/protocols/OAuth2InstalledApp
GCRCredHelperClientNotSoSecret = "HpVi8cnKx8AAkddzaNrSWmS8"
)
// Version can be set via:
// -ldflags="-X 'github.com/GoogleCloudPlatform/docker-credential-gcr/v2/config.Version=$TAG'"
var Version string
func init() {
if Version == "" {
if i, ok := debug.ReadBuildInfo(); ok {
Version = i.Main.Version
}
}
Version = strings.TrimPrefix(Version, "v")
re := regexp.MustCompile(`^[0-9]+(?:[\._][0-9]+)*$`)
if re.MatchString(Version) {
GcrOAuth2Username = fmt.Sprintf("_dcgcr_%s_token", strings.ReplaceAll(Version, ".", "_"))
} else {
GcrOAuth2Username = "_dcgcr_0_0_0_token"
}
}
// DefaultGCRRegistries contains the list of default registries to authenticate for.
var DefaultGCRRegistries = [...]string{
"gcr.io",
"us.gcr.io",
"eu.gcr.io",
"asia.gcr.io",
"marketplace.gcr.io",
}
// DefaultARRegistries contains the list of default registries for Artifact
// Registry. If the --include-artifact-registry flag is supplied then these
// are added in addition to the GCR Registries.
var DefaultARRegistries = [...]string{
"africa-south1-docker.pkg.dev",
"asia-docker.pkg.dev",
"asia-east1-docker.pkg.dev",
"asia-east2-docker.pkg.dev",
"asia-northeast1-docker.pkg.dev",
"asia-northeast2-docker.pkg.dev",
"asia-northeast3-docker.pkg.dev",
"asia-south1-docker.pkg.dev",
"asia-south2-docker.pkg.dev",
"asia-southeast1-docker.pkg.dev",
"asia-southeast2-docker.pkg.dev",
"australia-southeast1-docker.pkg.dev",
"australia-southeast2-docker.pkg.dev",
"europe-docker.pkg.dev",
"europe-central2-docker.pkg.dev",
"europe-north1-docker.pkg.dev",
"europe-southwest1-docker.pkg.dev",
"europe-west1-docker.pkg.dev",
"europe-west2-docker.pkg.dev",
"europe-west3-docker.pkg.dev",
"docker.europe-west3.rep.pkg.dev",
"europe-west4-docker.pkg.dev",
"europe-west6-docker.pkg.dev",
"europe-west8-docker.pkg.dev",
"docker.europe-west8.rep.pkg.dev",
"europe-west9-docker.pkg.dev",
"docker.europe-west9.rep.pkg.dev",
"europe-west10-docker.pkg.dev",
"europe-west12-docker.pkg.dev",
"me-central1-docker.pkg.dev",
"me-central2-docker.pkg.dev",
"docker.me-central2.rep.pkg.dev",
"me-west1-docker.pkg.dev",
"northamerica-northeast1-docker.pkg.dev",
"northamerica-northeast2-docker.pkg.dev",
"northamerica-south1-docker.pkg.dev",
"southamerica-east1-docker.pkg.dev",
"southamerica-west1-docker.pkg.dev",
"us-docker.pkg.dev",
"us-central1-docker.pkg.dev",
"docker.us-central1.rep.pkg.dev",
"us-east1-docker.pkg.dev",
"docker.us-east1.rep.pkg.dev",
"us-east4-docker.pkg.dev",
"docker.us-east4.rep.pkg.dev",
"us-east5-docker.pkg.dev",
"docker.us-east5.rep.pkg.dev",
"us-south1-docker.pkg.dev",
"docker.us-south1.rep.pkg.dev",
"us-west1-docker.pkg.dev",
"docker.us-west1.rep.pkg.dev",
"us-west2-docker.pkg.dev",
"docker.us-west2.rep.pkg.dev",
"us-west3-docker.pkg.dev",
"docker.us-west3.rep.pkg.dev",
"us-west4-docker.pkg.dev",
"docker.us-west4.rep.pkg.dev",
"us-west8-docker.pkg.dev",
"docker.us-west8.rep.pkg.dev",
"europe-north2-docker.pkg.dev",
}
// SupportedGCRTokenSources maps config keys to plain english explanations for
// where the helper should search for a GCR access token.
var SupportedGCRTokenSources = map[string]string{
"env": "Application default credentials or GCE/AppEngine metadata.",
"gcloud": "'gcloud auth print-access-token'",
"store": "The file store maintained by the credential helper.",
}
// GCROAuth2Endpoint describes the oauth2.Endpoint to be used when
// authenticating a GCR user.
var GCROAuth2Endpoint = google.Endpoint
// GCRScopes is/are the OAuth2 scope(s) to request during access_token creation.
var GCRScopes = []string{"https://www.googleapis.com/auth/devstorage.read_write"}
// OAuthHTTPContext is the HTTP context to use when performing OAuth2 calls.
var OAuthHTTPContext = context.Background()
// GcrOAuth2Username is the Basic auth username accompanying Docker requests to GCR.
var GcrOAuth2Username string