diff --git a/authenticate/authenticate.go b/authenticate/authenticate.go index 8e22c7bf3..b29fb4709 100644 --- a/authenticate/authenticate.go +++ b/authenticate/authenticate.go @@ -31,9 +31,6 @@ func ValidateOptions(o *config.Options) error { if _, err := cryptutil.NewAEADCipherFromBase64(o.CookieSecret); err != nil { return fmt.Errorf("authenticate: 'COOKIE_SECRET' invalid %w", err) } - if _, err := o.GetAuthenticateURL(); err != nil { - return fmt.Errorf("authenticate: 'AUTHENTICATE_SERVICE_URL' invalid: %w", err) - } if o.Provider == "" { return errors.New("authenticate: 'IDP_PROVIDER' is required") } diff --git a/authenticate/authenticate_test.go b/authenticate/authenticate_test.go index 6999c6f85..2fd5e9622 100644 --- a/authenticate/authenticate_test.go +++ b/authenticate/authenticate_test.go @@ -53,14 +53,12 @@ func TestOptions_Validate(t *testing.T) { }{ {"minimum options", good, false}, {"nil options", &config.Options{}, true}, - {"bad scheme", badScheme, true}, {"no cookie secret", emptyCookieSecret, true}, {"invalid cookie secret", invalidCookieSecret, true}, {"short cookie secret", shortCookieLength, true}, {"no shared secret", badSharedKey, true}, {"no client id", emptyClientID, true}, {"no client secret", emptyClientSecret, true}, - {"empty authenticate url", badAuthenticateURL, true}, {"empty callback path", badCallbackPath, true}, } for _, tt := range tests { diff --git a/authenticate/middleware.go b/authenticate/middleware.go index 2989f2a4b..5f4d91464 100644 --- a/authenticate/middleware.go +++ b/authenticate/middleware.go @@ -13,7 +13,7 @@ import ( func (a *Authenticate) requireValidSignatureOnRedirect(next httputil.HandlerFunc) http.Handler { return httputil.HandlerFunc(func(w http.ResponseWriter, r *http.Request) error { if r.FormValue(urlutil.QueryRedirectURI) != "" || r.FormValue(urlutil.QueryHmacSignature) != "" { - err := middleware.ValidateRequestURL(r, a.state.Load().sharedKey) + err := middleware.ValidateRequestURL(a.getExternalRequest(r), a.state.Load().sharedKey) if err != nil { return httputil.NewError(http.StatusBadRequest, err) } @@ -25,10 +25,39 @@ func (a *Authenticate) requireValidSignatureOnRedirect(next httputil.HandlerFunc // requireValidSignature validates the pomerium_signature. func (a *Authenticate) requireValidSignature(next httputil.HandlerFunc) http.Handler { return httputil.HandlerFunc(func(w http.ResponseWriter, r *http.Request) error { - err := middleware.ValidateRequestURL(r, a.state.Load().sharedKey) + err := middleware.ValidateRequestURL(a.getExternalRequest(r), a.state.Load().sharedKey) if err != nil { return err } return next(w, r) }) } + +func (a *Authenticate) getExternalRequest(r *http.Request) *http.Request { + options := a.options.Load() + + externalURL, err := options.GetAuthenticateURL() + if err != nil { + return r + } + + internalURL, err := options.GetInternalAuthenticateURL() + if err != nil { + return r + } + + // if we're not using a different internal URL there's nothing to do + if externalURL.String() == internalURL.String() { + return r + } + + // replace the internal host with the external host + er := r.Clone(r.Context()) + if er.URL.Host == internalURL.Host { + er.URL.Host = externalURL.Host + } + if er.Host == internalURL.Host { + er.Host = externalURL.Host + } + return er +} diff --git a/authorize/authorize.go b/authorize/authorize.go index 08556c414..88a67f8c2 100644 --- a/authorize/authorize.go +++ b/authorize/authorize.go @@ -73,9 +73,6 @@ func validateOptions(o *config.Options) error { if _, err := cryptutil.NewAEADCipher(sharedKey); err != nil { return fmt.Errorf("authorize: bad 'SHARED_SECRET': %w", err) } - if _, err := o.GetAuthenticateURL(); err != nil { - return fmt.Errorf("authorize: invalid 'AUTHENTICATE_SERVICE_URL': %w", err) - } return nil } @@ -93,7 +90,7 @@ func newPolicyEvaluator(opts *config.Options, store *evaluator.Store) (*evaluato return nil, fmt.Errorf("authorize: invalid client CA: %w", err) } - authenticateURL, err := opts.GetAuthenticateURL() + authenticateURL, err := opts.GetInternalAuthenticateURL() if err != nil { return nil, fmt.Errorf("authorize: invalid authenticate url: %w", err) } diff --git a/config/envoyconfig/clusters.go b/config/envoyconfig/clusters.go index 22a604e48..05fcbdcdd 100644 --- a/config/envoyconfig/clusters.go +++ b/config/envoyconfig/clusters.go @@ -35,7 +35,7 @@ func (b *Builder) BuildClusters(ctx context.Context, cfg *config.Config) ([]*env Scheme: "http", Host: b.localHTTPAddress, } - authorizeURLs, err := cfg.Options.GetAuthorizeURLs() + authorizeURLs, err := cfg.Options.GetInternalAuthorizeURLs() if err != nil { return nil, err } diff --git a/config/envoyconfig/listeners.go b/config/envoyconfig/listeners.go index 567bc51c7..eb37e9076 100644 --- a/config/envoyconfig/listeners.go +++ b/config/envoyconfig/listeners.go @@ -295,12 +295,12 @@ func (b *Builder) buildMainHTTPConnectionManagerFilter( domains []string, tlsDomain string, ) (*envoy_config_listener_v3.Filter, error) { - authorizeURLs, err := options.GetAuthorizeURLs() + authorizeURLs, err := options.GetInternalAuthorizeURLs() if err != nil { return nil, err } - dataBrokerURLs, err := options.GetDataBrokerURLs() + dataBrokerURLs, err := options.GetInternalDataBrokerURLs() if err != nil { return nil, err } @@ -728,21 +728,6 @@ func getRouteableDomainsForTLSDomain(options *config.Options, addr string, tlsDo } func getAllRouteableDomains(options *config.Options, addr string) ([]string, error) { - authenticateURL, err := options.GetAuthenticateURL() - if err != nil { - return nil, err - } - - authorizeURLs, err := options.GetAuthorizeURLs() - if err != nil { - return nil, err - } - - dataBrokerURLs, err := options.GetDataBrokerURLs() - if err != nil { - return nil, err - } - forwardAuthURL, err := options.GetForwardAuthURL() if err != nil { return nil, err @@ -750,24 +735,62 @@ func getAllRouteableDomains(options *config.Options, addr string) ([]string, err lookup := map[string]struct{}{} if config.IsAuthenticate(options.Services) && addr == options.Addr { + authenticateURL, err := options.GetInternalAuthenticateURL() + if err != nil { + return nil, err + } for _, h := range urlutil.GetDomainsForURL(*authenticateURL) { lookup[h] = struct{}{} } } - if config.IsAuthorize(options.Services) && addr == options.GetGRPCAddr() { + + // authorize urls + if config.IsAll(options.Services) && addr == options.GetGRPCAddr() { + authorizeURLs, err := options.GetAuthorizeURLs() + if err != nil { + return nil, err + } + for _, u := range authorizeURLs { + for _, h := range urlutil.GetDomainsForURL(*u) { + lookup[h] = struct{}{} + } + } + } else if config.IsAuthorize(options.Services) && addr == options.GetGRPCAddr() { + authorizeURLs, err := options.GetInternalAuthorizeURLs() + if err != nil { + return nil, err + } for _, u := range authorizeURLs { for _, h := range urlutil.GetDomainsForURL(*u) { lookup[h] = struct{}{} } } } - if config.IsDataBroker(options.Services) && addr == options.GetGRPCAddr() { + + // databroker urls + if config.IsAll(options.Services) && addr == options.GetGRPCAddr() { + dataBrokerURLs, err := options.GetDataBrokerURLs() + if err != nil { + return nil, err + } + for _, u := range dataBrokerURLs { + for _, h := range urlutil.GetDomainsForURL(*u) { + lookup[h] = struct{}{} + } + } + } else if config.IsDataBroker(options.Services) && addr == options.GetGRPCAddr() { + dataBrokerURLs, err := options.GetInternalDataBrokerURLs() + if err != nil { + return nil, err + } for _, u := range dataBrokerURLs { for _, h := range urlutil.GetDomainsForURL(*u) { lookup[h] = struct{}{} } } } + + // policy urls if config.IsProxy(options.Services) && addr == options.Addr { for _, policy := range options.GetAllPolicies() { for _, h := range urlutil.GetDomainsForURL(*policy.Source.URL) { diff --git a/config/envoyconfig/routes.go b/config/envoyconfig/routes.go index 40a25818b..347933723 100644 --- a/config/envoyconfig/routes.go +++ b/config/envoyconfig/routes.go @@ -105,7 +105,7 @@ func (b *Builder) buildPomeriumHTTPRoutes(options *config.Options, domain string } } // if we're handling authentication, add the oauth2 callback url - authenticateURL, err := options.GetAuthenticateURL() + authenticateURL, err := options.GetInternalAuthenticateURL() if err != nil { return nil, err } diff --git a/config/options.go b/config/options.go index ef0cdc71c..8ce70d4b4 100644 --- a/config/options.go +++ b/config/options.go @@ -122,7 +122,8 @@ type Options struct { // AuthenticateURL represents the externally accessible http endpoints // used for authentication requests and callbacks - AuthenticateURLString string `mapstructure:"authenticate_service_url" yaml:"authenticate_service_url,omitempty"` + AuthenticateURLString string `mapstructure:"authenticate_service_url" yaml:"authenticate_service_url,omitempty"` + AuthenticateInternalURLString string `mapstructure:"authenticate_internal_service_url" yaml:"authenticate_internal_service_url,omitempty"` // SignOutRedirectURL represents the url that user will be redirected to after signing out. SignOutRedirectURLString string `mapstructure:"signout_redirect_url" yaml:"signout_redirect_url,omitempty"` @@ -164,8 +165,9 @@ type Options struct { // AuthorizeURLString is the routable destination of the authorize service's // gRPC endpoint. NOTE: As many load balancers do not support // externally routed gRPC so this may be an internal location. - AuthorizeURLString string `mapstructure:"authorize_service_url" yaml:"authorize_service_url,omitempty"` - AuthorizeURLStrings []string `mapstructure:"authorize_service_urls" yaml:"authorize_service_urls,omitempty"` + AuthorizeURLString string `mapstructure:"authorize_service_url" yaml:"authorize_service_url,omitempty"` + AuthorizeURLStrings []string `mapstructure:"authorize_service_urls" yaml:"authorize_service_urls,omitempty"` + AuthorizeInternalURLString string `mapstructure:"authorize_internal_service_url" yaml:"authorize_internal_service_url,omitempty"` // Settings to enable custom behind-the-ingress service communication OverrideCertificateName string `mapstructure:"override_certificate_name" yaml:"override_certificate_name,omitempty"` @@ -241,8 +243,9 @@ type Options struct { ForwardAuthURLString string `mapstructure:"forward_auth_url" yaml:"forward_auth_url,omitempty"` // DataBrokerURLString is the routable destination of the databroker service's gRPC endpiont. - DataBrokerURLString string `mapstructure:"databroker_service_url" yaml:"databroker_service_url,omitempty"` - DataBrokerURLStrings []string `mapstructure:"databroker_service_urls" yaml:"databroker_service_urls,omitempty"` + DataBrokerURLString string `mapstructure:"databroker_service_url" yaml:"databroker_service_url,omitempty"` + DataBrokerURLStrings []string `mapstructure:"databroker_service_urls" yaml:"databroker_service_urls,omitempty"` + DataBrokerInternalURLString string `mapstructure:"databroker_internal_service_url" yaml:"databroker_internal_service_url,omitempty"` // DataBrokerStorageType is the storage backend type that databroker will use. // Supported type: memory, redis DataBrokerStorageType string `mapstructure:"databroker_storage_type" yaml:"databroker_storage_type,omitempty"` @@ -559,6 +562,12 @@ func (o *Options) Validate() error { return fmt.Errorf("config: bad authenticate-url %s : %w", o.AuthenticateURLString, err) } } + if o.AuthenticateInternalURLString != "" { + _, err := urlutil.ParseAndValidateURL(o.AuthenticateInternalURLString) + if err != nil { + return fmt.Errorf("config: bad authenticate-internal-url %s : %w", o.AuthenticateInternalURLString, err) + } + } if o.SignOutRedirectURLString != "" { _, err := urlutil.ParseAndValidateURL(o.SignOutRedirectURLString) @@ -573,6 +582,12 @@ func (o *Options) Validate() error { return fmt.Errorf("config: bad authorize-url %s : %w", o.AuthorizeURLString, err) } } + if o.AuthorizeInternalURLString != "" { + _, err := urlutil.ParseAndValidateURL(o.AuthorizeInternalURLString) + if err != nil { + return fmt.Errorf("config: bad authorize-internal-url %s : %w", o.AuthorizeInternalURLString, err) + } + } if o.DataBrokerURLString != "" { _, err := urlutil.ParseAndValidateURL(o.DataBrokerURLString) @@ -580,6 +595,12 @@ func (o *Options) Validate() error { return fmt.Errorf("config: bad databroker service url %s : %w", o.DataBrokerURLString, err) } } + if o.DataBrokerInternalURLString != "" { + _, err := urlutil.ParseAndValidateURL(o.DataBrokerInternalURLString) + if err != nil { + return fmt.Errorf("config: bad databroker internal service url %s : %w", o.DataBrokerInternalURLString, err) + } + } if o.ForwardAuthURLString != "" { _, err := urlutil.ParseAndValidateURL(o.ForwardAuthURLString) @@ -749,6 +770,15 @@ func (o *Options) GetAuthenticateURL() (*url.URL, error) { return urlutil.ParseAndValidateURL(rawurl) } +// GetInternalAuthenticateURL returns the internal AuthenticateURL in the options or the AuthenticateURL. +func (o *Options) GetInternalAuthenticateURL() (*url.URL, error) { + rawurl := o.AuthenticateInternalURLString + if rawurl == "" { + return o.GetAuthenticateURL() + } + return urlutil.ParseAndValidateURL(o.AuthenticateInternalURLString) +} + // GetAuthorizeURLs returns the AuthorizeURLs in the options or 127.0.0.1:5443. func (o *Options) GetAuthorizeURLs() ([]*url.URL, error) { if IsAll(o.Services) && o.AuthorizeURLString == "" && len(o.AuthorizeURLStrings) == 0 { @@ -761,6 +791,15 @@ func (o *Options) GetAuthorizeURLs() ([]*url.URL, error) { return o.getURLs(append([]string{o.AuthorizeURLString}, o.AuthorizeURLStrings...)...) } +// GetInternalAuthorizeURLs returns the internal AuthorizeURLs in the options or the AuthorizeURLs. +func (o *Options) GetInternalAuthorizeURLs() ([]*url.URL, error) { + rawurl := o.AuthorizeInternalURLString + if rawurl == "" { + return o.GetAuthorizeURLs() + } + return o.getURLs(rawurl) +} + // GetDataBrokerURLs returns the DataBrokerURLs in the options or 127.0.0.1:5443. func (o *Options) GetDataBrokerURLs() ([]*url.URL, error) { if IsAll(o.Services) && o.DataBrokerURLString == "" && len(o.DataBrokerURLStrings) == 0 { @@ -773,6 +812,15 @@ func (o *Options) GetDataBrokerURLs() ([]*url.URL, error) { return o.getURLs(append([]string{o.DataBrokerURLString}, o.DataBrokerURLStrings...)...) } +// GetInternalDataBrokerURLs returns the internal DataBrokerURLs in the options or the DataBrokerURLs. +func (o *Options) GetInternalDataBrokerURLs() ([]*url.URL, error) { + rawurl := o.DataBrokerInternalURLString + if rawurl == "" { + return o.GetDataBrokerURLs() + } + return o.getURLs(rawurl) +} + func (o *Options) getURLs(strs ...string) ([]*url.URL, error) { var urls []*url.URL if o != nil { @@ -1102,6 +1150,9 @@ func (o *Options) ApplySettings(ctx context.Context, settings *config.Settings) if settings.AuthenticateServiceUrl != nil { o.AuthenticateURLString = settings.GetAuthenticateServiceUrl() } + if settings.AuthenticateInternalServiceUrl != nil { + o.AuthenticateInternalURLString = settings.GetAuthenticateInternalServiceUrl() + } if settings.AuthenticateCallbackPath != nil { o.AuthenticateCallbackPath = settings.GetAuthenticateCallbackPath() } @@ -1153,6 +1204,9 @@ func (o *Options) ApplySettings(ctx context.Context, settings *config.Settings) if len(settings.AuthorizeServiceUrls) > 0 { o.AuthorizeURLStrings = settings.GetAuthorizeServiceUrls() } + if settings.AuthorizeInternalServiceUrl != nil { + o.AuthorizeInternalURLString = settings.GetAuthorizeInternalServiceUrl() + } if settings.OverrideCertificateName != nil { o.OverrideCertificateName = settings.GetOverrideCertificateName() } @@ -1225,6 +1279,9 @@ func (o *Options) ApplySettings(ctx context.Context, settings *config.Settings) if len(settings.DatabrokerServiceUrls) > 0 { o.DataBrokerURLStrings = settings.GetDatabrokerServiceUrls() } + if settings.DatabrokerInternalServiceUrl != nil { + o.DataBrokerInternalURLString = settings.GetDatabrokerInternalServiceUrl() + } if settings.ClientCa != nil { o.ClientCA = settings.GetClientCa() } diff --git a/databroker/cache.go b/databroker/cache.go index 6d22deb2f..575f53c21 100644 --- a/databroker/cache.go +++ b/databroker/cache.go @@ -84,7 +84,7 @@ func New(cfg *config.Config) (*DataBroker, error) { } dataBrokerServer := newDataBrokerServer(cfg) - dataBrokerURLs, err := cfg.Options.GetDataBrokerURLs() + dataBrokerURLs, err := cfg.Options.GetInternalDataBrokerURLs() if err != nil { return nil, err } diff --git a/docs/reference/readme.md b/docs/reference/readme.md index 3d7fb9da1..6d3a0307b 100644 --- a/docs/reference/readme.md +++ b/docs/reference/readme.md @@ -713,6 +713,16 @@ See also: Authenticate Service URL is the externally accessible URL for the authenticate service. +### Authenticate Internal Service URL +- Environmental Variable: `AUTHENTICATE_INTERNAL_SERVICE_URL` +- Config File Key: `authenticate_internal_service_url` +- Type: `URL` +- Required +- Example: `https://authenticate.internal` + +Authenticate Internal Service URL overrides `authenticate_service_url` when determining the TLS certificate and hostname for the authenticate service to listen with. + + ### Identity Provider Client ID - Environmental Variable: `IDP_CLIENT_ID` - Config File Key: `idp_client_id` @@ -845,6 +855,16 @@ Authorize Service URL is the location of the internally accessible authorize ser If your load balancer does not support gRPC pass-through you'll need to set this value to an internally routable location (`https://pomerium-authorize-service.default.svc.cluster.local`) instead of an externally routable one (`https://authorize.corp.example.com`). +### Authorize Internal Service URL +- Environmental Variable: `AUTHORIZE_INTERNAL_SERVICE_URL` +- Config File Key: `authorize_internal_service_url` +- Type: `URL` +- Required; inferred in all-in-one mode to be localhost. +- Example: `https://pomerium-authorize-service.default.svc.cluster.local` or `https://localhost:5443` + +Authorize Internal Service URL overrides `authorize_service_url` when determining the TLS certificate for the authorize service to listen with. + + ### Certificate Authority - Environmental Variable: `CERTIFICATE_AUTHORITY` or `CERTIFICATE_AUTHORITY_FILE` - Config File Key: `certificate_authority` or `certificate_authority_file` @@ -1018,7 +1038,7 @@ The databroker service is used for storing user session data. - Example: `https://databroker.corp.example.com` - Default: in all-in-one mode, `http://localhost:5443` -The data broker service URL points to a data broker which is responsible for storing associated authorization context (e.g. sessions, users and user groups). Multiple URLs can be specified with `databroker_service_url`. +The data broker service URL points to a data broker which is responsible for storing associated authorization context (e.g. sessions, users and user groups). Multiple URLs can be specified with `databroker_service_urls`. By default, the `databroker` service uses an in-memory databroker. @@ -1031,6 +1051,16 @@ For an example implementation, the in-memory database used by the databroker ser - [pkg/databroker/memory](https://github.com/pomerium/pomerium/tree/master/pkg/databroker/memory) +### Data Broker Internal Service URL +- Environmental Variable: `DATABROKER_INTERNAL_SERVICE_URL` or `DATABROKER_INTERNAL_SERVICE_URLS` +- Config File Key: `databroker_internal_service_url` or `databroker_internal_service_urls` +- Type: `URL` +- Example: `https://databroker.corp.example.com` +- Default: in all-in-one mode, `http://localhost:5443` + +Data Broker Internal URL overrides `databroker_service_url` when determining the TLS certificate for the databroker service to listen with. + + ### Data Broker Storage Type - Environmental Variable: `DATABROKER_STORAGE_TYPE` - Config File Key: `databroker_storage_type` diff --git a/docs/reference/settings.yaml b/docs/reference/settings.yaml index 235e2d34f..9e8e98db0 100644 --- a/docs/reference/settings.yaml +++ b/docs/reference/settings.yaml @@ -765,7 +765,14 @@ settings: doc: | Setting `use_proxy_protocol` will configure Pomerium to require the [HAProxy proxy protocol](https://www.haproxy.org/download/1.9/doc/proxy-protocol.txt) on incoming connections. Versions 1 and 2 of the protocol are supported. - name: "Envoy Bootstrap Options" - keys: ["envoy_admin_address","envoy_admin_access_log_path","envoy_admin_profile_path","envoy_bind_config_freebind","envoy_bind_config_source_address"] + keys: + [ + "envoy_admin_address", + "envoy_admin_access_log_path", + "envoy_admin_profile_path", + "envoy_bind_config_freebind", + "envoy_bind_config_source_address", + ] attributes: | - Environment Variable: `ENVOY_ADMIN_ADDRESS`, `ENVOY_ADMIN_ACCESS_LOG_PATH`, `ENVOY_ADMIN_PROFILE_PATH`, `ENVOY_BIND_CONFIG_FREEBIND`, `ENVOY_BIND_CONFIG_SOURCE_ADDRESS` - Config File Keys: `envoy_admin_address`, `envoy_admin_access_log_path`, `envoy_admin_profile_path`, `envoy_bind_config_freebind`, `envoy_bind_config_source_address` @@ -807,6 +814,18 @@ settings: Authenticate Service URL is the externally accessible URL for the authenticate service. shortdoc: | Authenticate Service URL is the externally accessible URL for the authenticate service. + - name: "Authenticate Internal Service URL" + keys: ["authenticate_internal_service_url"] + attributes: | + - Environmental Variable: `AUTHENTICATE_INTERNAL_SERVICE_URL` + - Config File Key: `authenticate_internal_service_url` + - Type: `URL` + - Required + - Example: `https://authenticate.internal` + short: | + Authenticate Service URL is the internally accessible URL for the authenticate service. + doc: | + Authenticate Internal Service URL overrides `authenticate_service_url` when determining the TLS certificate and hostname for the authenticate service to listen with. - name: "Identity Provider Client ID" keys: ["idp_client_id"] attributes: | @@ -955,6 +974,16 @@ settings: Authorize Service URL is the location of the internally accessible authorize service. NOTE: Unlike authenticate, authorize has no publicly accessible http handlers so this setting is purely for gRPC communication. If your load balancer does not support gRPC pass-through you'll need to set this value to an internally routable location (`https://pomerium-authorize-service.default.svc.cluster.local`) instead of an externally routable one (`https://authorize.corp.example.com`). + - name: "Authorize Internal Service URL" + keys: ["authorize_internal_service_url"] + attributes: | + - Environmental Variable: `AUTHORIZE_INTERNAL_SERVICE_URL` + - Config File Key: `authorize_internal_service_url` + - Type: `URL` + - Required; inferred in all-in-one mode to be localhost. + - Example: `https://pomerium-authorize-service.default.svc.cluster.local` or `https://localhost:5443` + doc: | + Authorize Internal Service URL overrides `authorize_service_url` when determining the TLS certificate for the authorize service to listen with. - name: "Certificate Authority" keys: ["certificate_authority", "certificate_authority_file"] attributes: | @@ -1142,7 +1171,7 @@ settings: - Example: `https://databroker.corp.example.com` - Default: in all-in-one mode, `http://localhost:5443` doc: | - The data broker service URL points to a data broker which is responsible for storing associated authorization context (e.g. sessions, users and user groups). Multiple URLs can be specified with `databroker_service_url`. + The data broker service URL points to a data broker which is responsible for storing associated authorization context (e.g. sessions, users and user groups). Multiple URLs can be specified with `databroker_service_urls`. By default, the `databroker` service uses an in-memory databroker. @@ -1153,6 +1182,16 @@ settings: For an example implementation, the in-memory database used by the databroker service can be found here: - [pkg/databroker/memory](https://github.com/pomerium/pomerium/tree/master/pkg/databroker/memory) + - name: "Data Broker Internal Service URL" + keys: ["databroker_internal_service_url"] + attributes: | + - Environmental Variable: `DATABROKER_INTERNAL_SERVICE_URL` or `DATABROKER_INTERNAL_SERVICE_URLS` + - Config File Key: `databroker_internal_service_url` or `databroker_internal_service_urls` + - Type: `URL` + - Example: `https://databroker.corp.example.com` + - Default: in all-in-one mode, `http://localhost:5443` + doc: | + Data Broker Internal URL overrides `databroker_service_url` when determining the TLS certificate for the databroker service to listen with. - name: "Data Broker Storage Type" keys: ["databroker_storage_type"] attributes: | diff --git a/integration/clusters/auth0-multi/compose.yml b/integration/clusters/auth0-multi/compose.yml index 4e2e19f1b..a808dfc94 100644 --- a/integration/clusters/auth0-multi/compose.yml +++ b/integration/clusters/auth0-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "auth0"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/azure-multi/compose.yml b/integration/clusters/azure-multi/compose.yml index 8cf781b28..055d7fb0c 100644 --- a/integration/clusters/azure-multi/compose.yml +++ b/integration/clusters/azure-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "azure"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/github-multi/compose.yml b/integration/clusters/github-multi/compose.yml index 8c99387bd..ed115973c 100644 --- a/integration/clusters/github-multi/compose.yml +++ b/integration/clusters/github-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "github"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/gitlab-multi/compose.yml b/integration/clusters/gitlab-multi/compose.yml index 402bb3c0c..a3212e838 100644 --- a/integration/clusters/gitlab-multi/compose.yml +++ b/integration/clusters/gitlab-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "gitlab"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/google-multi/compose.yml b/integration/clusters/google-multi/compose.yml index eecf4298e..fc743d163 100644 --- a/integration/clusters/google-multi/compose.yml +++ b/integration/clusters/google-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "google"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/oidc-multi/compose.yml b/integration/clusters/oidc-multi/compose.yml index ac0a75538..64b162349 100644 --- a/integration/clusters/oidc-multi/compose.yml +++ b/integration/clusters/oidc-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "oidc"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/okta-multi/compose.yml b/integration/clusters/okta-multi/compose.yml index d8c9c8c82..ca8da821d 100644 --- a/integration/clusters/okta-multi/compose.yml +++ b/integration/clusters/okta-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "okta"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/onelogin-multi/compose.yml b/integration/clusters/onelogin-multi/compose.yml index cdc54c8eb..6b6ad9641 100644 --- a/integration/clusters/onelogin-multi/compose.yml +++ b/integration/clusters/onelogin-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "onelogin"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/clusters/ping-multi/compose.yml b/integration/clusters/ping-multi/compose.yml index 0876c7dc5..bb68d4268 100644 --- a/integration/clusters/ping-multi/compose.yml +++ b/integration/clusters/ping-multi/compose.yml @@ -153,6 +153,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -172,7 +173,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authenticate SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -211,6 +212,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lSQU5NalQzSmp2cEdtbjRUTzVPWUFyazh3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB4T1RBMk1ERXcKTURBd01EQmFGdzB6TVRFeE1UVXhPVEV4TlRWYU1Gc3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXdNQzRHQTFVRUN3d25ZMkZzWldKQVkyRnNaV0l0YkdGd2RHOXdMV3hwCmJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0MKQVFFQTlqUkR2Mkl5V1FaV3V1STkxdWdlbWF3R0RxK1BERUpUaVNDZ3ZhWWkwSEc0SEowNndwVjk4cDNTYWZVbgpwWU12ajlmY3lqbkJaOHlvcGU5VUQrakFSMVhEYmI1YlUvVU1iV3JkU29LWVM4a0dzYllDdDAzMHk4QWRaejY5CmI3Q2t2Y25IQUpPcDV4VXRYU1ExaEo3ZjQzZ29aaEdSbHJKU2cxSkpWKzJTTlUxMHNnM1V3YjNieGdBL1hrRk0KaUIzWnF2STRJNTh3RzBqakxVSEFmQ043eTFEQWFiVlNJQll6b1B5cjJxUUEvR0lHMWJsbzljWWdrRFlkb1d3UgpwZ21maHBLQ2NrNUxWZWdZejNBcSs4NkpPVGxHbWc5WlIxaUdNSEpNYklsUGJNdEU2MXovQjhtWUc5aUptUHJTCmYzNHVZVlJ4VDZTMkZWTkU1cDZVbHZXNHd3SURBUUFCbzNVd2N6QU9CZ05WSFE4QkFmOEVCQU1DQmFBd0V3WUQKVlIwbEJBd3dDZ1lJS3dZQkJRVUhBd0V3REFZRFZSMFRBUUgvQkFJd0FEQWZCZ05WSFNNRUdEQVdnQlNGaGxoWQpnRWZLVHBsVk9lbmVWRzMrM0lFL1RUQWRCZ05WSFJFRUZqQVVnaEp3YjIxbGNtbDFiUzFoZFhSb2IzSnBlbVV3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFESHNQT1p6WHh5eWMrZ1EwYkxSbG5WejNZMDV6cTNmV2gxeWp0U04KMmtQTFJ1aU02ZkZWUGlDV1VuUzk0cnNDeDV6Sk0xQnRNR3VNcUNMWGxmZERWYlZNcDM2d0NHMms5TWt3aE01dgpuTFRXTkkzclFZSUJnU0xvdFNTeTZYdUV5U1pJQlhUZ2RHODFYcG5pVjBUc1dKMjJEdGxlMlhOZUo1cHNnMS93CjdMbTZLdElkL3FEYUF5T1pLR1Y2Z21GL0YyNTB4RDkxYys3Mk9DUkFrK0x2WXhydFBVY3lwV0lNV2lMUEtlRkMKQnB6Q3BsNDB3c0o5YzVFMTdJcWNjMVVzanRwUnVXSlFRb0FBb3NhQ2RVUThXN04yMXdyNTcyTjFKcmNVOElBeAprN3U3T0Rrc24vK0NaODQ2N3dYclB5OXZGL3F2QkxtYWVFMWswd3VnTldlSnZNT0JLcGRKNG5iS0VCbU5xcmpMCmRRM21aTW90ZWNlelRDY29WYmRhdC9NVHNKR3hPSG42ZExoeHlKQzQ5K0FxbjJ2OGJ1ajZEbk56M3d3VHZxdXUKOGJEOW83SzlHdmRaaEtBNUxISmpFOXNkdmxzZVpNUnZqUGVnUDRWeWpaWmlBejBFUW04d292MHYvK2J5d2RUZgp5QjQ4eVJjSVdzdzZyU3BNdHR5ZU1neGJiQT09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -230,7 +232,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: authorize SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -268,6 +270,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVYekNDQXNlZ0F3SUJBZ0lRWDBCTFVEUmE0cHI3TFlueGRkYzRKREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEU1TURZd01UQXcKTURBd01Gb1hEVE14TVRFeE5URTVNVEl5TjFvd1d6RW5NQ1VHQTFVRUNoTWViV3RqWlhKMElHUmxkbVZzYjNCdApaVzUwSUdObGNuUnBabWxqWVhSbE1UQXdMZ1lEVlFRTERDZGpZV3hsWWtCallXeGxZaTFzWVhCMGIzQXRiR2x1CmRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNrd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFEYVhWcVp4MXNXLzREdTlBdTJnSjNsT2JubVlzQzhpV2JLSTJ4UWVrSWljc0NHMm5qYkVPejMza2FuL3VsaQpNbXh2TEF2UUcwTjhDU3djSzlhakFydHJvbE96S2NZajFmUzNmK25yRWZpa3NiemNHNFFiMDc0MUtlcTJLZFJkCllwR0E0TSs2Y0c0QTQvVnhDOWxnNU5UMDJXd2tYUlRUVWVjUWJIdTV5blEzcjR1MWk3R3RCb3RDODRQVGlFdXUKUVpEbFcxMUx2UjlTUW5ZenVZUmM0aG9QR1pKN1dBNE1jdlIxY3MyUHZWU3FOWjc4aGZDRGgyQ21mYUxGQVhxVgpSUk5sbUVlclMvWjQ1N3JnbHhrOTlKSlBrd1FTWm43KzBrcHJKMm9ubmRtUFpxN2JnT1FOdG13WFQ0cTRjSEFCCjFyTWRGTEdXODJqMGFnbmhMdXl4MEtuTkFnTUJBQUdqZGpCME1BNEdBMVVkRHdFQi93UUVBd0lGb0RBVEJnTlYKSFNVRUREQUtCZ2dyQmdFRkJRY0RBVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSVdHV0ZpQQpSOHBPbVZVNTZkNVViZjdjZ1Q5Tk1CNEdBMVVkRVFRWE1CV0NFM0J2YldWeWFYVnRMV1JoZEdGaWNtOXJaWEl3CkRRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFGSkovQzVRT3hBRnFxMXRjZDN5REdPbzB6V29NejBzZDZEZnQ1cVAKTXRaOWx5WTU4dnpZN1pIWEVwVzU2Mm9hYmpuRmRTMVYyZTFtTFM5ZGRFQkZIdzRxQm1hZmZHcFVQdzZkTndXawpCSmJVRUhXVFhvVmRaejhYMUExei9mUkNEY0NxRW50amZkUXo3NFkrZFZZcDhzQ215UmVIdy8rQ2tCMmtNblRZCmticzJBMUxpYnZ4ZUlrOVRmN0k0THZFbjNSRXZ1bjZjcSs4R1gvN1QxTm1KUS9sSkZjS0hrSXpvZFVBUTR4TUcKL29xUXFFalhHalM1cTRKMGNjVExDMlQ1Y0VsSDlHdnFwV3Q1L3RJSi96aTlFajl2UVROZVJ4Nllsc2RGNXA4OQpmbm9EWkZUb3BteXF3MGdySk5EN25mNU93R3BTNzlwN1NFcmUvWi9QTmlTSmdWNlU0L21IY25PVXk2UVk0SjBjClhqd2laK1J6cjlRam5DS2xPMEprNDI1U0J2Q0M2L0ZDcHViQ1JpSjViR0Rkd1k3bE9ydmNRV3R2NDJ1WUp4UEEKeG0yM0Q2WWowdjQrVWhNMWwvVURGdjlFcGgwSXdGM1I5Sk5WOGYvZUszM0VDc2QyQW5PWDkrTVljMG0weHRJMwpVMUYwM3czTlR5c2hKYXQ0ZHp4QytBbTBaZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K @@ -287,7 +290,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: databroker SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= @@ -325,6 +328,7 @@ services: wrongly-named-httpdetails-ready: condition: service_completed_successfully environment: + AUTHENTICATE_INTERNAL_SERVICE_URL: https://pomerium-authenticate AUTHENTICATE_SERVICE_URL: https://authenticate.localhost.pomerium.io AUTHORIZE_SERVICE_URL: https://pomerium-authorize:5443 CERTIFICATE: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUVVakNDQXJxZ0F3SUJBZ0lSQUtOYUVxQ21tWmZobWNZZ1p5MDFXQ3N3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1UQXgKTnpNeU1UQmFGdzB5TXpFeE1UQXhPRE15TVRCYU1GY3hKekFsQmdOVkJBb1RIbTFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCalpYSjBhV1pwWTJGMFpURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnCktFTmhiR1ZpSUVSdmVITmxlU2t3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRQzgKSExCQUl6WGtQZWVnbGRVZlJLSzJqUXhTVlpENWcrcXNqQXpwbXJxL0F0bXdlSzFjR2NPdFo2ZU9MK3A4YnJQRAp5VmhEVDBRbEkvTy9FS2dDT0ZGeFVEcW9SODJpWTA2U2FjQWpIbmk2K1BPOXRWUmJGVjB3MTRCREFKU3BCK1Z2Cld5bCtGb1BEVi92c1ozMUZ0WXcrRXdxa2JEeC9rYVQ5dXpmK0xKZGxrZjE0blFRajhFa3kvOGQzbVdKYmIvOXQKak9ic2FRZ0o1TEx4Q1lkSW1rcjc3WDJMTXVEdy8xdHBINjQyR0UyNU5yZ202UUhseUtTZllYbzM4djgzZWJFcQpiWlVERytaaW9BclBtcW1rYXdVV3czZWtoajgwU0pnL1RLOVBSYU4vVnZjSTFQZ0FkN0xaenRVUmVTbVR5NWhkCjlyNnJPQnhweHduVER2SGtCbjZ2QWdNQkFBR2piREJxTUE0R0ExVWREd0VCL3dRRUF3SUZvREFUQmdOVkhTVUUKRERBS0JnZ3JCZ0VGQlFjREFUQWZCZ05WSFNNRUdEQVdnQlNGaGxoWWdFZktUcGxWT2VuZVZHMyszSUUvVFRBaQpCZ05WSFJFRUd6QVpnaGNxTG14dlkyRnNhRzl6ZEM1d2IyMWxjbWwxYlM1cGJ6QU5CZ2txaGtpRzl3MEJBUXNGCkFBT0NBWUVBdWZRQUY3OXM3YzFnbVo5Q0lLQlNHa0hoK1NIMDFDdUtZbm5IaU1vd0hzVGlvRmFVQVFzZC9QNFgKYzJYQnFjMzRlVDNtQ3ZwZ1pqSGJqejZKbG5UWUp4dUx2VnFuVkIzZW10V3JiMWNRdmg4QnBoeHNwVGxTOHVpRQpBRWYvbmd0cHpmQS9mNGxwR2t6clEwY3lQa0VKR3o1MTFxOTdpdHpuOVJaWnpWVFp4TlZGU1AydlZoTk5RVnNXCk94YWtjdllSZ256OEFPUVMzT1BIajJGUWMzaWlic2hjdDVsZUl3WVpGY3hJTkdIUjZLTDYrL0xTZVBOQ0VNbUsKcXltVlBrUUdzSWNVNkdROWZ4YVN1NG1wK0lVQUxQcm9pekVWSThTVms1bk9tM0hJZXorWmZYaHpmbkd4MDZTSQo2TnVvUVFQcVVCZVplWG4yWUZZaGlwZVJkclF4dkEzNi9ZWGEvQWtYQ2VVMHBYeGJ0WEtjdmF0ZnJpNUtuWUpECmtINTlhK2FGa1RzbDQxdGZJMmNuUllWZGRxWFZsM096TGJjZ0FGTG4xV2VDMXh4M3hSWGk3S2xkb2tPbHZndisKQjZuYVdmQ3hSbFdaL2xzbUhhZTRrYzFXSDRLYzduSytJVGI0MEVralY2OC9BN2tyWnNOMVZjcU50cG9tWWtnRQp4alVFOFhVdQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg== @@ -344,7 +348,7 @@ services: IDP_PROVIDER_URL: https://mock-idp.localhost.pomerium.io/ JWT_CLAIMS_HEADERS: email,groups,user LOG_LEVEL: info - POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"host_rewrite": "authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] + POLICY: [
{
"allow_public_unauthenticated_access": true,
"from": "https://mock-idp.localhost.pomerium.io",
"preserve_host_header": true,
"to": "http://mock-idp:8024"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://envoy.localhost.pomerium.io",
"to": "http://localhost:9901"
},
{
"allow_any_authenticated_user": true,
"from": "https://verify.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://verify:80"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://websocket-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_any_authenticated_user": true,
"from": "https://fortio-ui.localhost.pomerium.io",
"to": "https://fortio:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://fortio-ping.localhost.pomerium.io",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUxekNDQXorZ0F3SUJBZ0lRWjEzOWNkL3BhUGRrUzJKeUF1N2tFREFOQmdrcWhraUc5dzBCQVFzRkFEQ0IKZ3pFZU1Cd0dBMVVFQ2hNVmJXdGpaWEowSUdSbGRtVnNiM0J0Wlc1MElFTkJNU3d3S2dZRFZRUUxEQ05qWVd4bApZa0JqWVd4bFlpMXdZeTFzYVc1MWVDQW9RMkZzWldJZ1JHOTRjMlY1S1RFek1ERUdBMVVFQXd3cWJXdGpaWEowCklHTmhiR1ZpUUdOaGJHVmlMWEJqTFd4cGJuVjRJQ2hEWVd4bFlpQkViM2h6WlhrcE1CNFhEVEl4TURneE1ERTMKTXpJd09Wb1hEVE14TURneE1ERTNNekl3T1Zvd2dZTXhIakFjQmdOVkJBb1RGVzFyWTJWeWRDQmtaWFpsYkc5dwpiV1Z1ZENCRFFURXNNQ29HQTFVRUN3d2pZMkZzWldKQVkyRnNaV0l0Y0dNdGJHbHVkWGdnS0VOaGJHVmlJRVJ2CmVITmxlU2t4TXpBeEJnTlZCQU1NS20xclkyVnlkQ0JqWVd4bFlrQmpZV3hsWWkxd1l5MXNhVzUxZUNBb1EyRnMKWldJZ1JHOTRjMlY1S1RDQ0FhSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnR1BBRENDQVlvQ2dnR0JBTmJLeU16NQpNVlc2WUtkamgxb0lOMU1uN1BFMnBINVNiSlNwV3hkQUdoZEJrQmtwQWE3T3hhcmpINUtWa0NUU2E3b25jbGE3CnFOdUpaUzZtQm1veEYrUitjUjNqeUdkVUFZbG96bDFqbGZxTElmQy8rZzdWN1ZtT0puOTh0akI0MmZhdHhMbDYKV1BBdzFKRE5zV3RRZmhLaGJjSHV0N1JzRjByTU9PSGN3eXdUUjdMT3lDbUllbDFwY21wVjRoYlZjVDZlVndvUApIWHlKU2E5Y3FhTVE1WHJkb2dhaTRJcVpaSUdMSGVMc1RWdXRPZ0pGWEVldmxYL1FUM3NXb21FY3R6aDM4SnM0CjlEaUFQRDZkNFk3L0NQTFlFZmsyOUpROU5aaHBnRHNpOWh1NUZISFpjWHdmMUlIbHcvQ0JWZ242aitqbXZLS3oKOTBNYTFvcXV2M1c2ZHR0aWQveENjTEd1MlMrOTZUenJ5a21veTVWYWNMdFZFUDQxWW1vVmxzOTFybG83b2xwZQpRV0Zibm1jbzczOVRJLzRoK0hvZG9scGVyUUVSUWw3dUNucEtWUFozV29rS3VSaDVwa3FrUXAvYXJRanR3Y1J0Ckc0M0NyRHBibCt1U2pNQ0F4aGE5NThlVFl2dG9qVE1udkx0c0dJRDFoR1hucWx3KzVLaktyZ1JIclFJREFRQUIKbzBVd1F6QU9CZ05WSFE4QkFmOEVCQU1DQWdRd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RQpGZ1FVaFlaWVdJQkh5azZaVlRucDNsUnQvdHlCUDAwd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dHQkFBMUYvYXByCmw2cE5UM01wL014aFVVZ282dXNFSkNyeUdRY0xSZmV4eVFYR04zaHVDbUlyUDU1VkZhOEVUUEF0anNyNlBNZTcKN3Z2RWo4ZUZ1Mkp0S292bFF3TmV3WVU5Y2pBTUNWYUZpTmJyUWEyMGh6aFdjMmpzNmR5aWxkRTYvRFB6YmVkcwpLREF4aEZOcDM1U2x3dFJ0S2sxU3p4SnhzcVN3amZ4SThmcCtSLzB3TzhnMGZXVGRNMmdDcFJ3WU1Od0pFTEVnCitkU2x2SkN3dXUrcnp4TGFsemFQRjFQTVRXNzJPRUxhbC9qNXNEKzJWeXRRNGsrSFVEYnl0MkRuUVQ3WVEzem8KcTAyeDJ1MnNtMVdXL28vdWg4cGpQeGtHUXFMMm1yeVpzNlZIOVZDVTNRa0tORHNzTmQ3MWxyM3dQb0U0WVJIZQpVdnpEMWVEZWVsekJVRk5JcERDamRDc0w1NXlJUHFVc3I2bG1qcEJQTDB2ZWEzM1FUTWJjc1N4dTB1bUdYRGJVCjY2anVVNFoxak9FMHdDbEl2YU82OTlKK0UyZ0JlMWpVTjZBdDZiOEJTb1pxQ3FYWW9ESEdlaTlSQlVkdmdxdG8Ka1Zzb0pmREkvVEZNZWtZZ3BMNVVWWW1MZGZncUxQUFJQOXBRQkxEeDNtc3plQXFudmZUSUNBemZYZz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "fortio-ping.localhost.pomerium.io",
"to": "https://fortio:8079"
},
{
"allow_any_authenticated_user": true,
"from": "tcp+https://redis.localhost.pomerium.io:6379",
"to": "tcp://redis:6379"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-enabled",
"tls_skip_verify": true,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-skip-verify-disabled",
"tls_skip_verify": false,
"to": "https://trusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-enabled",
"tls_server_name": "httpdetails.localhost.notpomerium.io",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-server-name-disabled",
"to": "https://wrongly-named-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-enabled",
"tls_custom_ca": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUUyRENDQTBDZ0F3SUJBZ0lSQUxkOUdhSlI5MnFpN3FMMWVIR002SzB3RFFZSktvWklodmNOQVFFTEJRQXcKZ1lNeEhqQWNCZ05WQkFvVEZXMXJZMlZ5ZENCa1pYWmxiRzl3YldWdWRDQkRRVEVzTUNvR0ExVUVDd3dqWTJGcwpaV0pBWTJGc1pXSXRjR010YkdsdWRYZ2dLRU5oYkdWaUlFUnZlSE5sZVNreE16QXhCZ05WQkFNTUttMXJZMlZ5CmRDQmpZV3hsWWtCallXeGxZaTF3WXkxc2FXNTFlQ0FvUTJGc1pXSWdSRzk0YzJWNUtUQWVGdzB5TVRBNE1URXkKTVRVMk1UQmFGdzB6TVRBNE1URXlNVFUyTVRCYU1JR0RNUjR3SEFZRFZRUUtFeFZ0YTJObGNuUWdaR1YyWld4dgpjRzFsYm5RZ1EwRXhMREFxQmdOVkJBc01JMk5oYkdWaVFHTmhiR1ZpTFhCakxXeHBiblY0SUNoRFlXeGxZaUJFCmIzaHpaWGtwTVRNd01RWURWUVFERENwdGEyTmxjblFnWTJGc1pXSkFZMkZzWldJdGNHTXRiR2x1ZFhnZ0tFTmgKYkdWaUlFUnZlSE5sZVNrd2dnR2lNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJqd0F3Z2dHS0FvSUJnUURXWXBWZQpCU25lZTJjQUJZb2ZTb1d4R015RmFNUTBuSmtZMFVXTTlja3lVaDdWZmdOKy9hRlNXMlpTbVh1djVkcmNwaTIwCnozZWxoUFRlOThiQU5iaisvYmkwMDE1UVduTWVuSzA1Wks2cUR0RndvL0hWQy9ZY2FydXU5NisxSjJ0b2VXdUUKdHlrVzNNQ3BDMXBIWVM1ZzlpVkRrcGRyem52WEtsWXVTaWtqcmo3SzV0b2lUdnVtOTdMeEtrdWo2RFhqYXBQRAo1dnRlU04xZFFnTzlDUzNzcWxjd1lBNlJqVUh3WTJWRWgyYWRQMzdCWnJad08reUpxOXFGNXk1R2xnaThsTjRjCktsSWxGVXMveFNwUXN4TmJOUVh0TjltazRpbVlsWkd6WVliYm0rZm9CVlBQYm9hNWpWd0tEcFo2NW1PczdKR1AKNnlqKzdWN1VCTUZwVytnS21KdGdoL2trQXgxODVoOTNxd0xGUGM4L1Q3bisrUDFidStmYWtYUEdQRTIxckRlTApQblVtdWNJWnBKbzVOcFlWUXY0V3ZUS3Evek1SOVNzcHoyUEZKbkVSVGZUdnErRjFxM1pOYWZFemlQc0I5b2VTCm5qeHdtYVpPU1YwdlhxL3Flb3F4NHY2TUJ6VkFZMC84UjJMY3BKNHVnME9aM3cwYjJ0NnlvODZQNVE4Q0F3RUEKQWFORk1FTXdEZ1lEVlIwUEFRSC9CQVFEQWdJRU1CSUdBMVVkRXdFQi93UUlNQVlCQWY4Q0FRQXdIUVlEVlIwTwpCQllFRkxjWThFb05vZk1jcnJ4enl4SW4zVzZaT01WWE1BMEdDU3FHU0liM0RRRUJDd1VBQTRJQmdRQ1p6REN2CktJSFgzR3ZqTlNZNXc1Yk9uNEUzdzdRSFAwOUFCalQvd3VUNExEa1pISk1tbHJMbzNzOGJjc1Ewc01EMVkvLy8KczA3Y3A0eFlscUQ3QkEwQWNwdllWWXE1OHhLeHNvQ3dWWG1HNWNFZU9vWm1XZjNxWTJtUzhlVzk2dk9GcmRJYgpMNE9GNHhZVU9NUnFBT0dBQXI2VmxPN2dYYTQwNkh6cnNBMWhZWndyZVhoT1RDWlpQWk9VbkF1MDVTSEZkZ2FNClRKTkIvbzAxdHB3UWxyVHhObWZyb3BvT3p5dXZIMHpVMlJyTXMwK0ViT3VDNEEyY1E4M0RJRnh2cTY3bHlVMEEKczFRNnRSTTArVURtSk9MejNTZGdOK0QwMGhjdXVqOTJHVjRiSDhCZnlVdjhOQ1kwdkRpajBUU2pqNGM0UXRjNwpJUExUWjJnNTQ1b2N6aE5nQW1UN2QrQjVJbnlmaVNJS2VtWHFlczJqcGlBZnpQTmw5QlZ4c2FrY3MvWXpvWXMxCitxVGpBV3VhRHNLb2hFbk80Qkp1enYweHJjZTQwZW5SZ1h5R0dGdlh1MnM0RlkydkpxVFNvNnlzRFduaEkzTFcKZGNnNk8yRjRBUENHR2U3enN1cWlxa3Bja25CYWJnekVzOWZvSHEybWZvN1hpRXplZE1OOEJOcWZTYkE9Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K",
"tls_server_name": "httpdetails.localhost.pomerium.io",
"to": "https://untrusted-httpdetails:8443"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"path": "/tls-custom-ca-disabled",
"to": "https://untrusted-httpdetails:8443"
},
{
"cors_allow_preflight": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-enabled",
"to": "http://trusted-httpdetails:8080"
},
{
"cors_allow_preflight": false,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/cors-disabled",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-enabled",
"preserve_host_header": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"prefix": "/preserve-host-header-disabled",
"preserve_host_header": false,
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://restricted-httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_domains": [
"dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-domain",
"to": "http://trusted-httpdetails:8080"
},
{
"allowed_users": [
"user1@dogs.test"
],
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"prefix": "/by-user",
"to": "http://trusted-httpdetails:8080"
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "ROUND_ROBIN",
"prefix": "/round-robin",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "RING_HASH",
"prefix": "/ring-hash",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_any_authenticated_user": true,
"from": "https://httpdetails.localhost.pomerium.io",
"lb_policy": "MAGLEV",
"prefix": "/maglev",
"to": [
"http://trusted-1-httpdetails:8080",
"http://trusted-2-httpdetails:8080",
"http://trusted-3-httpdetails:8080"
]
},
{
"allow_public_unauthenticated_access": true,
"from": "https://httpdetails.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"X-Custom-Request-Header": "custom-request-header-value"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"allow_websockets": true,
"from": "https://enabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://disabled-ws-echo.localhost.pomerium.io",
"to": "http://websocket-echo:80"
},
{
"allow_public_unauthenticated_access": true,
"enable_google_cloud_serverless_authentication": true,
"from": "https://cloudrun.localhost.pomerium.io",
"pass_identity_headers": true,
"set_request_headers": {
"x-idp": "ping"
},
"to": "http://trusted-httpdetails:8080"
},
{
"allow_public_unauthenticated_access": true,
"from": "https://authenticate.localhost.pomerium.io",
"tls_skip_verify": true,
"to": "https://pomerium-authenticate"
}
] SERVICES: proxy SHARED_SECRET: UYgnt8bxxK5G2sFaNzyqi5Z+OgF8m2akNc0xdQx718w= SIGNING_KEY: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBSR1d3TGg3NW5OWG5razM3ekRmTjhvbkx3ZkNpYUxQVEQrbmM4THg1aGNvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFa3BCa08wVEttaDRKZFFmTE9lZU1kNTNLbmdhMVdkUVhyNUZjZXBrK2RMVktkVkt4WENHcQpoMW9qdWh1VzExR0lvT3pTOUdvU0tsTlZTUkZXVkVXRHZ3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo= diff --git a/integration/tpl/backends/pomerium.libsonnet b/integration/tpl/backends/pomerium.libsonnet index f859302fa..1302d71ff 100644 --- a/integration/tpl/backends/pomerium.libsonnet +++ b/integration/tpl/backends/pomerium.libsonnet @@ -98,6 +98,7 @@ local Environment(mode, idp, dns_suffix) = SIGNING_KEY: std.base64(importstr '../files/signing-key.pem'), SIGNING_KEY_ALGORITHM: 'ES256', } + if mode == 'multi' then { + AUTHENTICATE_INTERNAL_SERVICE_URL: 'https://pomerium-authenticate', AUTHORIZE_SERVICE_URL: 'https://pomerium-authorize:5443', DATABROKER_SERVICE_URL: 'https://pomerium-databroker:5443', GRPC_ADDRESS: ':5443', diff --git a/integration/tpl/backends/routes.libsonnet b/integration/tpl/backends/routes.libsonnet index edf4a03d6..efed2e9d0 100644 --- a/integration/tpl/backends/routes.libsonnet +++ b/integration/tpl/backends/routes.libsonnet @@ -223,7 +223,6 @@ local Routes(mode, idp, dns_suffix) = from: 'https://authenticate.localhost.pomerium.io', to: 'https://pomerium-authenticate', allow_public_unauthenticated_access: true, - host_rewrite: 'authenticate.localhost.pomerium.io', tls_skip_verify: true, }, ] else []; diff --git a/internal/cmd/pomerium/pomerium.go b/internal/cmd/pomerium/pomerium.go index 5f6fb2bbb..851921b27 100644 --- a/internal/cmd/pomerium/pomerium.go +++ b/internal/cmd/pomerium/pomerium.go @@ -164,7 +164,7 @@ func setupAuthenticate(ctx context.Context, src config.Source, controlPlane *con return fmt.Errorf("error creating authenticate service: %w", err) } - authenticateURL, err := src.GetConfig().Options.GetAuthenticateURL() + authenticateURL, err := src.GetConfig().Options.GetInternalAuthenticateURL() if err != nil { return fmt.Errorf("error getting authenticate URL: %w", err) } diff --git a/pkg/grpc/cli/api.pb.go b/pkg/grpc/cli/api.pb.go new file mode 100644 index 000000000..5d83eaf06 --- /dev/null +++ b/pkg/grpc/cli/api.pb.go @@ -0,0 +1,1842 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// versions: +// protoc-gen-go v1.27.1 +// protoc v3.14.0 +// source: api.proto + +package cli + +import ( + context "context" + grpc "google.golang.org/grpc" + codes "google.golang.org/grpc/codes" + status "google.golang.org/grpc/status" + protoreflect "google.golang.org/protobuf/reflect/protoreflect" + protoimpl "google.golang.org/protobuf/runtime/protoimpl" + reflect "reflect" + sync "sync" +) + +const ( + // Verify that this generated code is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion) + // Verify that runtime/protoimpl is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20) +) + +type ExportRequest_Format int32 + +const ( + ExportRequest_EXPORT_FORMAT_UNDEFINED ExportRequest_Format = 0 + ExportRequest_EXPORT_FORMAT_JSON_COMPACT ExportRequest_Format = 1 + ExportRequest_EXPORT_FORMAT_JSON_PRETTY ExportRequest_Format = 2 +) + +// Enum value maps for ExportRequest_Format. +var ( + ExportRequest_Format_name = map[int32]string{ + 0: "EXPORT_FORMAT_UNDEFINED", + 1: "EXPORT_FORMAT_JSON_COMPACT", + 2: "EXPORT_FORMAT_JSON_PRETTY", + } + ExportRequest_Format_value = map[string]int32{ + "EXPORT_FORMAT_UNDEFINED": 0, + "EXPORT_FORMAT_JSON_COMPACT": 1, + "EXPORT_FORMAT_JSON_PRETTY": 2, + } +) + +func (x ExportRequest_Format) Enum() *ExportRequest_Format { + p := new(ExportRequest_Format) + *p = x + return p +} + +func (x ExportRequest_Format) String() string { + return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) +} + +func (ExportRequest_Format) Descriptor() protoreflect.EnumDescriptor { + return file_api_proto_enumTypes[0].Descriptor() +} + +func (ExportRequest_Format) Type() protoreflect.EnumType { + return &file_api_proto_enumTypes[0] +} + +func (x ExportRequest_Format) Number() protoreflect.EnumNumber { + return protoreflect.EnumNumber(x) +} + +// Deprecated: Use ExportRequest_Format.Descriptor instead. +func (ExportRequest_Format) EnumDescriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{4, 0} +} + +type ConnectionStatusUpdates_ConnectionStatus int32 + +const ( + ConnectionStatusUpdates_CONNECTION_STATUS_UNDEFINED ConnectionStatusUpdates_ConnectionStatus = 0 + ConnectionStatusUpdates_CONNECTION_STATUS_CONNECTING ConnectionStatusUpdates_ConnectionStatus = 1 + ConnectionStatusUpdates_CONNECTION_STATUS_AUTH_REQUIRED ConnectionStatusUpdates_ConnectionStatus = 2 + ConnectionStatusUpdates_CONNECTION_STATUS_CONNECTED ConnectionStatusUpdates_ConnectionStatus = 3 + ConnectionStatusUpdates_CONNECTION_STATUS_DISCONNECTED ConnectionStatusUpdates_ConnectionStatus = 4 +) + +// Enum value maps for ConnectionStatusUpdates_ConnectionStatus. +var ( + ConnectionStatusUpdates_ConnectionStatus_name = map[int32]string{ + 0: "CONNECTION_STATUS_UNDEFINED", + 1: "CONNECTION_STATUS_CONNECTING", + 2: "CONNECTION_STATUS_AUTH_REQUIRED", + 3: "CONNECTION_STATUS_CONNECTED", + 4: "CONNECTION_STATUS_DISCONNECTED", + } + ConnectionStatusUpdates_ConnectionStatus_value = map[string]int32{ + "CONNECTION_STATUS_UNDEFINED": 0, + "CONNECTION_STATUS_CONNECTING": 1, + "CONNECTION_STATUS_AUTH_REQUIRED": 2, + "CONNECTION_STATUS_CONNECTED": 3, + "CONNECTION_STATUS_DISCONNECTED": 4, + } +) + +func (x ConnectionStatusUpdates_ConnectionStatus) Enum() *ConnectionStatusUpdates_ConnectionStatus { + p := new(ConnectionStatusUpdates_ConnectionStatus) + *p = x + return p +} + +func (x ConnectionStatusUpdates_ConnectionStatus) String() string { + return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) +} + +func (ConnectionStatusUpdates_ConnectionStatus) Descriptor() protoreflect.EnumDescriptor { + return file_api_proto_enumTypes[1].Descriptor() +} + +func (ConnectionStatusUpdates_ConnectionStatus) Type() protoreflect.EnumType { + return &file_api_proto_enumTypes[1] +} + +func (x ConnectionStatusUpdates_ConnectionStatus) Number() protoreflect.EnumNumber { + return protoreflect.EnumNumber(x) +} + +// Deprecated: Use ConnectionStatusUpdates_ConnectionStatus.Descriptor instead. +func (ConnectionStatusUpdates_ConnectionStatus) EnumDescriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{11, 0} +} + +type Record struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // if omitted, a new record would be created + Id *string `protobuf:"bytes,1,opt,name=id,proto3,oneof" json:"id,omitempty"` + Tags []string `protobuf:"bytes,2,rep,name=tags,proto3" json:"tags,omitempty"` + // connection data may be omitted if i.e. just manipulating the tags data + Conn *Connection `protobuf:"bytes,3,opt,name=conn,proto3,oneof" json:"conn,omitempty"` +} + +func (x *Record) Reset() { + *x = Record{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[0] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *Record) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*Record) ProtoMessage() {} + +func (x *Record) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[0] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use Record.ProtoReflect.Descriptor instead. +func (*Record) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{0} +} + +func (x *Record) GetId() string { + if x != nil && x.Id != nil { + return *x.Id + } + return "" +} + +func (x *Record) GetTags() []string { + if x != nil { + return x.Tags + } + return nil +} + +func (x *Record) GetConn() *Connection { + if x != nil { + return x.Conn + } + return nil +} + +type Selector struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // Types that are assignable to Filter: + // *Selector_All + // *Selector_Tag + // *Selector_IdFilter_ + Filter isSelector_Filter `protobuf_oneof:"filter"` +} + +func (x *Selector) Reset() { + *x = Selector{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[1] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *Selector) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*Selector) ProtoMessage() {} + +func (x *Selector) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[1] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use Selector.ProtoReflect.Descriptor instead. +func (*Selector) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{1} +} + +func (m *Selector) GetFilter() isSelector_Filter { + if m != nil { + return m.Filter + } + return nil +} + +func (x *Selector) GetAll() bool { + if x, ok := x.GetFilter().(*Selector_All); ok { + return x.All + } + return false +} + +func (x *Selector) GetTag() *Selector_TagFilter { + if x, ok := x.GetFilter().(*Selector_Tag); ok { + return x.Tag + } + return nil +} + +func (x *Selector) GetIdFilter() *Selector_IdFilter { + if x, ok := x.GetFilter().(*Selector_IdFilter_); ok { + return x.IdFilter + } + return nil +} + +type isSelector_Filter interface { + isSelector_Filter() +} + +type Selector_All struct { + // all records + All bool `protobuf:"varint,1,opt,name=all,proto3,oneof"` +} + +type Selector_Tag struct { + // only return connections matching tag(s) + Tag *Selector_TagFilter `protobuf:"bytes,2,opt,name=tag,proto3,oneof"` +} + +type Selector_IdFilter_ struct { + // only return specific connection(s) + IdFilter *Selector_IdFilter `protobuf:"bytes,3,opt,name=id_filter,json=idFilter,proto3,oneof"` +} + +func (*Selector_All) isSelector_Filter() {} + +func (*Selector_Tag) isSelector_Filter() {} + +func (*Selector_IdFilter_) isSelector_Filter() {} + +type ListRecordsResponse struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Records []*Record `protobuf:"bytes,1,rep,name=records,proto3" json:"records,omitempty"` +} + +func (x *ListRecordsResponse) Reset() { + *x = ListRecordsResponse{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[2] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ListRecordsResponse) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ListRecordsResponse) ProtoMessage() {} + +func (x *ListRecordsResponse) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[2] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ListRecordsResponse.ProtoReflect.Descriptor instead. +func (*ListRecordsResponse) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{2} +} + +func (x *ListRecordsResponse) GetRecords() []*Record { + if x != nil { + return x.Records + } + return nil +} + +type DeleteRecordsResponse struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *DeleteRecordsResponse) Reset() { + *x = DeleteRecordsResponse{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[3] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *DeleteRecordsResponse) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*DeleteRecordsResponse) ProtoMessage() {} + +func (x *DeleteRecordsResponse) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[3] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use DeleteRecordsResponse.ProtoReflect.Descriptor instead. +func (*DeleteRecordsResponse) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{3} +} + +// Export dumps configuration (or subset of, based on provided tag filter) +// in the JSON format +type ExportRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Selector *Selector `protobuf:"bytes,1,opt,name=selector,proto3" json:"selector,omitempty"` + // remove_tags to strip tags from output + RemoveTags bool `protobuf:"varint,2,opt,name=remove_tags,json=removeTags,proto3" json:"remove_tags,omitempty"` + Format ExportRequest_Format `protobuf:"varint,3,opt,name=format,proto3,enum=pomerium.cli.ExportRequest_Format" json:"format,omitempty"` +} + +func (x *ExportRequest) Reset() { + *x = ExportRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[4] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ExportRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ExportRequest) ProtoMessage() {} + +func (x *ExportRequest) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[4] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ExportRequest.ProtoReflect.Descriptor instead. +func (*ExportRequest) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{4} +} + +func (x *ExportRequest) GetSelector() *Selector { + if x != nil { + return x.Selector + } + return nil +} + +func (x *ExportRequest) GetRemoveTags() bool { + if x != nil { + return x.RemoveTags + } + return false +} + +func (x *ExportRequest) GetFormat() ExportRequest_Format { + if x != nil { + return x.Format + } + return ExportRequest_EXPORT_FORMAT_UNDEFINED +} + +type ConfigData struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Data []byte `protobuf:"bytes,1,opt,name=data,proto3" json:"data,omitempty"` +} + +func (x *ConfigData) Reset() { + *x = ConfigData{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[5] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ConfigData) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ConfigData) ProtoMessage() {} + +func (x *ConfigData) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[5] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ConfigData.ProtoReflect.Descriptor instead. +func (*ConfigData) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{5} +} + +func (x *ConfigData) GetData() []byte { + if x != nil { + return x.Data + } + return nil +} + +// ImportRequest would consume the previously exported data back, +// merging it with existing configuration, +// and performing de-duplication of the records so that multiple imports would +// yield the same result +type ImportRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // if set, all connections would receive that tag instead + OverrideTag *string `protobuf:"bytes,1,opt,name=override_tag,json=overrideTag,proto3,oneof" json:"override_tag,omitempty"` + Data []byte `protobuf:"bytes,2,opt,name=data,proto3" json:"data,omitempty"` +} + +func (x *ImportRequest) Reset() { + *x = ImportRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[6] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ImportRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ImportRequest) ProtoMessage() {} + +func (x *ImportRequest) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[6] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ImportRequest.ProtoReflect.Descriptor instead. +func (*ImportRequest) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{6} +} + +func (x *ImportRequest) GetOverrideTag() string { + if x != nil && x.OverrideTag != nil { + return *x.OverrideTag + } + return "" +} + +func (x *ImportRequest) GetData() []byte { + if x != nil { + return x.Data + } + return nil +} + +type ImportResponse struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *ImportResponse) Reset() { + *x = ImportResponse{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[7] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ImportResponse) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ImportResponse) ProtoMessage() {} + +func (x *ImportResponse) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[7] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ImportResponse.ProtoReflect.Descriptor instead. +func (*ImportResponse) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{7} +} + +type ListenerUpdateRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // omit connection ids to connect all connections + ConnectionIds []string `protobuf:"bytes,1,rep,name=connection_ids,json=connectionIds,proto3" json:"connection_ids,omitempty"` + Connected bool `protobuf:"varint,2,opt,name=connected,proto3" json:"connected,omitempty"` +} + +func (x *ListenerUpdateRequest) Reset() { + *x = ListenerUpdateRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[8] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ListenerUpdateRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ListenerUpdateRequest) ProtoMessage() {} + +func (x *ListenerUpdateRequest) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[8] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ListenerUpdateRequest.ProtoReflect.Descriptor instead. +func (*ListenerUpdateRequest) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{8} +} + +func (x *ListenerUpdateRequest) GetConnectionIds() []string { + if x != nil { + return x.ConnectionIds + } + return nil +} + +func (x *ListenerUpdateRequest) GetConnected() bool { + if x != nil { + return x.Connected + } + return false +} + +type ListenerStatus struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // active listeners with their current ports + Active map[string]uint32 `protobuf:"bytes,1,rep,name=active,proto3" json:"active,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"varint,2,opt,name=value,proto3"` + // if some listeners were unable to start up + Errors map[string]string `protobuf:"bytes,2,rep,name=errors,proto3" json:"errors,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` +} + +func (x *ListenerStatus) Reset() { + *x = ListenerStatus{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[9] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ListenerStatus) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ListenerStatus) ProtoMessage() {} + +func (x *ListenerStatus) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[9] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ListenerStatus.ProtoReflect.Descriptor instead. +func (*ListenerStatus) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{9} +} + +func (x *ListenerStatus) GetActive() map[string]uint32 { + if x != nil { + return x.Active + } + return nil +} + +func (x *ListenerStatus) GetErrors() map[string]string { + if x != nil { + return x.Errors + } + return nil +} + +type StatusUpdatesRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *StatusUpdatesRequest) Reset() { + *x = StatusUpdatesRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[10] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *StatusUpdatesRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*StatusUpdatesRequest) ProtoMessage() {} + +func (x *StatusUpdatesRequest) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[10] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use StatusUpdatesRequest.ProtoReflect.Descriptor instead. +func (*StatusUpdatesRequest) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{10} +} + +// ConnectionStatusUpdates represent connection state changes +type ConnectionStatusUpdates struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // record this event relates to + Id string `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"` + // peer_addr represents connecting party remote address and may be used to + // distinguish between individual TCP connections + PeerAddr string `protobuf:"bytes,2,opt,name=peer_addr,json=peerAddr,proto3" json:"peer_addr,omitempty"` + Status ConnectionStatusUpdates_ConnectionStatus `protobuf:"varint,3,opt,name=status,proto3,enum=pomerium.cli.ConnectionStatusUpdates_ConnectionStatus" json:"status,omitempty"` + // in case the connection failed or terminated, last error may be available + LastError *string `protobuf:"bytes,4,opt,name=last_error,json=lastError,proto3,oneof" json:"last_error,omitempty"` +} + +func (x *ConnectionStatusUpdates) Reset() { + *x = ConnectionStatusUpdates{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[11] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ConnectionStatusUpdates) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ConnectionStatusUpdates) ProtoMessage() {} + +func (x *ConnectionStatusUpdates) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[11] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ConnectionStatusUpdates.ProtoReflect.Descriptor instead. +func (*ConnectionStatusUpdates) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{11} +} + +func (x *ConnectionStatusUpdates) GetId() string { + if x != nil { + return x.Id + } + return "" +} + +func (x *ConnectionStatusUpdates) GetPeerAddr() string { + if x != nil { + return x.PeerAddr + } + return "" +} + +func (x *ConnectionStatusUpdates) GetStatus() ConnectionStatusUpdates_ConnectionStatus { + if x != nil { + return x.Status + } + return ConnectionStatusUpdates_CONNECTION_STATUS_UNDEFINED +} + +func (x *ConnectionStatusUpdates) GetLastError() string { + if x != nil && x.LastError != nil { + return *x.LastError + } + return "" +} + +// Connection +type Connection struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // name is a user friendly connection name that a user may define + Name *string `protobuf:"bytes,1,opt,name=name,proto3,oneof" json:"name,omitempty"` + // remote_addr is a remote pomerium host:port + RemoteAddr string `protobuf:"bytes,2,opt,name=remote_addr,json=remoteAddr,proto3" json:"remote_addr,omitempty"` + // listen_address, if not provided, will assign a random port each time + ListenAddr *string `protobuf:"bytes,3,opt,name=listen_addr,json=listenAddr,proto3,oneof" json:"listen_addr,omitempty"` + // the URL of the pomerium server to connect to + PomeriumUrl *string `protobuf:"bytes,4,opt,name=pomerium_url,json=pomeriumUrl,proto3,oneof" json:"pomerium_url,omitempty"` + // Types that are assignable to TlsOptions: + // *Connection_DisableTlsVerification + // *Connection_CaCert + TlsOptions isConnection_TlsOptions `protobuf_oneof:"tls_options"` +} + +func (x *Connection) Reset() { + *x = Connection{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[12] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *Connection) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*Connection) ProtoMessage() {} + +func (x *Connection) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[12] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use Connection.ProtoReflect.Descriptor instead. +func (*Connection) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{12} +} + +func (x *Connection) GetName() string { + if x != nil && x.Name != nil { + return *x.Name + } + return "" +} + +func (x *Connection) GetRemoteAddr() string { + if x != nil { + return x.RemoteAddr + } + return "" +} + +func (x *Connection) GetListenAddr() string { + if x != nil && x.ListenAddr != nil { + return *x.ListenAddr + } + return "" +} + +func (x *Connection) GetPomeriumUrl() string { + if x != nil && x.PomeriumUrl != nil { + return *x.PomeriumUrl + } + return "" +} + +func (m *Connection) GetTlsOptions() isConnection_TlsOptions { + if m != nil { + return m.TlsOptions + } + return nil +} + +func (x *Connection) GetDisableTlsVerification() bool { + if x, ok := x.GetTlsOptions().(*Connection_DisableTlsVerification); ok { + return x.DisableTlsVerification + } + return false +} + +func (x *Connection) GetCaCert() []byte { + if x, ok := x.GetTlsOptions().(*Connection_CaCert); ok { + return x.CaCert + } + return nil +} + +type isConnection_TlsOptions interface { + isConnection_TlsOptions() +} + +type Connection_DisableTlsVerification struct { + DisableTlsVerification bool `protobuf:"varint,5,opt,name=disable_tls_verification,json=disableTlsVerification,proto3,oneof"` +} + +type Connection_CaCert struct { + CaCert []byte `protobuf:"bytes,6,opt,name=ca_cert,json=caCert,proto3,oneof"` +} + +func (*Connection_DisableTlsVerification) isConnection_TlsOptions() {} + +func (*Connection_CaCert) isConnection_TlsOptions() {} + +type Selector_IdFilter struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Ids []string `protobuf:"bytes,1,rep,name=ids,proto3" json:"ids,omitempty"` +} + +func (x *Selector_IdFilter) Reset() { + *x = Selector_IdFilter{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[13] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *Selector_IdFilter) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*Selector_IdFilter) ProtoMessage() {} + +func (x *Selector_IdFilter) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[13] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use Selector_IdFilter.ProtoReflect.Descriptor instead. +func (*Selector_IdFilter) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{1, 0} +} + +func (x *Selector_IdFilter) GetIds() []string { + if x != nil { + return x.Ids + } + return nil +} + +type Selector_TagFilter struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Tags []string `protobuf:"bytes,2,rep,name=tags,proto3" json:"tags,omitempty"` +} + +func (x *Selector_TagFilter) Reset() { + *x = Selector_TagFilter{} + if protoimpl.UnsafeEnabled { + mi := &file_api_proto_msgTypes[14] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *Selector_TagFilter) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*Selector_TagFilter) ProtoMessage() {} + +func (x *Selector_TagFilter) ProtoReflect() protoreflect.Message { + mi := &file_api_proto_msgTypes[14] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use Selector_TagFilter.ProtoReflect.Descriptor instead. +func (*Selector_TagFilter) Descriptor() ([]byte, []int) { + return file_api_proto_rawDescGZIP(), []int{1, 1} +} + +func (x *Selector_TagFilter) GetTags() []string { + if x != nil { + return x.Tags + } + return nil +} + +var File_api_proto protoreflect.FileDescriptor + +var file_api_proto_rawDesc = []byte{ + 0x0a, 0x09, 0x61, 0x70, 0x69, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x0c, 0x70, 0x6f, 0x6d, + 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x22, 0x74, 0x0a, 0x06, 0x52, 0x65, 0x63, + 0x6f, 0x72, 0x64, 0x12, 0x13, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x48, + 0x00, 0x52, 0x02, 0x69, 0x64, 0x88, 0x01, 0x01, 0x12, 0x12, 0x0a, 0x04, 0x74, 0x61, 0x67, 0x73, + 0x18, 0x02, 0x20, 0x03, 0x28, 0x09, 0x52, 0x04, 0x74, 0x61, 0x67, 0x73, 0x12, 0x31, 0x0a, 0x04, + 0x63, 0x6f, 0x6e, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x18, 0x2e, 0x70, 0x6f, 0x6d, + 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, + 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x01, 0x52, 0x04, 0x63, 0x6f, 0x6e, 0x6e, 0x88, 0x01, 0x01, 0x42, + 0x05, 0x0a, 0x03, 0x5f, 0x69, 0x64, 0x42, 0x07, 0x0a, 0x05, 0x5f, 0x63, 0x6f, 0x6e, 0x6e, 0x22, + 0xdd, 0x01, 0x0a, 0x08, 0x53, 0x65, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x12, 0x12, 0x0a, 0x03, + 0x61, 0x6c, 0x6c, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x48, 0x00, 0x52, 0x03, 0x61, 0x6c, 0x6c, + 0x12, 0x34, 0x0a, 0x03, 0x74, 0x61, 0x67, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x20, 0x2e, + 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x53, 0x65, 0x6c, + 0x65, 0x63, 0x74, 0x6f, 0x72, 0x2e, 0x54, 0x61, 0x67, 0x46, 0x69, 0x6c, 0x74, 0x65, 0x72, 0x48, + 0x00, 0x52, 0x03, 0x74, 0x61, 0x67, 0x12, 0x3e, 0x0a, 0x09, 0x69, 0x64, 0x5f, 0x66, 0x69, 0x6c, + 0x74, 0x65, 0x72, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x70, 0x6f, 0x6d, 0x65, + 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x53, 0x65, 0x6c, 0x65, 0x63, 0x74, 0x6f, + 0x72, 0x2e, 0x49, 0x64, 0x46, 0x69, 0x6c, 0x74, 0x65, 0x72, 0x48, 0x00, 0x52, 0x08, 0x69, 0x64, + 0x46, 0x69, 0x6c, 0x74, 0x65, 0x72, 0x1a, 0x1c, 0x0a, 0x08, 0x49, 0x64, 0x46, 0x69, 0x6c, 0x74, + 0x65, 0x72, 0x12, 0x10, 0x0a, 0x03, 0x69, 0x64, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x09, 0x52, + 0x03, 0x69, 0x64, 0x73, 0x1a, 0x1f, 0x0a, 0x09, 0x54, 0x61, 0x67, 0x46, 0x69, 0x6c, 0x74, 0x65, + 0x72, 0x12, 0x12, 0x0a, 0x04, 0x74, 0x61, 0x67, 0x73, 0x18, 0x02, 0x20, 0x03, 0x28, 0x09, 0x52, + 0x04, 0x74, 0x61, 0x67, 0x73, 0x42, 0x08, 0x0a, 0x06, 0x66, 0x69, 0x6c, 0x74, 0x65, 0x72, 0x22, + 0x45, 0x0a, 0x13, 0x4c, 0x69, 0x73, 0x74, 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x73, 0x52, 0x65, + 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2e, 0x0a, 0x07, 0x72, 0x65, 0x63, 0x6f, 0x72, 0x64, + 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x14, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, + 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x52, 0x07, 0x72, + 0x65, 0x63, 0x6f, 0x72, 0x64, 0x73, 0x22, 0x17, 0x0a, 0x15, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, + 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, + 0x86, 0x02, 0x0a, 0x0d, 0x45, 0x78, 0x70, 0x6f, 0x72, 0x74, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, + 0x74, 0x12, 0x32, 0x0a, 0x08, 0x73, 0x65, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x18, 0x01, 0x20, + 0x01, 0x28, 0x0b, 0x32, 0x16, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, + 0x6c, 0x69, 0x2e, 0x53, 0x65, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x52, 0x08, 0x73, 0x65, 0x6c, + 0x65, 0x63, 0x74, 0x6f, 0x72, 0x12, 0x1f, 0x0a, 0x0b, 0x72, 0x65, 0x6d, 0x6f, 0x76, 0x65, 0x5f, + 0x74, 0x61, 0x67, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x0a, 0x72, 0x65, 0x6d, 0x6f, + 0x76, 0x65, 0x54, 0x61, 0x67, 0x73, 0x12, 0x3a, 0x0a, 0x06, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, + 0x18, 0x03, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x22, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, + 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x45, 0x78, 0x70, 0x6f, 0x72, 0x74, 0x52, 0x65, 0x71, 0x75, + 0x65, 0x73, 0x74, 0x2e, 0x46, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x52, 0x06, 0x66, 0x6f, 0x72, 0x6d, + 0x61, 0x74, 0x22, 0x64, 0x0a, 0x06, 0x46, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x12, 0x1b, 0x0a, 0x17, + 0x45, 0x58, 0x50, 0x4f, 0x52, 0x54, 0x5f, 0x46, 0x4f, 0x52, 0x4d, 0x41, 0x54, 0x5f, 0x55, 0x4e, + 0x44, 0x45, 0x46, 0x49, 0x4e, 0x45, 0x44, 0x10, 0x00, 0x12, 0x1e, 0x0a, 0x1a, 0x45, 0x58, 0x50, + 0x4f, 0x52, 0x54, 0x5f, 0x46, 0x4f, 0x52, 0x4d, 0x41, 0x54, 0x5f, 0x4a, 0x53, 0x4f, 0x4e, 0x5f, + 0x43, 0x4f, 0x4d, 0x50, 0x41, 0x43, 0x54, 0x10, 0x01, 0x12, 0x1d, 0x0a, 0x19, 0x45, 0x58, 0x50, + 0x4f, 0x52, 0x54, 0x5f, 0x46, 0x4f, 0x52, 0x4d, 0x41, 0x54, 0x5f, 0x4a, 0x53, 0x4f, 0x4e, 0x5f, + 0x50, 0x52, 0x45, 0x54, 0x54, 0x59, 0x10, 0x02, 0x22, 0x20, 0x0a, 0x0a, 0x43, 0x6f, 0x6e, 0x66, + 0x69, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x12, 0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x18, 0x01, + 0x20, 0x01, 0x28, 0x0c, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0x5c, 0x0a, 0x0d, 0x49, 0x6d, + 0x70, 0x6f, 0x72, 0x74, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x26, 0x0a, 0x0c, 0x6f, + 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, 0x65, 0x5f, 0x74, 0x61, 0x67, 0x18, 0x01, 0x20, 0x01, 0x28, + 0x09, 0x48, 0x00, 0x52, 0x0b, 0x6f, 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, 0x65, 0x54, 0x61, 0x67, + 0x88, 0x01, 0x01, 0x12, 0x12, 0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, + 0x0c, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x6f, 0x76, 0x65, 0x72, + 0x72, 0x69, 0x64, 0x65, 0x5f, 0x74, 0x61, 0x67, 0x22, 0x10, 0x0a, 0x0e, 0x49, 0x6d, 0x70, 0x6f, + 0x72, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x5c, 0x0a, 0x15, 0x4c, 0x69, + 0x73, 0x74, 0x65, 0x6e, 0x65, 0x72, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x52, 0x65, 0x71, 0x75, + 0x65, 0x73, 0x74, 0x12, 0x25, 0x0a, 0x0e, 0x63, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, + 0x6e, 0x5f, 0x69, 0x64, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x09, 0x52, 0x0d, 0x63, 0x6f, 0x6e, + 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x49, 0x64, 0x73, 0x12, 0x1c, 0x0a, 0x09, 0x63, 0x6f, + 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x65, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x09, 0x63, + 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x65, 0x64, 0x22, 0x8a, 0x02, 0x0a, 0x0e, 0x4c, 0x69, 0x73, + 0x74, 0x65, 0x6e, 0x65, 0x72, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x12, 0x40, 0x0a, 0x06, 0x61, + 0x63, 0x74, 0x69, 0x76, 0x65, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x28, 0x2e, 0x70, 0x6f, + 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x4c, 0x69, 0x73, 0x74, 0x65, + 0x6e, 0x65, 0x72, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x2e, 0x41, 0x63, 0x74, 0x69, 0x76, 0x65, + 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x06, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x12, 0x40, 0x0a, + 0x06, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x73, 0x18, 0x02, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x28, 0x2e, + 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x4c, 0x69, 0x73, + 0x74, 0x65, 0x6e, 0x65, 0x72, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x2e, 0x45, 0x72, 0x72, 0x6f, + 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x06, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x73, 0x1a, + 0x39, 0x0a, 0x0b, 0x41, 0x63, 0x74, 0x69, 0x76, 0x65, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, + 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, + 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0d, 0x52, + 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x1a, 0x39, 0x0a, 0x0b, 0x45, 0x72, + 0x72, 0x6f, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, + 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, + 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, + 0x65, 0x3a, 0x02, 0x38, 0x01, 0x22, 0x16, 0x0a, 0x14, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x55, + 0x70, 0x64, 0x61, 0x74, 0x65, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x22, 0x8b, 0x03, + 0x0a, 0x17, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x53, 0x74, 0x61, 0x74, + 0x75, 0x73, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x73, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, + 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x02, 0x69, 0x64, 0x12, 0x1b, 0x0a, 0x09, 0x70, 0x65, 0x65, + 0x72, 0x5f, 0x61, 0x64, 0x64, 0x72, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x08, 0x70, 0x65, + 0x65, 0x72, 0x41, 0x64, 0x64, 0x72, 0x12, 0x4e, 0x0a, 0x06, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, + 0x18, 0x03, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x36, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, + 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, + 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x73, 0x2e, 0x43, 0x6f, + 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x52, 0x06, + 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x12, 0x22, 0x0a, 0x0a, 0x6c, 0x61, 0x73, 0x74, 0x5f, 0x65, + 0x72, 0x72, 0x6f, 0x72, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x48, 0x00, 0x52, 0x09, 0x6c, 0x61, + 0x73, 0x74, 0x45, 0x72, 0x72, 0x6f, 0x72, 0x88, 0x01, 0x01, 0x22, 0xbf, 0x01, 0x0a, 0x10, 0x43, + 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x12, + 0x1f, 0x0a, 0x1b, 0x43, 0x4f, 0x4e, 0x4e, 0x45, 0x43, 0x54, 0x49, 0x4f, 0x4e, 0x5f, 0x53, 0x54, + 0x41, 0x54, 0x55, 0x53, 0x5f, 0x55, 0x4e, 0x44, 0x45, 0x46, 0x49, 0x4e, 0x45, 0x44, 0x10, 0x00, + 0x12, 0x20, 0x0a, 0x1c, 0x43, 0x4f, 0x4e, 0x4e, 0x45, 0x43, 0x54, 0x49, 0x4f, 0x4e, 0x5f, 0x53, + 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x43, 0x4f, 0x4e, 0x4e, 0x45, 0x43, 0x54, 0x49, 0x4e, 0x47, + 0x10, 0x01, 0x12, 0x23, 0x0a, 0x1f, 0x43, 0x4f, 0x4e, 0x4e, 0x45, 0x43, 0x54, 0x49, 0x4f, 0x4e, + 0x5f, 0x53, 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x41, 0x55, 0x54, 0x48, 0x5f, 0x52, 0x45, 0x51, + 0x55, 0x49, 0x52, 0x45, 0x44, 0x10, 0x02, 0x12, 0x1f, 0x0a, 0x1b, 0x43, 0x4f, 0x4e, 0x4e, 0x45, + 0x43, 0x54, 0x49, 0x4f, 0x4e, 0x5f, 0x53, 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x43, 0x4f, 0x4e, + 0x4e, 0x45, 0x43, 0x54, 0x45, 0x44, 0x10, 0x03, 0x12, 0x22, 0x0a, 0x1e, 0x43, 0x4f, 0x4e, 0x4e, + 0x45, 0x43, 0x54, 0x49, 0x4f, 0x4e, 0x5f, 0x53, 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x44, 0x49, + 0x53, 0x43, 0x4f, 0x4e, 0x4e, 0x45, 0x43, 0x54, 0x45, 0x44, 0x10, 0x04, 0x42, 0x0d, 0x0a, 0x0b, + 0x5f, 0x6c, 0x61, 0x73, 0x74, 0x5f, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x22, 0xa4, 0x02, 0x0a, 0x0a, + 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x17, 0x0a, 0x04, 0x6e, 0x61, + 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x48, 0x01, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, + 0x88, 0x01, 0x01, 0x12, 0x1f, 0x0a, 0x0b, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x5f, 0x61, 0x64, + 0x64, 0x72, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, + 0x41, 0x64, 0x64, 0x72, 0x12, 0x24, 0x0a, 0x0b, 0x6c, 0x69, 0x73, 0x74, 0x65, 0x6e, 0x5f, 0x61, + 0x64, 0x64, 0x72, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x48, 0x02, 0x52, 0x0a, 0x6c, 0x69, 0x73, + 0x74, 0x65, 0x6e, 0x41, 0x64, 0x64, 0x72, 0x88, 0x01, 0x01, 0x12, 0x26, 0x0a, 0x0c, 0x70, 0x6f, + 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, + 0x48, 0x03, 0x52, 0x0b, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x55, 0x72, 0x6c, 0x88, + 0x01, 0x01, 0x12, 0x3a, 0x0a, 0x18, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6c, 0x65, 0x5f, 0x74, 0x6c, + 0x73, 0x5f, 0x76, 0x65, 0x72, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x05, + 0x20, 0x01, 0x28, 0x08, 0x48, 0x00, 0x52, 0x16, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6c, 0x65, 0x54, + 0x6c, 0x73, 0x56, 0x65, 0x72, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x19, + 0x0a, 0x07, 0x63, 0x61, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0c, 0x48, + 0x00, 0x52, 0x06, 0x63, 0x61, 0x43, 0x65, 0x72, 0x74, 0x42, 0x0d, 0x0a, 0x0b, 0x74, 0x6c, 0x73, + 0x5f, 0x6f, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x42, 0x07, 0x0a, 0x05, 0x5f, 0x6e, 0x61, 0x6d, + 0x65, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x6c, 0x69, 0x73, 0x74, 0x65, 0x6e, 0x5f, 0x61, 0x64, 0x64, + 0x72, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x5f, 0x75, + 0x72, 0x6c, 0x32, 0xce, 0x02, 0x0a, 0x06, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x12, 0x41, 0x0a, + 0x04, 0x4c, 0x69, 0x73, 0x74, 0x12, 0x16, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, + 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x53, 0x65, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x1a, 0x21, 0x2e, + 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x4c, 0x69, 0x73, + 0x74, 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, + 0x12, 0x45, 0x0a, 0x06, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x12, 0x16, 0x2e, 0x70, 0x6f, 0x6d, + 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x53, 0x65, 0x6c, 0x65, 0x63, 0x74, + 0x6f, 0x72, 0x1a, 0x23, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, + 0x69, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x73, 0x52, + 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x34, 0x0a, 0x06, 0x55, 0x70, 0x73, 0x65, 0x72, + 0x74, 0x12, 0x14, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, + 0x2e, 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x1a, 0x14, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, + 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x52, 0x65, 0x63, 0x6f, 0x72, 0x64, 0x12, 0x3f, 0x0a, + 0x06, 0x45, 0x78, 0x70, 0x6f, 0x72, 0x74, 0x12, 0x1b, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, + 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x45, 0x78, 0x70, 0x6f, 0x72, 0x74, 0x52, 0x65, 0x71, + 0x75, 0x65, 0x73, 0x74, 0x1a, 0x18, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, + 0x63, 0x6c, 0x69, 0x2e, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x44, 0x61, 0x74, 0x61, 0x12, 0x43, + 0x0a, 0x06, 0x49, 0x6d, 0x70, 0x6f, 0x72, 0x74, 0x12, 0x1b, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, + 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x49, 0x6d, 0x70, 0x6f, 0x72, 0x74, 0x52, 0x65, + 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1c, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, + 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x49, 0x6d, 0x70, 0x6f, 0x72, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, + 0x6e, 0x73, 0x65, 0x32, 0xa9, 0x01, 0x0a, 0x08, 0x4c, 0x69, 0x73, 0x74, 0x65, 0x6e, 0x65, 0x72, + 0x12, 0x4b, 0x0a, 0x06, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x12, 0x23, 0x2e, 0x70, 0x6f, 0x6d, + 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x4c, 0x69, 0x73, 0x74, 0x65, 0x6e, + 0x65, 0x72, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, + 0x1c, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x4c, + 0x69, 0x73, 0x74, 0x65, 0x6e, 0x65, 0x72, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x12, 0x50, 0x0a, + 0x0d, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x73, 0x12, 0x16, + 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x53, 0x65, + 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x1a, 0x25, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, + 0x6d, 0x2e, 0x63, 0x6c, 0x69, 0x2e, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, + 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x73, 0x30, 0x01, 0x42, + 0x2b, 0x5a, 0x29, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x70, 0x6f, + 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2f, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2f, + 0x70, 0x6b, 0x67, 0x2f, 0x67, 0x72, 0x70, 0x63, 0x2f, 0x63, 0x6c, 0x69, 0x62, 0x06, 0x70, 0x72, + 0x6f, 0x74, 0x6f, 0x33, +} + +var ( + file_api_proto_rawDescOnce sync.Once + file_api_proto_rawDescData = file_api_proto_rawDesc +) + +func file_api_proto_rawDescGZIP() []byte { + file_api_proto_rawDescOnce.Do(func() { + file_api_proto_rawDescData = protoimpl.X.CompressGZIP(file_api_proto_rawDescData) + }) + return file_api_proto_rawDescData +} + +var file_api_proto_enumTypes = make([]protoimpl.EnumInfo, 2) +var file_api_proto_msgTypes = make([]protoimpl.MessageInfo, 17) +var file_api_proto_goTypes = []interface{}{ + (ExportRequest_Format)(0), // 0: pomerium.cli.ExportRequest.Format + (ConnectionStatusUpdates_ConnectionStatus)(0), // 1: pomerium.cli.ConnectionStatusUpdates.ConnectionStatus + (*Record)(nil), // 2: pomerium.cli.Record + (*Selector)(nil), // 3: pomerium.cli.Selector + (*ListRecordsResponse)(nil), // 4: pomerium.cli.ListRecordsResponse + (*DeleteRecordsResponse)(nil), // 5: pomerium.cli.DeleteRecordsResponse + (*ExportRequest)(nil), // 6: pomerium.cli.ExportRequest + (*ConfigData)(nil), // 7: pomerium.cli.ConfigData + (*ImportRequest)(nil), // 8: pomerium.cli.ImportRequest + (*ImportResponse)(nil), // 9: pomerium.cli.ImportResponse + (*ListenerUpdateRequest)(nil), // 10: pomerium.cli.ListenerUpdateRequest + (*ListenerStatus)(nil), // 11: pomerium.cli.ListenerStatus + (*StatusUpdatesRequest)(nil), // 12: pomerium.cli.StatusUpdatesRequest + (*ConnectionStatusUpdates)(nil), // 13: pomerium.cli.ConnectionStatusUpdates + (*Connection)(nil), // 14: pomerium.cli.Connection + (*Selector_IdFilter)(nil), // 15: pomerium.cli.Selector.IdFilter + (*Selector_TagFilter)(nil), // 16: pomerium.cli.Selector.TagFilter + nil, // 17: pomerium.cli.ListenerStatus.ActiveEntry + nil, // 18: pomerium.cli.ListenerStatus.ErrorsEntry +} +var file_api_proto_depIdxs = []int32{ + 14, // 0: pomerium.cli.Record.conn:type_name -> pomerium.cli.Connection + 16, // 1: pomerium.cli.Selector.tag:type_name -> pomerium.cli.Selector.TagFilter + 15, // 2: pomerium.cli.Selector.id_filter:type_name -> pomerium.cli.Selector.IdFilter + 2, // 3: pomerium.cli.ListRecordsResponse.records:type_name -> pomerium.cli.Record + 3, // 4: pomerium.cli.ExportRequest.selector:type_name -> pomerium.cli.Selector + 0, // 5: pomerium.cli.ExportRequest.format:type_name -> pomerium.cli.ExportRequest.Format + 17, // 6: pomerium.cli.ListenerStatus.active:type_name -> pomerium.cli.ListenerStatus.ActiveEntry + 18, // 7: pomerium.cli.ListenerStatus.errors:type_name -> pomerium.cli.ListenerStatus.ErrorsEntry + 1, // 8: pomerium.cli.ConnectionStatusUpdates.status:type_name -> pomerium.cli.ConnectionStatusUpdates.ConnectionStatus + 3, // 9: pomerium.cli.Config.List:input_type -> pomerium.cli.Selector + 3, // 10: pomerium.cli.Config.Delete:input_type -> pomerium.cli.Selector + 2, // 11: pomerium.cli.Config.Upsert:input_type -> pomerium.cli.Record + 6, // 12: pomerium.cli.Config.Export:input_type -> pomerium.cli.ExportRequest + 8, // 13: pomerium.cli.Config.Import:input_type -> pomerium.cli.ImportRequest + 10, // 14: pomerium.cli.Listener.Update:input_type -> pomerium.cli.ListenerUpdateRequest + 3, // 15: pomerium.cli.Listener.StatusUpdates:input_type -> pomerium.cli.Selector + 4, // 16: pomerium.cli.Config.List:output_type -> pomerium.cli.ListRecordsResponse + 5, // 17: pomerium.cli.Config.Delete:output_type -> pomerium.cli.DeleteRecordsResponse + 2, // 18: pomerium.cli.Config.Upsert:output_type -> pomerium.cli.Record + 7, // 19: pomerium.cli.Config.Export:output_type -> pomerium.cli.ConfigData + 9, // 20: pomerium.cli.Config.Import:output_type -> pomerium.cli.ImportResponse + 11, // 21: pomerium.cli.Listener.Update:output_type -> pomerium.cli.ListenerStatus + 13, // 22: pomerium.cli.Listener.StatusUpdates:output_type -> pomerium.cli.ConnectionStatusUpdates + 16, // [16:23] is the sub-list for method output_type + 9, // [9:16] is the sub-list for method input_type + 9, // [9:9] is the sub-list for extension type_name + 9, // [9:9] is the sub-list for extension extendee + 0, // [0:9] is the sub-list for field type_name +} + +func init() { file_api_proto_init() } +func file_api_proto_init() { + if File_api_proto != nil { + return + } + if !protoimpl.UnsafeEnabled { + file_api_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*Record); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*Selector); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ListRecordsResponse); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*DeleteRecordsResponse); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ExportRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[5].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ConfigData); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[6].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ImportRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[7].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ImportResponse); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[8].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ListenerUpdateRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[9].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ListenerStatus); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[10].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*StatusUpdatesRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[11].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ConnectionStatusUpdates); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[12].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*Connection); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[13].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*Selector_IdFilter); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_api_proto_msgTypes[14].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*Selector_TagFilter); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + } + file_api_proto_msgTypes[0].OneofWrappers = []interface{}{} + file_api_proto_msgTypes[1].OneofWrappers = []interface{}{ + (*Selector_All)(nil), + (*Selector_Tag)(nil), + (*Selector_IdFilter_)(nil), + } + file_api_proto_msgTypes[6].OneofWrappers = []interface{}{} + file_api_proto_msgTypes[11].OneofWrappers = []interface{}{} + file_api_proto_msgTypes[12].OneofWrappers = []interface{}{ + (*Connection_DisableTlsVerification)(nil), + (*Connection_CaCert)(nil), + } + type x struct{} + out := protoimpl.TypeBuilder{ + File: protoimpl.DescBuilder{ + GoPackagePath: reflect.TypeOf(x{}).PkgPath(), + RawDescriptor: file_api_proto_rawDesc, + NumEnums: 2, + NumMessages: 17, + NumExtensions: 0, + NumServices: 2, + }, + GoTypes: file_api_proto_goTypes, + DependencyIndexes: file_api_proto_depIdxs, + EnumInfos: file_api_proto_enumTypes, + MessageInfos: file_api_proto_msgTypes, + }.Build() + File_api_proto = out.File + file_api_proto_rawDesc = nil + file_api_proto_goTypes = nil + file_api_proto_depIdxs = nil +} + +// Reference imports to suppress errors if they are not otherwise used. +var _ context.Context +var _ grpc.ClientConnInterface + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +const _ = grpc.SupportPackageIsVersion6 + +// ConfigClient is the client API for Config service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. +type ConfigClient interface { + List(ctx context.Context, in *Selector, opts ...grpc.CallOption) (*ListRecordsResponse, error) + Delete(ctx context.Context, in *Selector, opts ...grpc.CallOption) (*DeleteRecordsResponse, error) + Upsert(ctx context.Context, in *Record, opts ...grpc.CallOption) (*Record, error) + Export(ctx context.Context, in *ExportRequest, opts ...grpc.CallOption) (*ConfigData, error) + Import(ctx context.Context, in *ImportRequest, opts ...grpc.CallOption) (*ImportResponse, error) +} + +type configClient struct { + cc grpc.ClientConnInterface +} + +func NewConfigClient(cc grpc.ClientConnInterface) ConfigClient { + return &configClient{cc} +} + +func (c *configClient) List(ctx context.Context, in *Selector, opts ...grpc.CallOption) (*ListRecordsResponse, error) { + out := new(ListRecordsResponse) + err := c.cc.Invoke(ctx, "/pomerium.cli.Config/List", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *configClient) Delete(ctx context.Context, in *Selector, opts ...grpc.CallOption) (*DeleteRecordsResponse, error) { + out := new(DeleteRecordsResponse) + err := c.cc.Invoke(ctx, "/pomerium.cli.Config/Delete", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *configClient) Upsert(ctx context.Context, in *Record, opts ...grpc.CallOption) (*Record, error) { + out := new(Record) + err := c.cc.Invoke(ctx, "/pomerium.cli.Config/Upsert", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *configClient) Export(ctx context.Context, in *ExportRequest, opts ...grpc.CallOption) (*ConfigData, error) { + out := new(ConfigData) + err := c.cc.Invoke(ctx, "/pomerium.cli.Config/Export", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *configClient) Import(ctx context.Context, in *ImportRequest, opts ...grpc.CallOption) (*ImportResponse, error) { + out := new(ImportResponse) + err := c.cc.Invoke(ctx, "/pomerium.cli.Config/Import", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +// ConfigServer is the server API for Config service. +type ConfigServer interface { + List(context.Context, *Selector) (*ListRecordsResponse, error) + Delete(context.Context, *Selector) (*DeleteRecordsResponse, error) + Upsert(context.Context, *Record) (*Record, error) + Export(context.Context, *ExportRequest) (*ConfigData, error) + Import(context.Context, *ImportRequest) (*ImportResponse, error) +} + +// UnimplementedConfigServer can be embedded to have forward compatible implementations. +type UnimplementedConfigServer struct { +} + +func (*UnimplementedConfigServer) List(context.Context, *Selector) (*ListRecordsResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method List not implemented") +} +func (*UnimplementedConfigServer) Delete(context.Context, *Selector) (*DeleteRecordsResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method Delete not implemented") +} +func (*UnimplementedConfigServer) Upsert(context.Context, *Record) (*Record, error) { + return nil, status.Errorf(codes.Unimplemented, "method Upsert not implemented") +} +func (*UnimplementedConfigServer) Export(context.Context, *ExportRequest) (*ConfigData, error) { + return nil, status.Errorf(codes.Unimplemented, "method Export not implemented") +} +func (*UnimplementedConfigServer) Import(context.Context, *ImportRequest) (*ImportResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method Import not implemented") +} + +func RegisterConfigServer(s *grpc.Server, srv ConfigServer) { + s.RegisterService(&_Config_serviceDesc, srv) +} + +func _Config_List_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(Selector) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ConfigServer).List(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/pomerium.cli.Config/List", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ConfigServer).List(ctx, req.(*Selector)) + } + return interceptor(ctx, in, info, handler) +} + +func _Config_Delete_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(Selector) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ConfigServer).Delete(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/pomerium.cli.Config/Delete", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ConfigServer).Delete(ctx, req.(*Selector)) + } + return interceptor(ctx, in, info, handler) +} + +func _Config_Upsert_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(Record) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ConfigServer).Upsert(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/pomerium.cli.Config/Upsert", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ConfigServer).Upsert(ctx, req.(*Record)) + } + return interceptor(ctx, in, info, handler) +} + +func _Config_Export_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ExportRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ConfigServer).Export(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/pomerium.cli.Config/Export", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ConfigServer).Export(ctx, req.(*ExportRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _Config_Import_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ImportRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ConfigServer).Import(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/pomerium.cli.Config/Import", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ConfigServer).Import(ctx, req.(*ImportRequest)) + } + return interceptor(ctx, in, info, handler) +} + +var _Config_serviceDesc = grpc.ServiceDesc{ + ServiceName: "pomerium.cli.Config", + HandlerType: (*ConfigServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "List", + Handler: _Config_List_Handler, + }, + { + MethodName: "Delete", + Handler: _Config_Delete_Handler, + }, + { + MethodName: "Upsert", + Handler: _Config_Upsert_Handler, + }, + { + MethodName: "Export", + Handler: _Config_Export_Handler, + }, + { + MethodName: "Import", + Handler: _Config_Import_Handler, + }, + }, + Streams: []grpc.StreamDesc{}, + Metadata: "api.proto", +} + +// ListenerClient is the client API for Listener service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. +type ListenerClient interface { + // Listen starts connection listener + Update(ctx context.Context, in *ListenerUpdateRequest, opts ...grpc.CallOption) (*ListenerStatus, error) + // StatusUpdates opens a stream to listen to connection status updates + // a client has to subscribe and continuously + // listen to the broadcasted updates + StatusUpdates(ctx context.Context, in *Selector, opts ...grpc.CallOption) (Listener_StatusUpdatesClient, error) +} + +type listenerClient struct { + cc grpc.ClientConnInterface +} + +func NewListenerClient(cc grpc.ClientConnInterface) ListenerClient { + return &listenerClient{cc} +} + +func (c *listenerClient) Update(ctx context.Context, in *ListenerUpdateRequest, opts ...grpc.CallOption) (*ListenerStatus, error) { + out := new(ListenerStatus) + err := c.cc.Invoke(ctx, "/pomerium.cli.Listener/Update", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *listenerClient) StatusUpdates(ctx context.Context, in *Selector, opts ...grpc.CallOption) (Listener_StatusUpdatesClient, error) { + stream, err := c.cc.NewStream(ctx, &_Listener_serviceDesc.Streams[0], "/pomerium.cli.Listener/StatusUpdates", opts...) + if err != nil { + return nil, err + } + x := &listenerStatusUpdatesClient{stream} + if err := x.ClientStream.SendMsg(in); err != nil { + return nil, err + } + if err := x.ClientStream.CloseSend(); err != nil { + return nil, err + } + return x, nil +} + +type Listener_StatusUpdatesClient interface { + Recv() (*ConnectionStatusUpdates, error) + grpc.ClientStream +} + +type listenerStatusUpdatesClient struct { + grpc.ClientStream +} + +func (x *listenerStatusUpdatesClient) Recv() (*ConnectionStatusUpdates, error) { + m := new(ConnectionStatusUpdates) + if err := x.ClientStream.RecvMsg(m); err != nil { + return nil, err + } + return m, nil +} + +// ListenerServer is the server API for Listener service. +type ListenerServer interface { + // Listen starts connection listener + Update(context.Context, *ListenerUpdateRequest) (*ListenerStatus, error) + // StatusUpdates opens a stream to listen to connection status updates + // a client has to subscribe and continuously + // listen to the broadcasted updates + StatusUpdates(*Selector, Listener_StatusUpdatesServer) error +} + +// UnimplementedListenerServer can be embedded to have forward compatible implementations. +type UnimplementedListenerServer struct { +} + +func (*UnimplementedListenerServer) Update(context.Context, *ListenerUpdateRequest) (*ListenerStatus, error) { + return nil, status.Errorf(codes.Unimplemented, "method Update not implemented") +} +func (*UnimplementedListenerServer) StatusUpdates(*Selector, Listener_StatusUpdatesServer) error { + return status.Errorf(codes.Unimplemented, "method StatusUpdates not implemented") +} + +func RegisterListenerServer(s *grpc.Server, srv ListenerServer) { + s.RegisterService(&_Listener_serviceDesc, srv) +} + +func _Listener_Update_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ListenerUpdateRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ListenerServer).Update(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/pomerium.cli.Listener/Update", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ListenerServer).Update(ctx, req.(*ListenerUpdateRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _Listener_StatusUpdates_Handler(srv interface{}, stream grpc.ServerStream) error { + m := new(Selector) + if err := stream.RecvMsg(m); err != nil { + return err + } + return srv.(ListenerServer).StatusUpdates(m, &listenerStatusUpdatesServer{stream}) +} + +type Listener_StatusUpdatesServer interface { + Send(*ConnectionStatusUpdates) error + grpc.ServerStream +} + +type listenerStatusUpdatesServer struct { + grpc.ServerStream +} + +func (x *listenerStatusUpdatesServer) Send(m *ConnectionStatusUpdates) error { + return x.ServerStream.SendMsg(m) +} + +var _Listener_serviceDesc = grpc.ServiceDesc{ + ServiceName: "pomerium.cli.Listener", + HandlerType: (*ListenerServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "Update", + Handler: _Listener_Update_Handler, + }, + }, + Streams: []grpc.StreamDesc{ + { + StreamName: "StatusUpdates", + Handler: _Listener_StatusUpdates_Handler, + ServerStreams: true, + }, + }, + Metadata: "api.proto", +} diff --git a/pkg/grpc/config/config.pb.go b/pkg/grpc/config/config.pb.go index b613b6360..9b80a13b7 100644 --- a/pkg/grpc/config/config.pb.go +++ b/pkg/grpc/config/config.pb.go @@ -801,43 +801,45 @@ type Settings struct { sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields - InstallationId *string `protobuf:"bytes,71,opt,name=installation_id,json=installationId,proto3,oneof" json:"installation_id,omitempty"` - Debug *bool `protobuf:"varint,2,opt,name=debug,proto3,oneof" json:"debug,omitempty"` - LogLevel *string `protobuf:"bytes,3,opt,name=log_level,json=logLevel,proto3,oneof" json:"log_level,omitempty"` - ProxyLogLevel *string `protobuf:"bytes,4,opt,name=proxy_log_level,json=proxyLogLevel,proto3,oneof" json:"proxy_log_level,omitempty"` - SharedSecret *string `protobuf:"bytes,5,opt,name=shared_secret,json=sharedSecret,proto3,oneof" json:"shared_secret,omitempty"` - Services *string `protobuf:"bytes,6,opt,name=services,proto3,oneof" json:"services,omitempty"` - Address *string `protobuf:"bytes,7,opt,name=address,proto3,oneof" json:"address,omitempty"` - InsecureServer *bool `protobuf:"varint,8,opt,name=insecure_server,json=insecureServer,proto3,oneof" json:"insecure_server,omitempty"` - DnsLookupFamily *string `protobuf:"bytes,60,opt,name=dns_lookup_family,json=dnsLookupFamily,proto3,oneof" json:"dns_lookup_family,omitempty"` - Certificates []*Settings_Certificate `protobuf:"bytes,9,rep,name=certificates,proto3" json:"certificates,omitempty"` - HttpRedirectAddr *string `protobuf:"bytes,10,opt,name=http_redirect_addr,json=httpRedirectAddr,proto3,oneof" json:"http_redirect_addr,omitempty"` - TimeoutRead *durationpb.Duration `protobuf:"bytes,11,opt,name=timeout_read,json=timeoutRead,proto3,oneof" json:"timeout_read,omitempty"` - TimeoutWrite *durationpb.Duration `protobuf:"bytes,12,opt,name=timeout_write,json=timeoutWrite,proto3,oneof" json:"timeout_write,omitempty"` - TimeoutIdle *durationpb.Duration `protobuf:"bytes,13,opt,name=timeout_idle,json=timeoutIdle,proto3,oneof" json:"timeout_idle,omitempty"` - AuthenticateServiceUrl *string `protobuf:"bytes,14,opt,name=authenticate_service_url,json=authenticateServiceUrl,proto3,oneof" json:"authenticate_service_url,omitempty"` - AuthenticateCallbackPath *string `protobuf:"bytes,15,opt,name=authenticate_callback_path,json=authenticateCallbackPath,proto3,oneof" json:"authenticate_callback_path,omitempty"` - CookieName *string `protobuf:"bytes,16,opt,name=cookie_name,json=cookieName,proto3,oneof" json:"cookie_name,omitempty"` - CookieSecret *string `protobuf:"bytes,17,opt,name=cookie_secret,json=cookieSecret,proto3,oneof" json:"cookie_secret,omitempty"` - CookieDomain *string `protobuf:"bytes,18,opt,name=cookie_domain,json=cookieDomain,proto3,oneof" json:"cookie_domain,omitempty"` - CookieSecure *bool `protobuf:"varint,19,opt,name=cookie_secure,json=cookieSecure,proto3,oneof" json:"cookie_secure,omitempty"` - CookieHttpOnly *bool `protobuf:"varint,20,opt,name=cookie_http_only,json=cookieHttpOnly,proto3,oneof" json:"cookie_http_only,omitempty"` - CookieExpire *durationpb.Duration `protobuf:"bytes,21,opt,name=cookie_expire,json=cookieExpire,proto3,oneof" json:"cookie_expire,omitempty"` - IdpClientId *string `protobuf:"bytes,22,opt,name=idp_client_id,json=idpClientId,proto3,oneof" json:"idp_client_id,omitempty"` - IdpClientSecret *string `protobuf:"bytes,23,opt,name=idp_client_secret,json=idpClientSecret,proto3,oneof" json:"idp_client_secret,omitempty"` - IdpProvider *string `protobuf:"bytes,24,opt,name=idp_provider,json=idpProvider,proto3,oneof" json:"idp_provider,omitempty"` - IdpProviderUrl *string `protobuf:"bytes,25,opt,name=idp_provider_url,json=idpProviderUrl,proto3,oneof" json:"idp_provider_url,omitempty"` - Scopes []string `protobuf:"bytes,26,rep,name=scopes,proto3" json:"scopes,omitempty"` - IdpServiceAccount *string `protobuf:"bytes,27,opt,name=idp_service_account,json=idpServiceAccount,proto3,oneof" json:"idp_service_account,omitempty"` - IdpRefreshDirectoryTimeout *durationpb.Duration `protobuf:"bytes,28,opt,name=idp_refresh_directory_timeout,json=idpRefreshDirectoryTimeout,proto3,oneof" json:"idp_refresh_directory_timeout,omitempty"` - IdpRefreshDirectoryInterval *durationpb.Duration `protobuf:"bytes,29,opt,name=idp_refresh_directory_interval,json=idpRefreshDirectoryInterval,proto3,oneof" json:"idp_refresh_directory_interval,omitempty"` - RequestParams map[string]string `protobuf:"bytes,30,rep,name=request_params,json=requestParams,proto3" json:"request_params,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` - AuthorizeServiceUrls []string `protobuf:"bytes,32,rep,name=authorize_service_urls,json=authorizeServiceUrls,proto3" json:"authorize_service_urls,omitempty"` - OverrideCertificateName *string `protobuf:"bytes,33,opt,name=override_certificate_name,json=overrideCertificateName,proto3,oneof" json:"override_certificate_name,omitempty"` - CertificateAuthority *string `protobuf:"bytes,34,opt,name=certificate_authority,json=certificateAuthority,proto3,oneof" json:"certificate_authority,omitempty"` - CertificateAuthorityFile *string `protobuf:"bytes,35,opt,name=certificate_authority_file,json=certificateAuthorityFile,proto3,oneof" json:"certificate_authority_file,omitempty"` - SigningKey *string `protobuf:"bytes,36,opt,name=signing_key,json=signingKey,proto3,oneof" json:"signing_key,omitempty"` - SetResponseHeaders map[string]string `protobuf:"bytes,69,rep,name=set_response_headers,json=setResponseHeaders,proto3" json:"set_response_headers,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` + InstallationId *string `protobuf:"bytes,71,opt,name=installation_id,json=installationId,proto3,oneof" json:"installation_id,omitempty"` + Debug *bool `protobuf:"varint,2,opt,name=debug,proto3,oneof" json:"debug,omitempty"` + LogLevel *string `protobuf:"bytes,3,opt,name=log_level,json=logLevel,proto3,oneof" json:"log_level,omitempty"` + ProxyLogLevel *string `protobuf:"bytes,4,opt,name=proxy_log_level,json=proxyLogLevel,proto3,oneof" json:"proxy_log_level,omitempty"` + SharedSecret *string `protobuf:"bytes,5,opt,name=shared_secret,json=sharedSecret,proto3,oneof" json:"shared_secret,omitempty"` + Services *string `protobuf:"bytes,6,opt,name=services,proto3,oneof" json:"services,omitempty"` + Address *string `protobuf:"bytes,7,opt,name=address,proto3,oneof" json:"address,omitempty"` + InsecureServer *bool `protobuf:"varint,8,opt,name=insecure_server,json=insecureServer,proto3,oneof" json:"insecure_server,omitempty"` + DnsLookupFamily *string `protobuf:"bytes,60,opt,name=dns_lookup_family,json=dnsLookupFamily,proto3,oneof" json:"dns_lookup_family,omitempty"` + Certificates []*Settings_Certificate `protobuf:"bytes,9,rep,name=certificates,proto3" json:"certificates,omitempty"` + HttpRedirectAddr *string `protobuf:"bytes,10,opt,name=http_redirect_addr,json=httpRedirectAddr,proto3,oneof" json:"http_redirect_addr,omitempty"` + TimeoutRead *durationpb.Duration `protobuf:"bytes,11,opt,name=timeout_read,json=timeoutRead,proto3,oneof" json:"timeout_read,omitempty"` + TimeoutWrite *durationpb.Duration `protobuf:"bytes,12,opt,name=timeout_write,json=timeoutWrite,proto3,oneof" json:"timeout_write,omitempty"` + TimeoutIdle *durationpb.Duration `protobuf:"bytes,13,opt,name=timeout_idle,json=timeoutIdle,proto3,oneof" json:"timeout_idle,omitempty"` + AuthenticateServiceUrl *string `protobuf:"bytes,14,opt,name=authenticate_service_url,json=authenticateServiceUrl,proto3,oneof" json:"authenticate_service_url,omitempty"` + AuthenticateInternalServiceUrl *string `protobuf:"bytes,82,opt,name=authenticate_internal_service_url,json=authenticateInternalServiceUrl,proto3,oneof" json:"authenticate_internal_service_url,omitempty"` + AuthenticateCallbackPath *string `protobuf:"bytes,15,opt,name=authenticate_callback_path,json=authenticateCallbackPath,proto3,oneof" json:"authenticate_callback_path,omitempty"` + CookieName *string `protobuf:"bytes,16,opt,name=cookie_name,json=cookieName,proto3,oneof" json:"cookie_name,omitempty"` + CookieSecret *string `protobuf:"bytes,17,opt,name=cookie_secret,json=cookieSecret,proto3,oneof" json:"cookie_secret,omitempty"` + CookieDomain *string `protobuf:"bytes,18,opt,name=cookie_domain,json=cookieDomain,proto3,oneof" json:"cookie_domain,omitempty"` + CookieSecure *bool `protobuf:"varint,19,opt,name=cookie_secure,json=cookieSecure,proto3,oneof" json:"cookie_secure,omitempty"` + CookieHttpOnly *bool `protobuf:"varint,20,opt,name=cookie_http_only,json=cookieHttpOnly,proto3,oneof" json:"cookie_http_only,omitempty"` + CookieExpire *durationpb.Duration `protobuf:"bytes,21,opt,name=cookie_expire,json=cookieExpire,proto3,oneof" json:"cookie_expire,omitempty"` + IdpClientId *string `protobuf:"bytes,22,opt,name=idp_client_id,json=idpClientId,proto3,oneof" json:"idp_client_id,omitempty"` + IdpClientSecret *string `protobuf:"bytes,23,opt,name=idp_client_secret,json=idpClientSecret,proto3,oneof" json:"idp_client_secret,omitempty"` + IdpProvider *string `protobuf:"bytes,24,opt,name=idp_provider,json=idpProvider,proto3,oneof" json:"idp_provider,omitempty"` + IdpProviderUrl *string `protobuf:"bytes,25,opt,name=idp_provider_url,json=idpProviderUrl,proto3,oneof" json:"idp_provider_url,omitempty"` + Scopes []string `protobuf:"bytes,26,rep,name=scopes,proto3" json:"scopes,omitempty"` + IdpServiceAccount *string `protobuf:"bytes,27,opt,name=idp_service_account,json=idpServiceAccount,proto3,oneof" json:"idp_service_account,omitempty"` + IdpRefreshDirectoryTimeout *durationpb.Duration `protobuf:"bytes,28,opt,name=idp_refresh_directory_timeout,json=idpRefreshDirectoryTimeout,proto3,oneof" json:"idp_refresh_directory_timeout,omitempty"` + IdpRefreshDirectoryInterval *durationpb.Duration `protobuf:"bytes,29,opt,name=idp_refresh_directory_interval,json=idpRefreshDirectoryInterval,proto3,oneof" json:"idp_refresh_directory_interval,omitempty"` + RequestParams map[string]string `protobuf:"bytes,30,rep,name=request_params,json=requestParams,proto3" json:"request_params,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` + AuthorizeServiceUrls []string `protobuf:"bytes,32,rep,name=authorize_service_urls,json=authorizeServiceUrls,proto3" json:"authorize_service_urls,omitempty"` + AuthorizeInternalServiceUrl *string `protobuf:"bytes,83,opt,name=authorize_internal_service_url,json=authorizeInternalServiceUrl,proto3,oneof" json:"authorize_internal_service_url,omitempty"` + OverrideCertificateName *string `protobuf:"bytes,33,opt,name=override_certificate_name,json=overrideCertificateName,proto3,oneof" json:"override_certificate_name,omitempty"` + CertificateAuthority *string `protobuf:"bytes,34,opt,name=certificate_authority,json=certificateAuthority,proto3,oneof" json:"certificate_authority,omitempty"` + CertificateAuthorityFile *string `protobuf:"bytes,35,opt,name=certificate_authority_file,json=certificateAuthorityFile,proto3,oneof" json:"certificate_authority_file,omitempty"` + SigningKey *string `protobuf:"bytes,36,opt,name=signing_key,json=signingKey,proto3,oneof" json:"signing_key,omitempty"` + SetResponseHeaders map[string]string `protobuf:"bytes,69,rep,name=set_response_headers,json=setResponseHeaders,proto3" json:"set_response_headers,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` // repeated string jwt_claims_headers = 37; JwtClaimsHeaders map[string]string `protobuf:"bytes,63,rep,name=jwt_claims_headers,json=jwtClaimsHeaders,proto3" json:"jwt_claims_headers,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` DefaultUpstreamTimeout *durationpb.Duration `protobuf:"bytes,39,opt,name=default_upstream_timeout,json=defaultUpstreamTimeout,proto3,oneof" json:"default_upstream_timeout,omitempty"` @@ -855,6 +857,7 @@ type Settings struct { GrpcInsecure *bool `protobuf:"varint,47,opt,name=grpc_insecure,json=grpcInsecure,proto3,oneof" json:"grpc_insecure,omitempty"` ForwardAuthUrl *string `protobuf:"bytes,50,opt,name=forward_auth_url,json=forwardAuthUrl,proto3,oneof" json:"forward_auth_url,omitempty"` DatabrokerServiceUrls []string `protobuf:"bytes,52,rep,name=databroker_service_urls,json=databrokerServiceUrls,proto3" json:"databroker_service_urls,omitempty"` + DatabrokerInternalServiceUrl *string `protobuf:"bytes,84,opt,name=databroker_internal_service_url,json=databrokerInternalServiceUrl,proto3,oneof" json:"databroker_internal_service_url,omitempty"` ClientCa *string `protobuf:"bytes,53,opt,name=client_ca,json=clientCa,proto3,oneof" json:"client_ca,omitempty"` ClientCaFile *string `protobuf:"bytes,54,opt,name=client_ca_file,json=clientCaFile,proto3,oneof" json:"client_ca_file,omitempty"` ClientCrl *string `protobuf:"bytes,74,opt,name=client_crl,json=clientCrl,proto3,oneof" json:"client_crl,omitempty"` @@ -1014,6 +1017,13 @@ func (x *Settings) GetAuthenticateServiceUrl() string { return "" } +func (x *Settings) GetAuthenticateInternalServiceUrl() string { + if x != nil && x.AuthenticateInternalServiceUrl != nil { + return *x.AuthenticateInternalServiceUrl + } + return "" +} + func (x *Settings) GetAuthenticateCallbackPath() string { if x != nil && x.AuthenticateCallbackPath != nil { return *x.AuthenticateCallbackPath @@ -1133,6 +1143,13 @@ func (x *Settings) GetAuthorizeServiceUrls() []string { return nil } +func (x *Settings) GetAuthorizeInternalServiceUrl() string { + if x != nil && x.AuthorizeInternalServiceUrl != nil { + return *x.AuthorizeInternalServiceUrl + } + return "" +} + func (x *Settings) GetOverrideCertificateName() string { if x != nil && x.OverrideCertificateName != nil { return *x.OverrideCertificateName @@ -1280,6 +1297,13 @@ func (x *Settings) GetDatabrokerServiceUrls() []string { return nil } +func (x *Settings) GetDatabrokerInternalServiceUrl() string { + if x != nil && x.DatabrokerInternalServiceUrl != nil { + return *x.DatabrokerInternalServiceUrl + } + return "" +} + func (x *Settings) GetClientCa() string { if x != nil && x.ClientCa != nil { return *x.ClientCa @@ -1755,7 +1779,7 @@ var file_config_proto_rawDesc = []byte{ 0x12, 0x30, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x4c, 0x69, 0x73, 0x74, 0x56, 0x61, 0x6c, 0x75, 0x65, 0x52, 0x05, 0x76, 0x61, 0x6c, - 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x22, 0xa7, 0x2e, 0x0a, 0x08, 0x53, 0x65, 0x74, 0x74, 0x69, + 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x22, 0xfa, 0x30, 0x0a, 0x08, 0x53, 0x65, 0x74, 0x74, 0x69, 0x6e, 0x67, 0x73, 0x12, 0x2c, 0x0a, 0x0f, 0x69, 0x6e, 0x73, 0x74, 0x61, 0x6c, 0x6c, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x5f, 0x69, 0x64, 0x18, 0x47, 0x20, 0x01, 0x28, 0x09, 0x48, 0x00, 0x52, 0x0e, 0x69, 0x6e, 0x73, 0x74, 0x61, 0x6c, 0x6c, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x49, 0x64, 0x88, 0x01, @@ -1802,55 +1826,60 @@ var file_config_proto_rawDesc = []byte{ 0x18, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x0e, 0x20, 0x01, 0x28, 0x09, 0x48, 0x0d, 0x52, 0x16, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x53, + 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x4e, 0x0a, 0x21, + 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x69, 0x6e, 0x74, + 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, + 0x6c, 0x18, 0x52, 0x20, 0x01, 0x28, 0x09, 0x48, 0x0e, 0x52, 0x1e, 0x61, 0x75, 0x74, 0x68, 0x65, + 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x49, 0x6e, 0x74, 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x41, 0x0a, 0x1a, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x63, 0x61, 0x6c, 0x6c, 0x62, 0x61, 0x63, 0x6b, 0x5f, 0x70, 0x61, 0x74, 0x68, 0x18, 0x0f, 0x20, 0x01, 0x28, 0x09, - 0x48, 0x0e, 0x52, 0x18, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, + 0x48, 0x0f, 0x52, 0x18, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x43, 0x61, 0x6c, 0x6c, 0x62, 0x61, 0x63, 0x6b, 0x50, 0x61, 0x74, 0x68, 0x88, 0x01, 0x01, 0x12, 0x24, 0x0a, 0x0b, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x10, - 0x20, 0x01, 0x28, 0x09, 0x48, 0x0f, 0x52, 0x0a, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x4e, 0x61, + 0x20, 0x01, 0x28, 0x09, 0x48, 0x10, 0x52, 0x0a, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x4e, 0x61, 0x6d, 0x65, 0x88, 0x01, 0x01, 0x12, 0x28, 0x0a, 0x0d, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, - 0x73, 0x65, 0x63, 0x72, 0x65, 0x74, 0x18, 0x11, 0x20, 0x01, 0x28, 0x09, 0x48, 0x10, 0x52, 0x0c, + 0x73, 0x65, 0x63, 0x72, 0x65, 0x74, 0x18, 0x11, 0x20, 0x01, 0x28, 0x09, 0x48, 0x11, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x53, 0x65, 0x63, 0x72, 0x65, 0x74, 0x88, 0x01, 0x01, 0x12, 0x28, 0x0a, 0x0d, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x64, 0x6f, 0x6d, 0x61, 0x69, 0x6e, - 0x18, 0x12, 0x20, 0x01, 0x28, 0x09, 0x48, 0x11, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, + 0x18, 0x12, 0x20, 0x01, 0x28, 0x09, 0x48, 0x12, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x44, 0x6f, 0x6d, 0x61, 0x69, 0x6e, 0x88, 0x01, 0x01, 0x12, 0x28, 0x0a, 0x0d, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x18, 0x13, 0x20, 0x01, 0x28, 0x08, - 0x48, 0x12, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x53, 0x65, 0x63, 0x75, 0x72, 0x65, + 0x48, 0x13, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x53, 0x65, 0x63, 0x75, 0x72, 0x65, 0x88, 0x01, 0x01, 0x12, 0x2d, 0x0a, 0x10, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x68, 0x74, - 0x74, 0x70, 0x5f, 0x6f, 0x6e, 0x6c, 0x79, 0x18, 0x14, 0x20, 0x01, 0x28, 0x08, 0x48, 0x13, 0x52, + 0x74, 0x70, 0x5f, 0x6f, 0x6e, 0x6c, 0x79, 0x18, 0x14, 0x20, 0x01, 0x28, 0x08, 0x48, 0x14, 0x52, 0x0e, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x48, 0x74, 0x74, 0x70, 0x4f, 0x6e, 0x6c, 0x79, 0x88, 0x01, 0x01, 0x12, 0x43, 0x0a, 0x0d, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x65, 0x78, 0x70, 0x69, 0x72, 0x65, 0x18, 0x15, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x44, 0x75, 0x72, 0x61, - 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x14, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x45, 0x78, + 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x15, 0x52, 0x0c, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x45, 0x78, 0x70, 0x69, 0x72, 0x65, 0x88, 0x01, 0x01, 0x12, 0x27, 0x0a, 0x0d, 0x69, 0x64, 0x70, 0x5f, 0x63, - 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x69, 0x64, 0x18, 0x16, 0x20, 0x01, 0x28, 0x09, 0x48, 0x15, + 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x69, 0x64, 0x18, 0x16, 0x20, 0x01, 0x28, 0x09, 0x48, 0x16, 0x52, 0x0b, 0x69, 0x64, 0x70, 0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x88, 0x01, 0x01, 0x12, 0x2f, 0x0a, 0x11, 0x69, 0x64, 0x70, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x73, - 0x65, 0x63, 0x72, 0x65, 0x74, 0x18, 0x17, 0x20, 0x01, 0x28, 0x09, 0x48, 0x16, 0x52, 0x0f, 0x69, + 0x65, 0x63, 0x72, 0x65, 0x74, 0x18, 0x17, 0x20, 0x01, 0x28, 0x09, 0x48, 0x17, 0x52, 0x0f, 0x69, 0x64, 0x70, 0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x53, 0x65, 0x63, 0x72, 0x65, 0x74, 0x88, 0x01, 0x01, 0x12, 0x26, 0x0a, 0x0c, 0x69, 0x64, 0x70, 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, - 0x72, 0x18, 0x18, 0x20, 0x01, 0x28, 0x09, 0x48, 0x17, 0x52, 0x0b, 0x69, 0x64, 0x70, 0x50, 0x72, + 0x72, 0x18, 0x18, 0x20, 0x01, 0x28, 0x09, 0x48, 0x18, 0x52, 0x0b, 0x69, 0x64, 0x70, 0x50, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x88, 0x01, 0x01, 0x12, 0x2d, 0x0a, 0x10, 0x69, 0x64, 0x70, 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x19, 0x20, - 0x01, 0x28, 0x09, 0x48, 0x18, 0x52, 0x0e, 0x69, 0x64, 0x70, 0x50, 0x72, 0x6f, 0x76, 0x69, 0x64, + 0x01, 0x28, 0x09, 0x48, 0x19, 0x52, 0x0e, 0x69, 0x64, 0x70, 0x50, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x55, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x16, 0x0a, 0x06, 0x73, 0x63, 0x6f, 0x70, 0x65, 0x73, 0x18, 0x1a, 0x20, 0x03, 0x28, 0x09, 0x52, 0x06, 0x73, 0x63, 0x6f, 0x70, 0x65, 0x73, 0x12, 0x33, 0x0a, 0x13, 0x69, 0x64, 0x70, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, - 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x1b, 0x20, 0x01, 0x28, 0x09, 0x48, 0x19, 0x52, + 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x1b, 0x20, 0x01, 0x28, 0x09, 0x48, 0x1a, 0x52, 0x11, 0x69, 0x64, 0x70, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x41, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x88, 0x01, 0x01, 0x12, 0x61, 0x0a, 0x1d, 0x69, 0x64, 0x70, 0x5f, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x79, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x18, 0x1c, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x44, - 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x1a, 0x52, 0x1a, 0x69, 0x64, 0x70, 0x52, 0x65, + 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x1b, 0x52, 0x1a, 0x69, 0x64, 0x70, 0x52, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x44, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x79, 0x54, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x88, 0x01, 0x01, 0x12, 0x63, 0x0a, 0x1e, 0x69, 0x64, 0x70, 0x5f, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x79, 0x5f, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x18, 0x1d, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, - 0x75, 0x66, 0x2e, 0x44, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x1b, 0x52, 0x1b, 0x69, + 0x75, 0x66, 0x2e, 0x44, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x1c, 0x52, 0x1b, 0x69, 0x64, 0x70, 0x52, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x44, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x79, 0x49, 0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x53, 0x0a, 0x0e, 0x72, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x5f, 0x70, 0x61, 0x72, 0x61, 0x6d, 0x73, 0x18, @@ -1861,275 +1890,291 @@ var file_config_proto_rawDesc = []byte{ 0x6d, 0x73, 0x12, 0x34, 0x0a, 0x16, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x7a, 0x65, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x73, 0x18, 0x20, 0x20, 0x03, 0x28, 0x09, 0x52, 0x14, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x7a, 0x65, 0x53, 0x65, 0x72, - 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x73, 0x12, 0x3f, 0x0a, 0x19, 0x6f, 0x76, 0x65, 0x72, - 0x72, 0x69, 0x64, 0x65, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, - 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x21, 0x20, 0x01, 0x28, 0x09, 0x48, 0x1c, 0x52, 0x17, 0x6f, - 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, 0x65, 0x43, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, - 0x74, 0x65, 0x4e, 0x61, 0x6d, 0x65, 0x88, 0x01, 0x01, 0x12, 0x38, 0x0a, 0x15, 0x63, 0x65, 0x72, - 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, - 0x74, 0x79, 0x18, 0x22, 0x20, 0x01, 0x28, 0x09, 0x48, 0x1d, 0x52, 0x14, 0x63, 0x65, 0x72, 0x74, - 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x41, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, - 0x88, 0x01, 0x01, 0x12, 0x41, 0x0a, 0x1a, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, - 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x5f, 0x66, 0x69, 0x6c, - 0x65, 0x18, 0x23, 0x20, 0x01, 0x28, 0x09, 0x48, 0x1e, 0x52, 0x18, 0x63, 0x65, 0x72, 0x74, 0x69, - 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x41, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x46, - 0x69, 0x6c, 0x65, 0x88, 0x01, 0x01, 0x12, 0x24, 0x0a, 0x0b, 0x73, 0x69, 0x67, 0x6e, 0x69, 0x6e, - 0x67, 0x5f, 0x6b, 0x65, 0x79, 0x18, 0x24, 0x20, 0x01, 0x28, 0x09, 0x48, 0x1f, 0x52, 0x0a, 0x73, - 0x69, 0x67, 0x6e, 0x69, 0x6e, 0x67, 0x4b, 0x65, 0x79, 0x88, 0x01, 0x01, 0x12, 0x63, 0x0a, 0x14, - 0x73, 0x65, 0x74, 0x5f, 0x72, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x5f, 0x68, 0x65, 0x61, - 0x64, 0x65, 0x72, 0x73, 0x18, 0x45, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x31, 0x2e, 0x70, 0x6f, 0x6d, - 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x53, 0x65, 0x74, - 0x74, 0x69, 0x6e, 0x67, 0x73, 0x2e, 0x53, 0x65, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, - 0x65, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x12, 0x73, - 0x65, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, - 0x73, 0x12, 0x5d, 0x0a, 0x12, 0x6a, 0x77, 0x74, 0x5f, 0x63, 0x6c, 0x61, 0x69, 0x6d, 0x73, 0x5f, - 0x68, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x18, 0x3f, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x2f, 0x2e, - 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, - 0x53, 0x65, 0x74, 0x74, 0x69, 0x6e, 0x67, 0x73, 0x2e, 0x4a, 0x77, 0x74, 0x43, 0x6c, 0x61, 0x69, - 0x6d, 0x73, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x10, - 0x6a, 0x77, 0x74, 0x43, 0x6c, 0x61, 0x69, 0x6d, 0x73, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, - 0x12, 0x58, 0x0a, 0x18, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x5f, 0x75, 0x70, 0x73, 0x74, - 0x72, 0x65, 0x61, 0x6d, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x18, 0x27, 0x20, 0x01, - 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, - 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x44, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x20, 0x52, - 0x16, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x55, 0x70, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6d, - 0x54, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x88, 0x01, 0x01, 0x12, 0x2c, 0x0a, 0x0f, 0x6d, 0x65, - 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x18, 0x28, 0x20, - 0x01, 0x28, 0x09, 0x48, 0x21, 0x52, 0x0e, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x41, 0x64, - 0x64, 0x72, 0x65, 0x73, 0x73, 0x88, 0x01, 0x01, 0x12, 0x31, 0x0a, 0x12, 0x6d, 0x65, 0x74, 0x72, - 0x69, 0x63, 0x73, 0x5f, 0x62, 0x61, 0x73, 0x69, 0x63, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x18, 0x40, - 0x20, 0x01, 0x28, 0x09, 0x48, 0x22, 0x52, 0x10, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x42, - 0x61, 0x73, 0x69, 0x63, 0x41, 0x75, 0x74, 0x68, 0x88, 0x01, 0x01, 0x12, 0x5b, 0x0a, 0x13, 0x6d, - 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, - 0x74, 0x65, 0x18, 0x41, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x25, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, - 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x53, 0x65, 0x74, 0x74, 0x69, - 0x6e, 0x67, 0x73, 0x2e, 0x43, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x48, - 0x23, 0x52, 0x12, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x43, 0x65, 0x72, 0x74, 0x69, 0x66, - 0x69, 0x63, 0x61, 0x74, 0x65, 0x88, 0x01, 0x01, 0x12, 0x2f, 0x0a, 0x11, 0x6d, 0x65, 0x74, 0x72, - 0x69, 0x63, 0x73, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x18, 0x42, 0x20, - 0x01, 0x28, 0x09, 0x48, 0x24, 0x52, 0x0f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x43, 0x6c, - 0x69, 0x65, 0x6e, 0x74, 0x43, 0x61, 0x88, 0x01, 0x01, 0x12, 0x38, 0x0a, 0x16, 0x6d, 0x65, 0x74, - 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, 0x66, - 0x69, 0x6c, 0x65, 0x18, 0x43, 0x20, 0x01, 0x28, 0x09, 0x48, 0x25, 0x52, 0x13, 0x6d, 0x65, 0x74, - 0x72, 0x69, 0x63, 0x73, 0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x43, 0x61, 0x46, 0x69, 0x6c, 0x65, - 0x88, 0x01, 0x01, 0x12, 0x2e, 0x0a, 0x10, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x70, - 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x18, 0x29, 0x20, 0x01, 0x28, 0x09, 0x48, 0x26, 0x52, - 0x0f, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x50, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, - 0x88, 0x01, 0x01, 0x12, 0x33, 0x0a, 0x13, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x73, - 0x61, 0x6d, 0x70, 0x6c, 0x65, 0x5f, 0x72, 0x61, 0x74, 0x65, 0x18, 0x2a, 0x20, 0x01, 0x28, 0x01, - 0x48, 0x27, 0x52, 0x11, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x53, 0x61, 0x6d, 0x70, 0x6c, - 0x65, 0x52, 0x61, 0x74, 0x65, 0x88, 0x01, 0x01, 0x12, 0x4e, 0x0a, 0x21, 0x74, 0x72, 0x61, 0x63, - 0x69, 0x6e, 0x67, 0x5f, 0x6a, 0x61, 0x65, 0x67, 0x65, 0x72, 0x5f, 0x63, 0x6f, 0x6c, 0x6c, 0x65, - 0x63, 0x74, 0x6f, 0x72, 0x5f, 0x65, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x18, 0x2b, 0x20, - 0x01, 0x28, 0x09, 0x48, 0x28, 0x52, 0x1e, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x4a, 0x61, - 0x65, 0x67, 0x65, 0x72, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x45, 0x6e, 0x64, - 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x88, 0x01, 0x01, 0x12, 0x46, 0x0a, 0x1d, 0x74, 0x72, 0x61, 0x63, + 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x73, 0x12, 0x48, 0x0a, 0x1e, 0x61, 0x75, 0x74, 0x68, + 0x6f, 0x72, 0x69, 0x7a, 0x65, 0x5f, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x5f, 0x73, + 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x53, 0x20, 0x01, 0x28, 0x09, + 0x48, 0x1d, 0x52, 0x1b, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x7a, 0x65, 0x49, 0x6e, 0x74, + 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x88, + 0x01, 0x01, 0x12, 0x3f, 0x0a, 0x19, 0x6f, 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, 0x65, 0x5f, 0x63, + 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x18, + 0x21, 0x20, 0x01, 0x28, 0x09, 0x48, 0x1e, 0x52, 0x17, 0x6f, 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, + 0x65, 0x43, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x4e, 0x61, 0x6d, 0x65, + 0x88, 0x01, 0x01, 0x12, 0x38, 0x0a, 0x15, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, + 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x18, 0x22, 0x20, 0x01, + 0x28, 0x09, 0x48, 0x1f, 0x52, 0x14, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, + 0x65, 0x41, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x88, 0x01, 0x01, 0x12, 0x41, 0x0a, + 0x1a, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, + 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x23, 0x20, 0x01, 0x28, + 0x09, 0x48, 0x20, 0x52, 0x18, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, + 0x41, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x46, 0x69, 0x6c, 0x65, 0x88, 0x01, 0x01, + 0x12, 0x24, 0x0a, 0x0b, 0x73, 0x69, 0x67, 0x6e, 0x69, 0x6e, 0x67, 0x5f, 0x6b, 0x65, 0x79, 0x18, + 0x24, 0x20, 0x01, 0x28, 0x09, 0x48, 0x21, 0x52, 0x0a, 0x73, 0x69, 0x67, 0x6e, 0x69, 0x6e, 0x67, + 0x4b, 0x65, 0x79, 0x88, 0x01, 0x01, 0x12, 0x63, 0x0a, 0x14, 0x73, 0x65, 0x74, 0x5f, 0x72, 0x65, + 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x5f, 0x68, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x18, 0x45, + 0x20, 0x03, 0x28, 0x0b, 0x32, 0x31, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, + 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x53, 0x65, 0x74, 0x74, 0x69, 0x6e, 0x67, 0x73, 0x2e, + 0x53, 0x65, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x48, 0x65, 0x61, 0x64, 0x65, + 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x12, 0x73, 0x65, 0x74, 0x52, 0x65, 0x73, 0x70, + 0x6f, 0x6e, 0x73, 0x65, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x12, 0x5d, 0x0a, 0x12, 0x6a, + 0x77, 0x74, 0x5f, 0x63, 0x6c, 0x61, 0x69, 0x6d, 0x73, 0x5f, 0x68, 0x65, 0x61, 0x64, 0x65, 0x72, + 0x73, 0x18, 0x3f, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x2f, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, + 0x75, 0x6d, 0x2e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x53, 0x65, 0x74, 0x74, 0x69, 0x6e, + 0x67, 0x73, 0x2e, 0x4a, 0x77, 0x74, 0x43, 0x6c, 0x61, 0x69, 0x6d, 0x73, 0x48, 0x65, 0x61, 0x64, + 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x52, 0x10, 0x6a, 0x77, 0x74, 0x43, 0x6c, 0x61, + 0x69, 0x6d, 0x73, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x12, 0x58, 0x0a, 0x18, 0x64, 0x65, + 0x66, 0x61, 0x75, 0x6c, 0x74, 0x5f, 0x75, 0x70, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6d, 0x5f, 0x74, + 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x18, 0x27, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x67, + 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x44, + 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x48, 0x22, 0x52, 0x16, 0x64, 0x65, 0x66, 0x61, 0x75, + 0x6c, 0x74, 0x55, 0x70, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6d, 0x54, 0x69, 0x6d, 0x65, 0x6f, 0x75, + 0x74, 0x88, 0x01, 0x01, 0x12, 0x2c, 0x0a, 0x0f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, + 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x18, 0x28, 0x20, 0x01, 0x28, 0x09, 0x48, 0x23, 0x52, + 0x0e, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x41, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x88, + 0x01, 0x01, 0x12, 0x31, 0x0a, 0x12, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x62, 0x61, + 0x73, 0x69, 0x63, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x18, 0x40, 0x20, 0x01, 0x28, 0x09, 0x48, 0x24, + 0x52, 0x10, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x42, 0x61, 0x73, 0x69, 0x63, 0x41, 0x75, + 0x74, 0x68, 0x88, 0x01, 0x01, 0x12, 0x5b, 0x0a, 0x13, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, + 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x18, 0x41, 0x20, 0x01, + 0x28, 0x0b, 0x32, 0x25, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x6f, + 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x53, 0x65, 0x74, 0x74, 0x69, 0x6e, 0x67, 0x73, 0x2e, 0x43, 0x65, + 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x48, 0x25, 0x52, 0x12, 0x6d, 0x65, 0x74, + 0x72, 0x69, 0x63, 0x73, 0x43, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x88, + 0x01, 0x01, 0x12, 0x2f, 0x0a, 0x11, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x6c, + 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x18, 0x42, 0x20, 0x01, 0x28, 0x09, 0x48, 0x26, 0x52, + 0x0f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x43, 0x61, + 0x88, 0x01, 0x01, 0x12, 0x38, 0x0a, 0x16, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, + 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x43, 0x20, + 0x01, 0x28, 0x09, 0x48, 0x27, 0x52, 0x13, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x43, 0x6c, + 0x69, 0x65, 0x6e, 0x74, 0x43, 0x61, 0x46, 0x69, 0x6c, 0x65, 0x88, 0x01, 0x01, 0x12, 0x2e, 0x0a, + 0x10, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, + 0x72, 0x18, 0x29, 0x20, 0x01, 0x28, 0x09, 0x48, 0x28, 0x52, 0x0f, 0x74, 0x72, 0x61, 0x63, 0x69, + 0x6e, 0x67, 0x50, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x88, 0x01, 0x01, 0x12, 0x33, 0x0a, + 0x13, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x73, 0x61, 0x6d, 0x70, 0x6c, 0x65, 0x5f, + 0x72, 0x61, 0x74, 0x65, 0x18, 0x2a, 0x20, 0x01, 0x28, 0x01, 0x48, 0x29, 0x52, 0x11, 0x74, 0x72, + 0x61, 0x63, 0x69, 0x6e, 0x67, 0x53, 0x61, 0x6d, 0x70, 0x6c, 0x65, 0x52, 0x61, 0x74, 0x65, 0x88, + 0x01, 0x01, 0x12, 0x4e, 0x0a, 0x21, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x6a, 0x61, + 0x65, 0x67, 0x65, 0x72, 0x5f, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x5f, 0x65, + 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x18, 0x2b, 0x20, 0x01, 0x28, 0x09, 0x48, 0x2a, 0x52, + 0x1e, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x4a, 0x61, 0x65, 0x67, 0x65, 0x72, 0x43, 0x6f, + 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x45, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x88, + 0x01, 0x01, 0x12, 0x46, 0x0a, 0x1d, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x6a, 0x61, + 0x65, 0x67, 0x65, 0x72, 0x5f, 0x61, 0x67, 0x65, 0x6e, 0x74, 0x5f, 0x65, 0x6e, 0x64, 0x70, 0x6f, + 0x69, 0x6e, 0x74, 0x18, 0x2c, 0x20, 0x01, 0x28, 0x09, 0x48, 0x2b, 0x52, 0x1a, 0x74, 0x72, 0x61, + 0x63, 0x69, 0x6e, 0x67, 0x4a, 0x61, 0x65, 0x67, 0x65, 0x72, 0x41, 0x67, 0x65, 0x6e, 0x74, 0x45, + 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x88, 0x01, 0x01, 0x12, 0x3b, 0x0a, 0x17, 0x74, 0x72, + 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x7a, 0x69, 0x70, 0x6b, 0x69, 0x6e, 0x5f, 0x65, 0x6e, 0x64, + 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x18, 0x2d, 0x20, 0x01, 0x28, 0x09, 0x48, 0x2c, 0x52, 0x15, 0x74, + 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5a, 0x69, 0x70, 0x6b, 0x69, 0x6e, 0x45, 0x6e, 0x64, 0x70, + 0x6f, 0x69, 0x6e, 0x74, 0x88, 0x01, 0x01, 0x12, 0x26, 0x0a, 0x0c, 0x67, 0x72, 0x70, 0x63, 0x5f, + 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x18, 0x2e, 0x20, 0x01, 0x28, 0x09, 0x48, 0x2d, 0x52, + 0x0b, 0x67, 0x72, 0x70, 0x63, 0x41, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x88, 0x01, 0x01, 0x12, + 0x28, 0x0a, 0x0d, 0x67, 0x72, 0x70, 0x63, 0x5f, 0x69, 0x6e, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, + 0x18, 0x2f, 0x20, 0x01, 0x28, 0x08, 0x48, 0x2e, 0x52, 0x0c, 0x67, 0x72, 0x70, 0x63, 0x49, 0x6e, + 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x88, 0x01, 0x01, 0x12, 0x2d, 0x0a, 0x10, 0x66, 0x6f, 0x72, + 0x77, 0x61, 0x72, 0x64, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x32, 0x20, + 0x01, 0x28, 0x09, 0x48, 0x2f, 0x52, 0x0e, 0x66, 0x6f, 0x72, 0x77, 0x61, 0x72, 0x64, 0x41, 0x75, + 0x74, 0x68, 0x55, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x36, 0x0a, 0x17, 0x64, 0x61, 0x74, 0x61, + 0x62, 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, + 0x72, 0x6c, 0x73, 0x18, 0x34, 0x20, 0x03, 0x28, 0x09, 0x52, 0x15, 0x64, 0x61, 0x74, 0x61, 0x62, + 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x73, + 0x12, 0x4a, 0x0a, 0x1f, 0x64, 0x61, 0x74, 0x61, 0x62, 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x5f, 0x69, + 0x6e, 0x74, 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, + 0x75, 0x72, 0x6c, 0x18, 0x54, 0x20, 0x01, 0x28, 0x09, 0x48, 0x30, 0x52, 0x1c, 0x64, 0x61, 0x74, + 0x61, 0x62, 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x49, 0x6e, 0x74, 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x53, + 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x55, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x20, 0x0a, 0x09, + 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x18, 0x35, 0x20, 0x01, 0x28, 0x09, 0x48, + 0x31, 0x52, 0x08, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x43, 0x61, 0x88, 0x01, 0x01, 0x12, 0x29, + 0x0a, 0x0e, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, + 0x18, 0x36, 0x20, 0x01, 0x28, 0x09, 0x48, 0x32, 0x52, 0x0c, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, + 0x43, 0x61, 0x46, 0x69, 0x6c, 0x65, 0x88, 0x01, 0x01, 0x12, 0x22, 0x0a, 0x0a, 0x63, 0x6c, 0x69, + 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, 0x6c, 0x18, 0x4a, 0x20, 0x01, 0x28, 0x09, 0x48, 0x33, 0x52, + 0x09, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x43, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x2b, 0x0a, + 0x0f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, 0x6c, 0x5f, 0x66, 0x69, 0x6c, 0x65, + 0x18, 0x4b, 0x20, 0x01, 0x28, 0x09, 0x48, 0x34, 0x52, 0x0d, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, + 0x43, 0x72, 0x6c, 0x46, 0x69, 0x6c, 0x65, 0x88, 0x01, 0x01, 0x12, 0x76, 0x0a, 0x36, 0x67, 0x6f, + 0x6f, 0x67, 0x6c, 0x65, 0x5f, 0x63, 0x6c, 0x6f, 0x75, 0x64, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x65, + 0x72, 0x6c, 0x65, 0x73, 0x73, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, + 0x74, 0x69, 0x6f, 0x6e, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x61, 0x63, 0x63, + 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x37, 0x20, 0x01, 0x28, 0x09, 0x48, 0x35, 0x52, 0x31, 0x67, 0x6f, + 0x6f, 0x67, 0x6c, 0x65, 0x43, 0x6c, 0x6f, 0x75, 0x64, 0x53, 0x65, 0x72, 0x76, 0x65, 0x72, 0x6c, + 0x65, 0x73, 0x73, 0x41, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, + 0x6e, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x41, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x88, + 0x01, 0x01, 0x12, 0x1f, 0x0a, 0x08, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x18, 0x38, + 0x20, 0x01, 0x28, 0x08, 0x48, 0x36, 0x52, 0x08, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, + 0x88, 0x01, 0x01, 0x12, 0x24, 0x0a, 0x0b, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, + 0x63, 0x61, 0x18, 0x4c, 0x20, 0x01, 0x28, 0x09, 0x48, 0x37, 0x52, 0x0a, 0x61, 0x75, 0x74, 0x6f, + 0x63, 0x65, 0x72, 0x74, 0x43, 0x61, 0x88, 0x01, 0x01, 0x12, 0x2a, 0x0a, 0x0e, 0x61, 0x75, 0x74, + 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x18, 0x4d, 0x20, 0x01, 0x28, + 0x09, 0x48, 0x38, 0x52, 0x0d, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x45, 0x6d, 0x61, + 0x69, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x32, 0x0a, 0x13, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, + 0x74, 0x5f, 0x65, 0x61, 0x62, 0x5f, 0x6b, 0x65, 0x79, 0x5f, 0x69, 0x64, 0x18, 0x4e, 0x20, 0x01, + 0x28, 0x09, 0x48, 0x39, 0x52, 0x10, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x45, 0x61, + 0x62, 0x4b, 0x65, 0x79, 0x49, 0x64, 0x88, 0x01, 0x01, 0x12, 0x34, 0x0a, 0x14, 0x61, 0x75, 0x74, + 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x61, 0x62, 0x5f, 0x6d, 0x61, 0x63, 0x5f, 0x6b, 0x65, + 0x79, 0x18, 0x4f, 0x20, 0x01, 0x28, 0x09, 0x48, 0x3a, 0x52, 0x11, 0x61, 0x75, 0x74, 0x6f, 0x63, + 0x65, 0x72, 0x74, 0x45, 0x61, 0x62, 0x4d, 0x61, 0x63, 0x4b, 0x65, 0x79, 0x88, 0x01, 0x01, 0x12, + 0x33, 0x0a, 0x13, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x74, 0x72, 0x75, 0x73, + 0x74, 0x65, 0x64, 0x5f, 0x63, 0x61, 0x18, 0x50, 0x20, 0x01, 0x28, 0x09, 0x48, 0x3b, 0x52, 0x11, + 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x54, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x43, + 0x61, 0x88, 0x01, 0x01, 0x12, 0x3c, 0x0a, 0x18, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, + 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, + 0x18, 0x51, 0x20, 0x01, 0x28, 0x09, 0x48, 0x3c, 0x52, 0x15, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, + 0x72, 0x74, 0x54, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x43, 0x61, 0x46, 0x69, 0x6c, 0x65, 0x88, + 0x01, 0x01, 0x12, 0x35, 0x0a, 0x14, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x75, + 0x73, 0x65, 0x5f, 0x73, 0x74, 0x61, 0x67, 0x69, 0x6e, 0x67, 0x18, 0x39, 0x20, 0x01, 0x28, 0x08, + 0x48, 0x3d, 0x52, 0x12, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x55, 0x73, 0x65, 0x53, + 0x74, 0x61, 0x67, 0x69, 0x6e, 0x67, 0x88, 0x01, 0x01, 0x12, 0x35, 0x0a, 0x14, 0x61, 0x75, 0x74, + 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x6d, 0x75, 0x73, 0x74, 0x5f, 0x73, 0x74, 0x61, 0x70, 0x6c, + 0x65, 0x18, 0x3a, 0x20, 0x01, 0x28, 0x08, 0x48, 0x3e, 0x52, 0x12, 0x61, 0x75, 0x74, 0x6f, 0x63, + 0x65, 0x72, 0x74, 0x4d, 0x75, 0x73, 0x74, 0x53, 0x74, 0x61, 0x70, 0x6c, 0x65, 0x88, 0x01, 0x01, + 0x12, 0x26, 0x0a, 0x0c, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x64, 0x69, 0x72, + 0x18, 0x3b, 0x20, 0x01, 0x28, 0x09, 0x48, 0x3f, 0x52, 0x0b, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, + 0x72, 0x74, 0x44, 0x69, 0x72, 0x88, 0x01, 0x01, 0x12, 0x2b, 0x0a, 0x0f, 0x73, 0x6b, 0x69, 0x70, + 0x5f, 0x78, 0x66, 0x66, 0x5f, 0x61, 0x70, 0x70, 0x65, 0x6e, 0x64, 0x18, 0x3d, 0x20, 0x01, 0x28, + 0x08, 0x48, 0x40, 0x52, 0x0d, 0x73, 0x6b, 0x69, 0x70, 0x58, 0x66, 0x66, 0x41, 0x70, 0x70, 0x65, + 0x6e, 0x64, 0x88, 0x01, 0x01, 0x12, 0x34, 0x0a, 0x14, 0x78, 0x66, 0x66, 0x5f, 0x6e, 0x75, 0x6d, + 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x68, 0x6f, 0x70, 0x73, 0x18, 0x46, 0x20, + 0x01, 0x28, 0x0d, 0x48, 0x41, 0x52, 0x11, 0x78, 0x66, 0x66, 0x4e, 0x75, 0x6d, 0x54, 0x72, 0x75, + 0x73, 0x74, 0x65, 0x64, 0x48, 0x6f, 0x70, 0x73, 0x88, 0x01, 0x01, 0x12, 0x53, 0x0a, 0x26, 0x70, + 0x72, 0x6f, 0x67, 0x72, 0x61, 0x6d, 0x6d, 0x61, 0x74, 0x69, 0x63, 0x5f, 0x72, 0x65, 0x64, 0x69, + 0x72, 0x65, 0x63, 0x74, 0x5f, 0x64, 0x6f, 0x6d, 0x61, 0x69, 0x6e, 0x5f, 0x77, 0x68, 0x69, 0x74, + 0x65, 0x6c, 0x69, 0x73, 0x74, 0x18, 0x44, 0x20, 0x03, 0x28, 0x09, 0x52, 0x23, 0x70, 0x72, 0x6f, + 0x67, 0x72, 0x61, 0x6d, 0x6d, 0x61, 0x74, 0x69, 0x63, 0x52, 0x65, 0x64, 0x69, 0x72, 0x65, 0x63, + 0x74, 0x44, 0x6f, 0x6d, 0x61, 0x69, 0x6e, 0x57, 0x68, 0x69, 0x74, 0x65, 0x6c, 0x69, 0x73, 0x74, + 0x12, 0x48, 0x0a, 0x09, 0x61, 0x75, 0x64, 0x69, 0x74, 0x5f, 0x6b, 0x65, 0x79, 0x18, 0x48, 0x20, + 0x01, 0x28, 0x0b, 0x32, 0x26, 0x2e, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, + 0x72, 0x79, 0x70, 0x74, 0x2e, 0x50, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x4b, 0x65, 0x79, 0x45, 0x6e, + 0x63, 0x72, 0x79, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x4b, 0x65, 0x79, 0x48, 0x42, 0x52, 0x08, 0x61, + 0x75, 0x64, 0x69, 0x74, 0x4b, 0x65, 0x79, 0x88, 0x01, 0x01, 0x12, 0x80, 0x01, 0x0a, 0x0a, 0x63, + 0x6f, 0x64, 0x65, 0x63, 0x5f, 0x74, 0x79, 0x70, 0x65, 0x18, 0x49, 0x20, 0x01, 0x28, 0x0e, 0x32, + 0x5c, 0x2e, 0x65, 0x6e, 0x76, 0x6f, 0x79, 0x2e, 0x65, 0x78, 0x74, 0x65, 0x6e, 0x73, 0x69, 0x6f, + 0x6e, 0x73, 0x2e, 0x66, 0x69, 0x6c, 0x74, 0x65, 0x72, 0x73, 0x2e, 0x6e, 0x65, 0x74, 0x77, 0x6f, + 0x72, 0x6b, 0x2e, 0x68, 0x74, 0x74, 0x70, 0x5f, 0x63, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, + 0x6f, 0x6e, 0x5f, 0x6d, 0x61, 0x6e, 0x61, 0x67, 0x65, 0x72, 0x2e, 0x76, 0x33, 0x2e, 0x48, 0x74, + 0x74, 0x70, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x61, 0x6e, 0x61, + 0x67, 0x65, 0x72, 0x2e, 0x43, 0x6f, 0x64, 0x65, 0x63, 0x54, 0x79, 0x70, 0x65, 0x48, 0x43, 0x52, + 0x09, 0x63, 0x6f, 0x64, 0x65, 0x63, 0x54, 0x79, 0x70, 0x65, 0x88, 0x01, 0x01, 0x1a, 0x81, 0x01, + 0x0a, 0x0b, 0x43, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x12, 0x1b, 0x0a, + 0x09, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, + 0x52, 0x08, 0x63, 0x65, 0x72, 0x74, 0x46, 0x69, 0x6c, 0x65, 0x12, 0x19, 0x0a, 0x08, 0x6b, 0x65, + 0x79, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x6b, 0x65, + 0x79, 0x46, 0x69, 0x6c, 0x65, 0x12, 0x1d, 0x0a, 0x0a, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x62, 0x79, + 0x74, 0x65, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x09, 0x63, 0x65, 0x72, 0x74, 0x42, + 0x79, 0x74, 0x65, 0x73, 0x12, 0x1b, 0x0a, 0x09, 0x6b, 0x65, 0x79, 0x5f, 0x62, 0x79, 0x74, 0x65, + 0x73, 0x18, 0x04, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x08, 0x6b, 0x65, 0x79, 0x42, 0x79, 0x74, 0x65, + 0x73, 0x1a, 0x40, 0x0a, 0x12, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x50, 0x61, 0x72, 0x61, + 0x6d, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, + 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, + 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, + 0x02, 0x38, 0x01, 0x1a, 0x45, 0x0a, 0x17, 0x53, 0x65, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, + 0x73, 0x65, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, + 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, + 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, + 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x1a, 0x43, 0x0a, 0x15, 0x4a, 0x77, + 0x74, 0x43, 0x6c, 0x61, 0x69, 0x6d, 0x73, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x45, 0x6e, + 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, + 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, + 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x42, + 0x12, 0x0a, 0x10, 0x5f, 0x69, 0x6e, 0x73, 0x74, 0x61, 0x6c, 0x6c, 0x61, 0x74, 0x69, 0x6f, 0x6e, + 0x5f, 0x69, 0x64, 0x42, 0x08, 0x0a, 0x06, 0x5f, 0x64, 0x65, 0x62, 0x75, 0x67, 0x42, 0x0c, 0x0a, + 0x0a, 0x5f, 0x6c, 0x6f, 0x67, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x42, 0x12, 0x0a, 0x10, 0x5f, + 0x70, 0x72, 0x6f, 0x78, 0x79, 0x5f, 0x6c, 0x6f, 0x67, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x42, + 0x10, 0x0a, 0x0e, 0x5f, 0x73, 0x68, 0x61, 0x72, 0x65, 0x64, 0x5f, 0x73, 0x65, 0x63, 0x72, 0x65, + 0x74, 0x42, 0x0b, 0x0a, 0x09, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x73, 0x42, 0x0a, + 0x0a, 0x08, 0x5f, 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x69, + 0x6e, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x42, 0x14, + 0x0a, 0x12, 0x5f, 0x64, 0x6e, 0x73, 0x5f, 0x6c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x5f, 0x66, 0x61, + 0x6d, 0x69, 0x6c, 0x79, 0x42, 0x15, 0x0a, 0x13, 0x5f, 0x68, 0x74, 0x74, 0x70, 0x5f, 0x72, 0x65, + 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x5f, 0x61, 0x64, 0x64, 0x72, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, + 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x5f, 0x72, 0x65, 0x61, 0x64, 0x42, 0x10, 0x0a, 0x0e, + 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x5f, 0x77, 0x72, 0x69, 0x74, 0x65, 0x42, 0x0f, + 0x0a, 0x0d, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x5f, 0x69, 0x64, 0x6c, 0x65, 0x42, + 0x1b, 0x0a, 0x19, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, + 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x42, 0x24, 0x0a, 0x22, + 0x5f, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x69, 0x6e, + 0x74, 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, + 0x72, 0x6c, 0x42, 0x1d, 0x0a, 0x1b, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, + 0x61, 0x74, 0x65, 0x5f, 0x63, 0x61, 0x6c, 0x6c, 0x62, 0x61, 0x63, 0x6b, 0x5f, 0x70, 0x61, 0x74, + 0x68, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x6e, 0x61, 0x6d, + 0x65, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x73, 0x65, 0x63, + 0x72, 0x65, 0x74, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x64, + 0x6f, 0x6d, 0x61, 0x69, 0x6e, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, + 0x5f, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x42, 0x13, 0x0a, 0x11, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, + 0x69, 0x65, 0x5f, 0x68, 0x74, 0x74, 0x70, 0x5f, 0x6f, 0x6e, 0x6c, 0x79, 0x42, 0x10, 0x0a, 0x0e, + 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x65, 0x78, 0x70, 0x69, 0x72, 0x65, 0x42, 0x10, + 0x0a, 0x0e, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x69, 0x64, + 0x42, 0x14, 0x0a, 0x12, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, + 0x73, 0x65, 0x63, 0x72, 0x65, 0x74, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x70, + 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x42, 0x13, 0x0a, 0x11, 0x5f, 0x69, 0x64, 0x70, 0x5f, + 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x5f, 0x75, 0x72, 0x6c, 0x42, 0x16, 0x0a, 0x14, + 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x61, 0x63, 0x63, + 0x6f, 0x75, 0x6e, 0x74, 0x42, 0x20, 0x0a, 0x1e, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x72, 0x65, 0x66, + 0x72, 0x65, 0x73, 0x68, 0x5f, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x79, 0x5f, 0x74, + 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x42, 0x21, 0x0a, 0x1f, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x72, + 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x79, + 0x5f, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x42, 0x21, 0x0a, 0x1f, 0x5f, 0x61, 0x75, + 0x74, 0x68, 0x6f, 0x72, 0x69, 0x7a, 0x65, 0x5f, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x6e, 0x61, 0x6c, + 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x42, 0x1c, 0x0a, 0x1a, + 0x5f, 0x6f, 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, 0x65, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, + 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x42, 0x18, 0x0a, 0x16, 0x5f, 0x63, + 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x6f, + 0x72, 0x69, 0x74, 0x79, 0x42, 0x1d, 0x0a, 0x1b, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, + 0x63, 0x61, 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x5f, 0x66, + 0x69, 0x6c, 0x65, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x73, 0x69, 0x67, 0x6e, 0x69, 0x6e, 0x67, 0x5f, + 0x6b, 0x65, 0x79, 0x42, 0x1b, 0x0a, 0x19, 0x5f, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x5f, + 0x75, 0x70, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6d, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, + 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x61, 0x64, 0x64, + 0x72, 0x65, 0x73, 0x73, 0x42, 0x15, 0x0a, 0x13, 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, + 0x5f, 0x62, 0x61, 0x73, 0x69, 0x63, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x42, 0x16, 0x0a, 0x14, 0x5f, + 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, + 0x61, 0x74, 0x65, 0x42, 0x14, 0x0a, 0x12, 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, + 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x42, 0x19, 0x0a, 0x17, 0x5f, 0x6d, 0x65, + 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, + 0x66, 0x69, 0x6c, 0x65, 0x42, 0x13, 0x0a, 0x11, 0x5f, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, + 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x42, 0x16, 0x0a, 0x14, 0x5f, 0x74, 0x72, + 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x73, 0x61, 0x6d, 0x70, 0x6c, 0x65, 0x5f, 0x72, 0x61, 0x74, + 0x65, 0x42, 0x24, 0x0a, 0x22, 0x5f, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x6a, 0x61, + 0x65, 0x67, 0x65, 0x72, 0x5f, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x5f, 0x65, + 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x42, 0x20, 0x0a, 0x1e, 0x5f, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x6a, 0x61, 0x65, 0x67, 0x65, 0x72, 0x5f, 0x61, 0x67, 0x65, 0x6e, 0x74, - 0x5f, 0x65, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x18, 0x2c, 0x20, 0x01, 0x28, 0x09, 0x48, - 0x29, 0x52, 0x1a, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x4a, 0x61, 0x65, 0x67, 0x65, 0x72, - 0x41, 0x67, 0x65, 0x6e, 0x74, 0x45, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x88, 0x01, 0x01, - 0x12, 0x3b, 0x0a, 0x17, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x7a, 0x69, 0x70, 0x6b, - 0x69, 0x6e, 0x5f, 0x65, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x18, 0x2d, 0x20, 0x01, 0x28, - 0x09, 0x48, 0x2a, 0x52, 0x15, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5a, 0x69, 0x70, 0x6b, - 0x69, 0x6e, 0x45, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x88, 0x01, 0x01, 0x12, 0x26, 0x0a, - 0x0c, 0x67, 0x72, 0x70, 0x63, 0x5f, 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x18, 0x2e, 0x20, - 0x01, 0x28, 0x09, 0x48, 0x2b, 0x52, 0x0b, 0x67, 0x72, 0x70, 0x63, 0x41, 0x64, 0x64, 0x72, 0x65, - 0x73, 0x73, 0x88, 0x01, 0x01, 0x12, 0x28, 0x0a, 0x0d, 0x67, 0x72, 0x70, 0x63, 0x5f, 0x69, 0x6e, - 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x18, 0x2f, 0x20, 0x01, 0x28, 0x08, 0x48, 0x2c, 0x52, 0x0c, - 0x67, 0x72, 0x70, 0x63, 0x49, 0x6e, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x88, 0x01, 0x01, 0x12, - 0x2d, 0x0a, 0x10, 0x66, 0x6f, 0x72, 0x77, 0x61, 0x72, 0x64, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x5f, - 0x75, 0x72, 0x6c, 0x18, 0x32, 0x20, 0x01, 0x28, 0x09, 0x48, 0x2d, 0x52, 0x0e, 0x66, 0x6f, 0x72, - 0x77, 0x61, 0x72, 0x64, 0x41, 0x75, 0x74, 0x68, 0x55, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x36, - 0x0a, 0x17, 0x64, 0x61, 0x74, 0x61, 0x62, 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x5f, 0x73, 0x65, 0x72, - 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x73, 0x18, 0x34, 0x20, 0x03, 0x28, 0x09, 0x52, - 0x15, 0x64, 0x61, 0x74, 0x61, 0x62, 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x53, 0x65, 0x72, 0x76, 0x69, - 0x63, 0x65, 0x55, 0x72, 0x6c, 0x73, 0x12, 0x20, 0x0a, 0x09, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, - 0x5f, 0x63, 0x61, 0x18, 0x35, 0x20, 0x01, 0x28, 0x09, 0x48, 0x2e, 0x52, 0x08, 0x63, 0x6c, 0x69, - 0x65, 0x6e, 0x74, 0x43, 0x61, 0x88, 0x01, 0x01, 0x12, 0x29, 0x0a, 0x0e, 0x63, 0x6c, 0x69, 0x65, - 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x36, 0x20, 0x01, 0x28, 0x09, - 0x48, 0x2f, 0x52, 0x0c, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x43, 0x61, 0x46, 0x69, 0x6c, 0x65, - 0x88, 0x01, 0x01, 0x12, 0x22, 0x0a, 0x0a, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, - 0x6c, 0x18, 0x4a, 0x20, 0x01, 0x28, 0x09, 0x48, 0x30, 0x52, 0x09, 0x63, 0x6c, 0x69, 0x65, 0x6e, - 0x74, 0x43, 0x72, 0x6c, 0x88, 0x01, 0x01, 0x12, 0x2b, 0x0a, 0x0f, 0x63, 0x6c, 0x69, 0x65, 0x6e, - 0x74, 0x5f, 0x63, 0x72, 0x6c, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x4b, 0x20, 0x01, 0x28, 0x09, - 0x48, 0x31, 0x52, 0x0d, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x43, 0x72, 0x6c, 0x46, 0x69, 0x6c, - 0x65, 0x88, 0x01, 0x01, 0x12, 0x76, 0x0a, 0x36, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x5f, 0x63, - 0x6c, 0x6f, 0x75, 0x64, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x6c, 0x65, 0x73, 0x73, 0x5f, - 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x5f, 0x73, - 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x37, - 0x20, 0x01, 0x28, 0x09, 0x48, 0x32, 0x52, 0x31, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x43, 0x6c, - 0x6f, 0x75, 0x64, 0x53, 0x65, 0x72, 0x76, 0x65, 0x72, 0x6c, 0x65, 0x73, 0x73, 0x41, 0x75, 0x74, - 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x53, 0x65, 0x72, 0x76, 0x69, - 0x63, 0x65, 0x41, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x88, 0x01, 0x01, 0x12, 0x1f, 0x0a, 0x08, - 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x18, 0x38, 0x20, 0x01, 0x28, 0x08, 0x48, 0x33, - 0x52, 0x08, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x88, 0x01, 0x01, 0x12, 0x24, 0x0a, - 0x0b, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x63, 0x61, 0x18, 0x4c, 0x20, 0x01, - 0x28, 0x09, 0x48, 0x34, 0x52, 0x0a, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x43, 0x61, - 0x88, 0x01, 0x01, 0x12, 0x2a, 0x0a, 0x0e, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, - 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x18, 0x4d, 0x20, 0x01, 0x28, 0x09, 0x48, 0x35, 0x52, 0x0d, 0x61, - 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x45, 0x6d, 0x61, 0x69, 0x6c, 0x88, 0x01, 0x01, 0x12, - 0x32, 0x0a, 0x13, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x61, 0x62, 0x5f, - 0x6b, 0x65, 0x79, 0x5f, 0x69, 0x64, 0x18, 0x4e, 0x20, 0x01, 0x28, 0x09, 0x48, 0x36, 0x52, 0x10, - 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x45, 0x61, 0x62, 0x4b, 0x65, 0x79, 0x49, 0x64, - 0x88, 0x01, 0x01, 0x12, 0x34, 0x0a, 0x14, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, - 0x65, 0x61, 0x62, 0x5f, 0x6d, 0x61, 0x63, 0x5f, 0x6b, 0x65, 0x79, 0x18, 0x4f, 0x20, 0x01, 0x28, - 0x09, 0x48, 0x37, 0x52, 0x11, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x45, 0x61, 0x62, - 0x4d, 0x61, 0x63, 0x4b, 0x65, 0x79, 0x88, 0x01, 0x01, 0x12, 0x33, 0x0a, 0x13, 0x61, 0x75, 0x74, - 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x63, 0x61, - 0x18, 0x50, 0x20, 0x01, 0x28, 0x09, 0x48, 0x38, 0x52, 0x11, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, - 0x72, 0x74, 0x54, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x43, 0x61, 0x88, 0x01, 0x01, 0x12, 0x3c, - 0x0a, 0x18, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, - 0x65, 0x64, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x18, 0x51, 0x20, 0x01, 0x28, 0x09, - 0x48, 0x39, 0x52, 0x15, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x54, 0x72, 0x75, 0x73, - 0x74, 0x65, 0x64, 0x43, 0x61, 0x46, 0x69, 0x6c, 0x65, 0x88, 0x01, 0x01, 0x12, 0x35, 0x0a, 0x14, - 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x75, 0x73, 0x65, 0x5f, 0x73, 0x74, 0x61, - 0x67, 0x69, 0x6e, 0x67, 0x18, 0x39, 0x20, 0x01, 0x28, 0x08, 0x48, 0x3a, 0x52, 0x12, 0x61, 0x75, - 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x55, 0x73, 0x65, 0x53, 0x74, 0x61, 0x67, 0x69, 0x6e, 0x67, - 0x88, 0x01, 0x01, 0x12, 0x35, 0x0a, 0x14, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, - 0x6d, 0x75, 0x73, 0x74, 0x5f, 0x73, 0x74, 0x61, 0x70, 0x6c, 0x65, 0x18, 0x3a, 0x20, 0x01, 0x28, - 0x08, 0x48, 0x3b, 0x52, 0x12, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x4d, 0x75, 0x73, - 0x74, 0x53, 0x74, 0x61, 0x70, 0x6c, 0x65, 0x88, 0x01, 0x01, 0x12, 0x26, 0x0a, 0x0c, 0x61, 0x75, - 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x64, 0x69, 0x72, 0x18, 0x3b, 0x20, 0x01, 0x28, 0x09, - 0x48, 0x3c, 0x52, 0x0b, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x44, 0x69, 0x72, 0x88, - 0x01, 0x01, 0x12, 0x2b, 0x0a, 0x0f, 0x73, 0x6b, 0x69, 0x70, 0x5f, 0x78, 0x66, 0x66, 0x5f, 0x61, - 0x70, 0x70, 0x65, 0x6e, 0x64, 0x18, 0x3d, 0x20, 0x01, 0x28, 0x08, 0x48, 0x3d, 0x52, 0x0d, 0x73, - 0x6b, 0x69, 0x70, 0x58, 0x66, 0x66, 0x41, 0x70, 0x70, 0x65, 0x6e, 0x64, 0x88, 0x01, 0x01, 0x12, - 0x34, 0x0a, 0x14, 0x78, 0x66, 0x66, 0x5f, 0x6e, 0x75, 0x6d, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, - 0x65, 0x64, 0x5f, 0x68, 0x6f, 0x70, 0x73, 0x18, 0x46, 0x20, 0x01, 0x28, 0x0d, 0x48, 0x3e, 0x52, - 0x11, 0x78, 0x66, 0x66, 0x4e, 0x75, 0x6d, 0x54, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x48, 0x6f, - 0x70, 0x73, 0x88, 0x01, 0x01, 0x12, 0x53, 0x0a, 0x26, 0x70, 0x72, 0x6f, 0x67, 0x72, 0x61, 0x6d, - 0x6d, 0x61, 0x74, 0x69, 0x63, 0x5f, 0x72, 0x65, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x5f, 0x64, - 0x6f, 0x6d, 0x61, 0x69, 0x6e, 0x5f, 0x77, 0x68, 0x69, 0x74, 0x65, 0x6c, 0x69, 0x73, 0x74, 0x18, - 0x44, 0x20, 0x03, 0x28, 0x09, 0x52, 0x23, 0x70, 0x72, 0x6f, 0x67, 0x72, 0x61, 0x6d, 0x6d, 0x61, - 0x74, 0x69, 0x63, 0x52, 0x65, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x44, 0x6f, 0x6d, 0x61, 0x69, - 0x6e, 0x57, 0x68, 0x69, 0x74, 0x65, 0x6c, 0x69, 0x73, 0x74, 0x12, 0x48, 0x0a, 0x09, 0x61, 0x75, - 0x64, 0x69, 0x74, 0x5f, 0x6b, 0x65, 0x79, 0x18, 0x48, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x26, 0x2e, - 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2e, 0x63, 0x72, 0x79, 0x70, 0x74, 0x2e, 0x50, - 0x75, 0x62, 0x6c, 0x69, 0x63, 0x4b, 0x65, 0x79, 0x45, 0x6e, 0x63, 0x72, 0x79, 0x70, 0x74, 0x69, - 0x6f, 0x6e, 0x4b, 0x65, 0x79, 0x48, 0x3f, 0x52, 0x08, 0x61, 0x75, 0x64, 0x69, 0x74, 0x4b, 0x65, - 0x79, 0x88, 0x01, 0x01, 0x12, 0x80, 0x01, 0x0a, 0x0a, 0x63, 0x6f, 0x64, 0x65, 0x63, 0x5f, 0x74, - 0x79, 0x70, 0x65, 0x18, 0x49, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x5c, 0x2e, 0x65, 0x6e, 0x76, 0x6f, - 0x79, 0x2e, 0x65, 0x78, 0x74, 0x65, 0x6e, 0x73, 0x69, 0x6f, 0x6e, 0x73, 0x2e, 0x66, 0x69, 0x6c, - 0x74, 0x65, 0x72, 0x73, 0x2e, 0x6e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x2e, 0x68, 0x74, 0x74, - 0x70, 0x5f, 0x63, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x5f, 0x6d, 0x61, 0x6e, - 0x61, 0x67, 0x65, 0x72, 0x2e, 0x76, 0x33, 0x2e, 0x48, 0x74, 0x74, 0x70, 0x43, 0x6f, 0x6e, 0x6e, - 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x61, 0x6e, 0x61, 0x67, 0x65, 0x72, 0x2e, 0x43, 0x6f, - 0x64, 0x65, 0x63, 0x54, 0x79, 0x70, 0x65, 0x48, 0x40, 0x52, 0x09, 0x63, 0x6f, 0x64, 0x65, 0x63, - 0x54, 0x79, 0x70, 0x65, 0x88, 0x01, 0x01, 0x1a, 0x81, 0x01, 0x0a, 0x0b, 0x43, 0x65, 0x72, 0x74, - 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x12, 0x1b, 0x0a, 0x09, 0x63, 0x65, 0x72, 0x74, 0x5f, - 0x66, 0x69, 0x6c, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x08, 0x63, 0x65, 0x72, 0x74, - 0x46, 0x69, 0x6c, 0x65, 0x12, 0x19, 0x0a, 0x08, 0x6b, 0x65, 0x79, 0x5f, 0x66, 0x69, 0x6c, 0x65, - 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x6b, 0x65, 0x79, 0x46, 0x69, 0x6c, 0x65, 0x12, - 0x1d, 0x0a, 0x0a, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x62, 0x79, 0x74, 0x65, 0x73, 0x18, 0x03, 0x20, - 0x01, 0x28, 0x0c, 0x52, 0x09, 0x63, 0x65, 0x72, 0x74, 0x42, 0x79, 0x74, 0x65, 0x73, 0x12, 0x1b, - 0x0a, 0x09, 0x6b, 0x65, 0x79, 0x5f, 0x62, 0x79, 0x74, 0x65, 0x73, 0x18, 0x04, 0x20, 0x01, 0x28, - 0x0c, 0x52, 0x08, 0x6b, 0x65, 0x79, 0x42, 0x79, 0x74, 0x65, 0x73, 0x1a, 0x40, 0x0a, 0x12, 0x52, - 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x50, 0x61, 0x72, 0x61, 0x6d, 0x73, 0x45, 0x6e, 0x74, 0x72, - 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, - 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, - 0x28, 0x09, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x1a, 0x45, 0x0a, - 0x17, 0x53, 0x65, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x48, 0x65, 0x61, 0x64, - 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, - 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, - 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, - 0x3a, 0x02, 0x38, 0x01, 0x1a, 0x43, 0x0a, 0x15, 0x4a, 0x77, 0x74, 0x43, 0x6c, 0x61, 0x69, 0x6d, - 0x73, 0x48, 0x65, 0x61, 0x64, 0x65, 0x72, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, 0x10, 0x0a, - 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, 0x79, 0x12, - 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, - 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x69, 0x6e, - 0x73, 0x74, 0x61, 0x6c, 0x6c, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x5f, 0x69, 0x64, 0x42, 0x08, 0x0a, - 0x06, 0x5f, 0x64, 0x65, 0x62, 0x75, 0x67, 0x42, 0x0c, 0x0a, 0x0a, 0x5f, 0x6c, 0x6f, 0x67, 0x5f, - 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x70, 0x72, 0x6f, 0x78, 0x79, 0x5f, - 0x6c, 0x6f, 0x67, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x73, 0x68, - 0x61, 0x72, 0x65, 0x64, 0x5f, 0x73, 0x65, 0x63, 0x72, 0x65, 0x74, 0x42, 0x0b, 0x0a, 0x09, 0x5f, - 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x73, 0x42, 0x0a, 0x0a, 0x08, 0x5f, 0x61, 0x64, 0x64, - 0x72, 0x65, 0x73, 0x73, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x69, 0x6e, 0x73, 0x65, 0x63, 0x75, 0x72, - 0x65, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x42, 0x14, 0x0a, 0x12, 0x5f, 0x64, 0x6e, 0x73, - 0x5f, 0x6c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x5f, 0x66, 0x61, 0x6d, 0x69, 0x6c, 0x79, 0x42, 0x15, - 0x0a, 0x13, 0x5f, 0x68, 0x74, 0x74, 0x70, 0x5f, 0x72, 0x65, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, - 0x5f, 0x61, 0x64, 0x64, 0x72, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, - 0x74, 0x5f, 0x72, 0x65, 0x61, 0x64, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, - 0x75, 0x74, 0x5f, 0x77, 0x72, 0x69, 0x74, 0x65, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x74, 0x69, 0x6d, - 0x65, 0x6f, 0x75, 0x74, 0x5f, 0x69, 0x64, 0x6c, 0x65, 0x42, 0x1b, 0x0a, 0x19, 0x5f, 0x61, 0x75, - 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, - 0x63, 0x65, 0x5f, 0x75, 0x72, 0x6c, 0x42, 0x1d, 0x0a, 0x1b, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x65, - 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x63, 0x61, 0x6c, 0x6c, 0x62, 0x61, 0x63, 0x6b, - 0x5f, 0x70, 0x61, 0x74, 0x68, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, - 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, - 0x5f, 0x73, 0x65, 0x63, 0x72, 0x65, 0x74, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, - 0x69, 0x65, 0x5f, 0x64, 0x6f, 0x6d, 0x61, 0x69, 0x6e, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, - 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x42, 0x13, 0x0a, 0x11, 0x5f, - 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x68, 0x74, 0x74, 0x70, 0x5f, 0x6f, 0x6e, 0x6c, 0x79, - 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x63, 0x6f, 0x6f, 0x6b, 0x69, 0x65, 0x5f, 0x65, 0x78, 0x70, 0x69, - 0x72, 0x65, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, - 0x74, 0x5f, 0x69, 0x64, 0x42, 0x14, 0x0a, 0x12, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x63, 0x6c, 0x69, - 0x65, 0x6e, 0x74, 0x5f, 0x73, 0x65, 0x63, 0x72, 0x65, 0x74, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x69, - 0x64, 0x70, 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x42, 0x13, 0x0a, 0x11, 0x5f, - 0x69, 0x64, 0x70, 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x5f, 0x75, 0x72, 0x6c, - 0x42, 0x16, 0x0a, 0x14, 0x5f, 0x69, 0x64, 0x70, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, - 0x5f, 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x42, 0x20, 0x0a, 0x1e, 0x5f, 0x69, 0x64, 0x70, - 0x5f, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x64, 0x69, 0x72, 0x65, 0x63, 0x74, 0x6f, - 0x72, 0x79, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, 0x74, 0x42, 0x21, 0x0a, 0x1f, 0x5f, 0x69, - 0x64, 0x70, 0x5f, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x64, 0x69, 0x72, 0x65, 0x63, - 0x74, 0x6f, 0x72, 0x79, 0x5f, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x42, 0x1c, 0x0a, - 0x1a, 0x5f, 0x6f, 0x76, 0x65, 0x72, 0x72, 0x69, 0x64, 0x65, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, - 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x42, 0x18, 0x0a, 0x16, 0x5f, - 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, - 0x6f, 0x72, 0x69, 0x74, 0x79, 0x42, 0x1d, 0x0a, 0x1b, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, - 0x69, 0x63, 0x61, 0x74, 0x65, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, 0x69, 0x74, 0x79, 0x5f, - 0x66, 0x69, 0x6c, 0x65, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x73, 0x69, 0x67, 0x6e, 0x69, 0x6e, 0x67, - 0x5f, 0x6b, 0x65, 0x79, 0x42, 0x1b, 0x0a, 0x19, 0x5f, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, - 0x5f, 0x75, 0x70, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6d, 0x5f, 0x74, 0x69, 0x6d, 0x65, 0x6f, 0x75, - 0x74, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x61, 0x64, - 0x64, 0x72, 0x65, 0x73, 0x73, 0x42, 0x15, 0x0a, 0x13, 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, - 0x73, 0x5f, 0x62, 0x61, 0x73, 0x69, 0x63, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x42, 0x16, 0x0a, 0x14, - 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x65, 0x72, 0x74, 0x69, 0x66, 0x69, - 0x63, 0x61, 0x74, 0x65, 0x42, 0x14, 0x0a, 0x12, 0x5f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, - 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x42, 0x19, 0x0a, 0x17, 0x5f, 0x6d, - 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, - 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x42, 0x13, 0x0a, 0x11, 0x5f, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, - 0x67, 0x5f, 0x70, 0x72, 0x6f, 0x76, 0x69, 0x64, 0x65, 0x72, 0x42, 0x16, 0x0a, 0x14, 0x5f, 0x74, - 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x73, 0x61, 0x6d, 0x70, 0x6c, 0x65, 0x5f, 0x72, 0x61, - 0x74, 0x65, 0x42, 0x24, 0x0a, 0x22, 0x5f, 0x74, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x6a, - 0x61, 0x65, 0x67, 0x65, 0x72, 0x5f, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x6f, 0x72, 0x5f, - 0x65, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x42, 0x20, 0x0a, 0x1e, 0x5f, 0x74, 0x72, 0x61, - 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x6a, 0x61, 0x65, 0x67, 0x65, 0x72, 0x5f, 0x61, 0x67, 0x65, 0x6e, - 0x74, 0x5f, 0x65, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x42, 0x1a, 0x0a, 0x18, 0x5f, 0x74, - 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x7a, 0x69, 0x70, 0x6b, 0x69, 0x6e, 0x5f, 0x65, 0x6e, - 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x67, 0x72, 0x70, 0x63, 0x5f, - 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x67, 0x72, 0x70, 0x63, - 0x5f, 0x69, 0x6e, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x42, 0x13, 0x0a, 0x11, 0x5f, 0x66, 0x6f, - 0x72, 0x77, 0x61, 0x72, 0x64, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x5f, 0x75, 0x72, 0x6c, 0x42, 0x0c, - 0x0a, 0x0a, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x42, 0x11, 0x0a, 0x0f, - 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x42, - 0x0d, 0x0a, 0x0b, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, 0x6c, 0x42, 0x12, - 0x0a, 0x10, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, 0x6c, 0x5f, 0x66, 0x69, - 0x6c, 0x65, 0x42, 0x39, 0x0a, 0x37, 0x5f, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x5f, 0x63, 0x6c, - 0x6f, 0x75, 0x64, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x6c, 0x65, 0x73, 0x73, 0x5f, 0x61, - 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x5f, 0x73, 0x65, - 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x42, 0x0b, 0x0a, - 0x09, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x61, - 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x63, 0x61, 0x42, 0x11, 0x0a, 0x0f, 0x5f, 0x61, - 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x42, 0x16, 0x0a, - 0x14, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x61, 0x62, 0x5f, 0x6b, - 0x65, 0x79, 0x5f, 0x69, 0x64, 0x42, 0x17, 0x0a, 0x15, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, - 0x72, 0x74, 0x5f, 0x65, 0x61, 0x62, 0x5f, 0x6d, 0x61, 0x63, 0x5f, 0x6b, 0x65, 0x79, 0x42, 0x16, - 0x0a, 0x14, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x74, 0x72, 0x75, 0x73, - 0x74, 0x65, 0x64, 0x5f, 0x63, 0x61, 0x42, 0x1b, 0x0a, 0x19, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, - 0x65, 0x72, 0x74, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x63, 0x61, 0x5f, 0x66, - 0x69, 0x6c, 0x65, 0x42, 0x17, 0x0a, 0x15, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, - 0x5f, 0x75, 0x73, 0x65, 0x5f, 0x73, 0x74, 0x61, 0x67, 0x69, 0x6e, 0x67, 0x42, 0x17, 0x0a, 0x15, - 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x6d, 0x75, 0x73, 0x74, 0x5f, 0x73, - 0x74, 0x61, 0x70, 0x6c, 0x65, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, - 0x72, 0x74, 0x5f, 0x64, 0x69, 0x72, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x73, 0x6b, 0x69, 0x70, 0x5f, - 0x78, 0x66, 0x66, 0x5f, 0x61, 0x70, 0x70, 0x65, 0x6e, 0x64, 0x42, 0x17, 0x0a, 0x15, 0x5f, 0x78, - 0x66, 0x66, 0x5f, 0x6e, 0x75, 0x6d, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x68, - 0x6f, 0x70, 0x73, 0x42, 0x0c, 0x0a, 0x0a, 0x5f, 0x61, 0x75, 0x64, 0x69, 0x74, 0x5f, 0x6b, 0x65, - 0x79, 0x42, 0x0d, 0x0a, 0x0b, 0x5f, 0x63, 0x6f, 0x64, 0x65, 0x63, 0x5f, 0x74, 0x79, 0x70, 0x65, - 0x42, 0x2e, 0x5a, 0x2c, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x70, - 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2f, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, - 0x2f, 0x70, 0x6b, 0x67, 0x2f, 0x67, 0x72, 0x70, 0x63, 0x2f, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, - 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, + 0x5f, 0x65, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x42, 0x1a, 0x0a, 0x18, 0x5f, 0x74, 0x72, + 0x61, 0x63, 0x69, 0x6e, 0x67, 0x5f, 0x7a, 0x69, 0x70, 0x6b, 0x69, 0x6e, 0x5f, 0x65, 0x6e, 0x64, + 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x67, 0x72, 0x70, 0x63, 0x5f, 0x61, + 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x67, 0x72, 0x70, 0x63, 0x5f, + 0x69, 0x6e, 0x73, 0x65, 0x63, 0x75, 0x72, 0x65, 0x42, 0x13, 0x0a, 0x11, 0x5f, 0x66, 0x6f, 0x72, + 0x77, 0x61, 0x72, 0x64, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x5f, 0x75, 0x72, 0x6c, 0x42, 0x22, 0x0a, + 0x20, 0x5f, 0x64, 0x61, 0x74, 0x61, 0x62, 0x72, 0x6f, 0x6b, 0x65, 0x72, 0x5f, 0x69, 0x6e, 0x74, + 0x65, 0x72, 0x6e, 0x61, 0x6c, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x75, 0x72, + 0x6c, 0x42, 0x0c, 0x0a, 0x0a, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x42, + 0x11, 0x0a, 0x0f, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x61, 0x5f, 0x66, 0x69, + 0x6c, 0x65, 0x42, 0x0d, 0x0a, 0x0b, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, + 0x6c, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x5f, 0x63, 0x72, 0x6c, + 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x42, 0x39, 0x0a, 0x37, 0x5f, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, + 0x5f, 0x63, 0x6c, 0x6f, 0x75, 0x64, 0x5f, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x6c, 0x65, 0x73, + 0x73, 0x5f, 0x61, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, + 0x5f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, + 0x42, 0x0b, 0x0a, 0x09, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x42, 0x0e, 0x0a, + 0x0c, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x63, 0x61, 0x42, 0x11, 0x0a, + 0x0f, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x6d, 0x61, 0x69, 0x6c, + 0x42, 0x16, 0x0a, 0x14, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x61, + 0x62, 0x5f, 0x6b, 0x65, 0x79, 0x5f, 0x69, 0x64, 0x42, 0x17, 0x0a, 0x15, 0x5f, 0x61, 0x75, 0x74, + 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x65, 0x61, 0x62, 0x5f, 0x6d, 0x61, 0x63, 0x5f, 0x6b, 0x65, + 0x79, 0x42, 0x16, 0x0a, 0x14, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x74, + 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x63, 0x61, 0x42, 0x1b, 0x0a, 0x19, 0x5f, 0x61, 0x75, + 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, 0x64, 0x5f, 0x63, + 0x61, 0x5f, 0x66, 0x69, 0x6c, 0x65, 0x42, 0x17, 0x0a, 0x15, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, + 0x65, 0x72, 0x74, 0x5f, 0x75, 0x73, 0x65, 0x5f, 0x73, 0x74, 0x61, 0x67, 0x69, 0x6e, 0x67, 0x42, + 0x17, 0x0a, 0x15, 0x5f, 0x61, 0x75, 0x74, 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x6d, 0x75, 0x73, + 0x74, 0x5f, 0x73, 0x74, 0x61, 0x70, 0x6c, 0x65, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x61, 0x75, 0x74, + 0x6f, 0x63, 0x65, 0x72, 0x74, 0x5f, 0x64, 0x69, 0x72, 0x42, 0x12, 0x0a, 0x10, 0x5f, 0x73, 0x6b, + 0x69, 0x70, 0x5f, 0x78, 0x66, 0x66, 0x5f, 0x61, 0x70, 0x70, 0x65, 0x6e, 0x64, 0x42, 0x17, 0x0a, + 0x15, 0x5f, 0x78, 0x66, 0x66, 0x5f, 0x6e, 0x75, 0x6d, 0x5f, 0x74, 0x72, 0x75, 0x73, 0x74, 0x65, + 0x64, 0x5f, 0x68, 0x6f, 0x70, 0x73, 0x42, 0x0c, 0x0a, 0x0a, 0x5f, 0x61, 0x75, 0x64, 0x69, 0x74, + 0x5f, 0x6b, 0x65, 0x79, 0x42, 0x0d, 0x0a, 0x0b, 0x5f, 0x63, 0x6f, 0x64, 0x65, 0x63, 0x5f, 0x74, + 0x79, 0x70, 0x65, 0x42, 0x2e, 0x5a, 0x2c, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, + 0x6d, 0x2f, 0x70, 0x6f, 0x6d, 0x65, 0x72, 0x69, 0x75, 0x6d, 0x2f, 0x70, 0x6f, 0x6d, 0x65, 0x72, + 0x69, 0x75, 0x6d, 0x2f, 0x70, 0x6b, 0x67, 0x2f, 0x67, 0x72, 0x70, 0x63, 0x2f, 0x63, 0x6f, 0x6e, + 0x66, 0x69, 0x67, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, } var ( diff --git a/pkg/grpc/config/config.proto b/pkg/grpc/config/config.proto index 7d4200f6b..3b2022752 100644 --- a/pkg/grpc/config/config.proto +++ b/pkg/grpc/config/config.proto @@ -137,6 +137,7 @@ message Settings { optional google.protobuf.Duration timeout_write = 12; optional google.protobuf.Duration timeout_idle = 13; optional string authenticate_service_url = 14; + optional string authenticate_internal_service_url = 82; optional string authenticate_callback_path = 15; optional string cookie_name = 16; optional string cookie_secret = 17; @@ -154,6 +155,7 @@ message Settings { optional google.protobuf.Duration idp_refresh_directory_interval = 29; map request_params = 30; repeated string authorize_service_urls = 32; + optional string authorize_internal_service_url = 83; optional string override_certificate_name = 33; optional string certificate_authority = 34; optional string certificate_authority_file = 35; @@ -176,6 +178,7 @@ message Settings { optional bool grpc_insecure = 47; optional string forward_auth_url = 50; repeated string databroker_service_urls = 52; + optional string databroker_internal_service_url = 84; optional string client_ca = 53; optional string client_ca_file = 54; optional string client_crl = 74; diff --git a/pkg/grpc/registry/registry.pb.validate.go b/pkg/grpc/registry/registry.pb.validate.go index 78e7c4d01..cf2aaa767 100644 --- a/pkg/grpc/registry/registry.pb.validate.go +++ b/pkg/grpc/registry/registry.pb.validate.go @@ -11,6 +11,7 @@ import ( "net/mail" "net/url" "regexp" + "sort" "strings" "time" "unicode/utf8" @@ -31,38 +32,84 @@ var ( _ = (*url.URL)(nil) _ = (*mail.Address)(nil) _ = anypb.Any{} + _ = sort.Sort ) // Validate checks the field values on Service with the rules defined in the -// proto definition for this message. If any rules are violated, an error is returned. +// proto definition for this message. If any rules are violated, the first +// error encountered is returned, or nil if there are no violations. func (m *Service) Validate() error { + return m.validate(false) +} + +// ValidateAll checks the field values on Service with the rules defined in the +// proto definition for this message. If any rules are violated, the result is +// a list of violation errors wrapped in ServiceMultiError, or nil if none found. +func (m *Service) ValidateAll() error { + return m.validate(true) +} + +func (m *Service) validate(all bool) error { if m == nil { return nil } + var errors []error + if _, ok := _Service_Kind_NotInLookup[m.GetKind()]; ok { - return ServiceValidationError{ + err := ServiceValidationError{ field: "Kind", reason: "value must not be in list [0]", } + if !all { + return err + } + errors = append(errors, err) } if uri, err := url.Parse(m.GetEndpoint()); err != nil { - return ServiceValidationError{ + err = ServiceValidationError{ field: "Endpoint", reason: "value must be a valid URI", cause: err, } + if !all { + return err + } + errors = append(errors, err) } else if !uri.IsAbs() { - return ServiceValidationError{ + err := ServiceValidationError{ field: "Endpoint", reason: "value must be absolute", } + if !all { + return err + } + errors = append(errors, err) } + if len(errors) > 0 { + return ServiceMultiError(errors) + } return nil } +// ServiceMultiError is an error wrapping multiple validation errors returned +// by Service.ValidateAll() if the designated constraints aren't met. +type ServiceMultiError []error + +// Error returns a concatenation of all the error messages it wraps. +func (m ServiceMultiError) Error() string { + var msgs []string + for _, err := range m { + msgs = append(msgs, err.Error()) + } + return strings.Join(msgs, "; ") +} + +// AllErrors returns a list of validation violation errors. +func (m ServiceMultiError) AllErrors() []error { return m } + // ServiceValidationError is the validation error returned by Service.Validate // if the designated constraints aren't met. type ServiceValidationError struct { @@ -122,24 +169,61 @@ var _Service_Kind_NotInLookup = map[ServiceKind]struct{}{ } // Validate checks the field values on RegisterRequest with the rules defined -// in the proto definition for this message. If any rules are violated, an -// error is returned. +// in the proto definition for this message. If any rules are violated, the +// first error encountered is returned, or nil if there are no violations. func (m *RegisterRequest) Validate() error { + return m.validate(false) +} + +// ValidateAll checks the field values on RegisterRequest with the rules +// defined in the proto definition for this message. If any rules are +// violated, the result is a list of violation errors wrapped in +// RegisterRequestMultiError, or nil if none found. +func (m *RegisterRequest) ValidateAll() error { + return m.validate(true) +} + +func (m *RegisterRequest) validate(all bool) error { if m == nil { return nil } + var errors []error + if len(m.GetServices()) < 1 { - return RegisterRequestValidationError{ + err := RegisterRequestValidationError{ field: "Services", reason: "value must contain at least 1 item(s)", } + if !all { + return err + } + errors = append(errors, err) } for idx, item := range m.GetServices() { _, _ = idx, item - if v, ok := interface{}(item).(interface{ Validate() error }); ok { + if all { + switch v := interface{}(item).(type) { + case interface{ ValidateAll() error }: + if err := v.ValidateAll(); err != nil { + errors = append(errors, RegisterRequestValidationError{ + field: fmt.Sprintf("Services[%v]", idx), + reason: "embedded message failed validation", + cause: err, + }) + } + case interface{ Validate() error }: + if err := v.Validate(); err != nil { + errors = append(errors, RegisterRequestValidationError{ + field: fmt.Sprintf("Services[%v]", idx), + reason: "embedded message failed validation", + cause: err, + }) + } + } + } else if v, ok := interface{}(item).(interface{ Validate() error }); ok { if err := v.Validate(); err != nil { return RegisterRequestValidationError{ field: fmt.Sprintf("Services[%v]", idx), @@ -151,26 +235,75 @@ func (m *RegisterRequest) Validate() error { } - for key, val := range m.GetMetadata() { - _ = val + { + sorted_keys := make([]string, len(m.GetMetadata())) + i := 0 + for key := range m.GetMetadata() { + sorted_keys[i] = key + i++ + } + sort.Slice(sorted_keys, func(i, j int) bool { return sorted_keys[i] < sorted_keys[j] }) + for _, key := range sorted_keys { + val := m.GetMetadata()[key] + _ = val - // no validation rules for Metadata[key] + // no validation rules for Metadata[key] - if v, ok := interface{}(val).(interface{ Validate() error }); ok { - if err := v.Validate(); err != nil { - return RegisterRequestValidationError{ - field: fmt.Sprintf("Metadata[%v]", key), - reason: "embedded message failed validation", - cause: err, + if all { + switch v := interface{}(val).(type) { + case interface{ ValidateAll() error }: + if err := v.ValidateAll(); err != nil { + errors = append(errors, RegisterRequestValidationError{ + field: fmt.Sprintf("Metadata[%v]", key), + reason: "embedded message failed validation", + cause: err, + }) + } + case interface{ Validate() error }: + if err := v.Validate(); err != nil { + errors = append(errors, RegisterRequestValidationError{ + field: fmt.Sprintf("Metadata[%v]", key), + reason: "embedded message failed validation", + cause: err, + }) + } + } + } else if v, ok := interface{}(val).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return RegisterRequestValidationError{ + field: fmt.Sprintf("Metadata[%v]", key), + reason: "embedded message failed validation", + cause: err, + } } } - } + } } + if len(errors) > 0 { + return RegisterRequestMultiError(errors) + } return nil } +// RegisterRequestMultiError is an error wrapping multiple validation errors +// returned by RegisterRequest.ValidateAll() if the designated constraints +// aren't met. +type RegisterRequestMultiError []error + +// Error returns a concatenation of all the error messages it wraps. +func (m RegisterRequestMultiError) Error() string { + var msgs []string + for _, err := range m { + msgs = append(msgs, err.Error()) + } + return strings.Join(msgs, "; ") +} + +// AllErrors returns a list of validation violation errors. +func (m RegisterRequestMultiError) AllErrors() []error { return m } + // RegisterRequestValidationError is the validation error returned by // RegisterRequest.Validate if the designated constraints aren't met. type RegisterRequestValidationError struct { @@ -226,14 +359,47 @@ var _ interface { } = RegisterRequestValidationError{} // Validate checks the field values on RegisterResponse with the rules defined -// in the proto definition for this message. If any rules are violated, an -// error is returned. +// in the proto definition for this message. If any rules are violated, the +// first error encountered is returned, or nil if there are no violations. func (m *RegisterResponse) Validate() error { + return m.validate(false) +} + +// ValidateAll checks the field values on RegisterResponse with the rules +// defined in the proto definition for this message. If any rules are +// violated, the result is a list of violation errors wrapped in +// RegisterResponseMultiError, or nil if none found. +func (m *RegisterResponse) ValidateAll() error { + return m.validate(true) +} + +func (m *RegisterResponse) validate(all bool) error { if m == nil { return nil } - if v, ok := interface{}(m.GetCallBackAfter()).(interface{ Validate() error }); ok { + var errors []error + + if all { + switch v := interface{}(m.GetCallBackAfter()).(type) { + case interface{ ValidateAll() error }: + if err := v.ValidateAll(); err != nil { + errors = append(errors, RegisterResponseValidationError{ + field: "CallBackAfter", + reason: "embedded message failed validation", + cause: err, + }) + } + case interface{ Validate() error }: + if err := v.Validate(); err != nil { + errors = append(errors, RegisterResponseValidationError{ + field: "CallBackAfter", + reason: "embedded message failed validation", + cause: err, + }) + } + } + } else if v, ok := interface{}(m.GetCallBackAfter()).(interface{ Validate() error }); ok { if err := v.Validate(); err != nil { return RegisterResponseValidationError{ field: "CallBackAfter", @@ -243,9 +409,29 @@ func (m *RegisterResponse) Validate() error { } } + if len(errors) > 0 { + return RegisterResponseMultiError(errors) + } return nil } +// RegisterResponseMultiError is an error wrapping multiple validation errors +// returned by RegisterResponse.ValidateAll() if the designated constraints +// aren't met. +type RegisterResponseMultiError []error + +// Error returns a concatenation of all the error messages it wraps. +func (m RegisterResponseMultiError) Error() string { + var msgs []string + for _, err := range m { + msgs = append(msgs, err.Error()) + } + return strings.Join(msgs, "; ") +} + +// AllErrors returns a list of validation violation errors. +func (m RegisterResponseMultiError) AllErrors() []error { return m } + // RegisterResponseValidationError is the validation error returned by // RegisterResponse.Validate if the designated constraints aren't met. type RegisterResponseValidationError struct { @@ -301,16 +487,49 @@ var _ interface { } = RegisterResponseValidationError{} // Validate checks the field values on ListRequest with the rules defined in -// the proto definition for this message. If any rules are violated, an error -// is returned. +// the proto definition for this message. If any rules are violated, the first +// error encountered is returned, or nil if there are no violations. func (m *ListRequest) Validate() error { + return m.validate(false) +} + +// ValidateAll checks the field values on ListRequest with the rules defined in +// the proto definition for this message. If any rules are violated, the +// result is a list of violation errors wrapped in ListRequestMultiError, or +// nil if none found. +func (m *ListRequest) ValidateAll() error { + return m.validate(true) +} + +func (m *ListRequest) validate(all bool) error { if m == nil { return nil } + var errors []error + + if len(errors) > 0 { + return ListRequestMultiError(errors) + } return nil } +// ListRequestMultiError is an error wrapping multiple validation errors +// returned by ListRequest.ValidateAll() if the designated constraints aren't met. +type ListRequestMultiError []error + +// Error returns a concatenation of all the error messages it wraps. +func (m ListRequestMultiError) Error() string { + var msgs []string + for _, err := range m { + msgs = append(msgs, err.Error()) + } + return strings.Join(msgs, "; ") +} + +// AllErrors returns a list of validation violation errors. +func (m ListRequestMultiError) AllErrors() []error { return m } + // ListRequestValidationError is the validation error returned by // ListRequest.Validate if the designated constraints aren't met. type ListRequestValidationError struct { @@ -367,13 +586,46 @@ var _ interface { // Validate checks the field values on ServiceRegistration with the rules // defined in the proto definition for this message. If any rules are -// violated, an error is returned. +// violated, the first error encountered is returned, or nil if there are no violations. func (m *ServiceRegistration) Validate() error { + return m.validate(false) +} + +// ValidateAll checks the field values on ServiceRegistration with the rules +// defined in the proto definition for this message. If any rules are +// violated, the result is a list of violation errors wrapped in +// ServiceRegistrationMultiError, or nil if none found. +func (m *ServiceRegistration) ValidateAll() error { + return m.validate(true) +} + +func (m *ServiceRegistration) validate(all bool) error { if m == nil { return nil } - if v, ok := interface{}(m.GetService()).(interface{ Validate() error }); ok { + var errors []error + + if all { + switch v := interface{}(m.GetService()).(type) { + case interface{ ValidateAll() error }: + if err := v.ValidateAll(); err != nil { + errors = append(errors, ServiceRegistrationValidationError{ + field: "Service", + reason: "embedded message failed validation", + cause: err, + }) + } + case interface{ Validate() error }: + if err := v.Validate(); err != nil { + errors = append(errors, ServiceRegistrationValidationError{ + field: "Service", + reason: "embedded message failed validation", + cause: err, + }) + } + } + } else if v, ok := interface{}(m.GetService()).(interface{ Validate() error }); ok { if err := v.Validate(); err != nil { return ServiceRegistrationValidationError{ field: "Service", @@ -383,7 +635,26 @@ func (m *ServiceRegistration) Validate() error { } } - if v, ok := interface{}(m.GetExpiresAt()).(interface{ Validate() error }); ok { + if all { + switch v := interface{}(m.GetExpiresAt()).(type) { + case interface{ ValidateAll() error }: + if err := v.ValidateAll(); err != nil { + errors = append(errors, ServiceRegistrationValidationError{ + field: "ExpiresAt", + reason: "embedded message failed validation", + cause: err, + }) + } + case interface{ Validate() error }: + if err := v.Validate(); err != nil { + errors = append(errors, ServiceRegistrationValidationError{ + field: "ExpiresAt", + reason: "embedded message failed validation", + cause: err, + }) + } + } + } else if v, ok := interface{}(m.GetExpiresAt()).(interface{ Validate() error }); ok { if err := v.Validate(); err != nil { return ServiceRegistrationValidationError{ field: "ExpiresAt", @@ -393,9 +664,29 @@ func (m *ServiceRegistration) Validate() error { } } + if len(errors) > 0 { + return ServiceRegistrationMultiError(errors) + } return nil } +// ServiceRegistrationMultiError is an error wrapping multiple validation +// errors returned by ServiceRegistration.ValidateAll() if the designated +// constraints aren't met. +type ServiceRegistrationMultiError []error + +// Error returns a concatenation of all the error messages it wraps. +func (m ServiceRegistrationMultiError) Error() string { + var msgs []string + for _, err := range m { + msgs = append(msgs, err.Error()) + } + return strings.Join(msgs, "; ") +} + +// AllErrors returns a list of validation violation errors. +func (m ServiceRegistrationMultiError) AllErrors() []error { return m } + // ServiceRegistrationValidationError is the validation error returned by // ServiceRegistration.Validate if the designated constraints aren't met. type ServiceRegistrationValidationError struct { @@ -453,17 +744,50 @@ var _ interface { } = ServiceRegistrationValidationError{} // Validate checks the field values on ServiceList with the rules defined in -// the proto definition for this message. If any rules are violated, an error -// is returned. +// the proto definition for this message. If any rules are violated, the first +// error encountered is returned, or nil if there are no violations. func (m *ServiceList) Validate() error { + return m.validate(false) +} + +// ValidateAll checks the field values on ServiceList with the rules defined in +// the proto definition for this message. If any rules are violated, the +// result is a list of violation errors wrapped in ServiceListMultiError, or +// nil if none found. +func (m *ServiceList) ValidateAll() error { + return m.validate(true) +} + +func (m *ServiceList) validate(all bool) error { if m == nil { return nil } + var errors []error + for idx, item := range m.GetServices() { _, _ = idx, item - if v, ok := interface{}(item).(interface{ Validate() error }); ok { + if all { + switch v := interface{}(item).(type) { + case interface{ ValidateAll() error }: + if err := v.ValidateAll(); err != nil { + errors = append(errors, ServiceListValidationError{ + field: fmt.Sprintf("Services[%v]", idx), + reason: "embedded message failed validation", + cause: err, + }) + } + case interface{ Validate() error }: + if err := v.Validate(); err != nil { + errors = append(errors, ServiceListValidationError{ + field: fmt.Sprintf("Services[%v]", idx), + reason: "embedded message failed validation", + cause: err, + }) + } + } + } else if v, ok := interface{}(item).(interface{ Validate() error }); ok { if err := v.Validate(); err != nil { return ServiceListValidationError{ field: fmt.Sprintf("Services[%v]", idx), @@ -475,9 +799,28 @@ func (m *ServiceList) Validate() error { } + if len(errors) > 0 { + return ServiceListMultiError(errors) + } return nil } +// ServiceListMultiError is an error wrapping multiple validation errors +// returned by ServiceList.ValidateAll() if the designated constraints aren't met. +type ServiceListMultiError []error + +// Error returns a concatenation of all the error messages it wraps. +func (m ServiceListMultiError) Error() string { + var msgs []string + for _, err := range m { + msgs = append(msgs, err.Error()) + } + return strings.Join(msgs, "; ") +} + +// AllErrors returns a list of validation violation errors. +func (m ServiceListMultiError) AllErrors() []error { return m } + // ServiceListValidationError is the validation error returned by // ServiceList.Validate if the designated constraints aren't met. type ServiceListValidationError struct { diff --git a/proxy/proxy.go b/proxy/proxy.go index 8c3879bff..dfcc9a0fd 100644 --- a/proxy/proxy.go +++ b/proxy/proxy.go @@ -44,10 +44,6 @@ func ValidateOptions(o *config.Options) error { return fmt.Errorf("proxy: invalid 'COOKIE_SECRET': %w", err) } - if _, err := o.GetAuthenticateURL(); err != nil { - return fmt.Errorf("proxy: invalid 'AUTHENTICATE_SERVICE_URL': %w", err) - } - return nil } diff --git a/proxy/proxy_test.go b/proxy/proxy_test.go index b3375dcd7..44d3c0a11 100644 --- a/proxy/proxy_test.go +++ b/proxy/proxy_test.go @@ -62,8 +62,6 @@ func TestOptions_Validate(t *testing.T) { }{ {"good - minimum options", good, false}, {"nil options", &config.Options{}, true}, - {"authenticate service url", badAuthURL, true}, - {"authenticate service url no scheme", authenticateBadScheme, true}, {"no cookie secret", emptyCookieSecret, true}, {"invalid cookie secret", invalidCookieSecret, true}, {"short cookie secret", shortCookieLength, true},