Pomerium is an identity and context-aware access proxy.
Find a file
Kenneth Jenkins 2bf83e20d8
Allow clearing default Azure and Google auth code options (#4315)
Allow users to clear the default IdP auth code options, by explicitly
setting an empty idp_request_params map.

To do this in a YAML config file, set:

    idp_request_params: {}
2023-06-27 09:11:54 -07:00
.github ci: updates (#4269) 2023-06-20 09:58:15 -06:00
.vscode use tlsClientConfig instead of custom dialer (#3830) 2022-12-27 09:55:36 -07:00
authenticate authenticate: add aws cognito (#4137) 2023-05-16 12:28:12 -04:00
authorize add JWT timestamp formatting workaround (#4270) 2023-06-16 10:36:00 -07:00
cmd/pomerium
config Allow clearing default Azure and Google auth code options (#4315) 2023-06-27 09:11:54 -07:00
databroker config: remove source, remove deadcode, fix linting issues (#4118) 2023-04-21 17:25:11 -06:00
examples Update grafana.ini.yml (#4045) 2023-03-08 09:18:50 -07:00
integration add downstream mTLS integration test cases (#4234) 2023-06-13 10:25:21 -07:00
internal Allow clearing default Azure and Google auth code options (#4315) 2023-06-27 09:11:54 -07:00
ospkg
pkg config: update logic for checking overlapping certificates (#4216) 2023-06-01 09:30:46 -06:00
proxy config: add cookie_same_site option (#4148) 2023-05-03 14:36:42 -06:00
scripts dependencies: upgrade go and envoy (#4116) 2023-04-17 16:44:58 -06:00
ui chore(deps): bump @fontsource/dm-sans from 4.5.1 to 5.0.3 in /ui (#4307) 2023-06-16 12:17:13 -06:00
.codecov.yml
.dockerignore
.fossa.yml
.gitattributes
.gitignore tls: wildcard catch-all cert must be at the end of cert list (#4119) 2023-04-21 12:37:32 -04:00
.golangci.yml config: remove source, remove deadcode, fix linting issues (#4118) 2023-04-21 17:25:11 -06:00
.pre-commit-config.yaml
.tool-versions dependencies: upgrade go and envoy (#4116) 2023-04-17 16:44:58 -06:00
3RD-PARTY
DEBUG.MD
Dockerfile chore(deps): bump node from f658ece to 05824f7 (#4272) 2023-06-16 11:57:07 -06:00
Dockerfile.debug chore(deps): bump node from f658ece to 05824f7 (#4272) 2023-06-16 11:57:07 -06:00
go.mod chore(deps): bump google.golang.org/grpc from 1.55.0 to 1.56.0 (#4278) 2023-06-16 12:16:06 -06:00
go.sum chore(deps): bump google.golang.org/grpc from 1.55.0 to 1.56.0 (#4278) 2023-06-16 12:16:06 -06:00
LICENSE
Makefile config: remove source, remove deadcode, fix linting issues (#4118) 2023-04-21 17:25:11 -06:00
pomerium.go
README.md Update README.md (#4146) 2023-05-02 08:08:49 -06:00
RELEASING.md
SECURITY.md Update SECURITY.md (#4144) 2023-05-01 15:17:50 -04:00
tools.go config: remove source, remove deadcode, fix linting issues (#4118) 2023-04-21 17:25:11 -06:00

pomerium logo

Go Report Card GoDoc LICENSE Docker Pulls

Pomerium is an identity and context-aware reverse proxy that brokers secure access to apps and services at scale. Pomerium provides a standardized interface to add access control to applications regardless of whether the application itself has authorization or authentication baked-in.

Pomerium can be used in situations where you'd typically reach for a VPN, but, unlike a VPN, does not require a client and uses identity and context, not network locality to determine access.

Pomerium can be used to:

  • provide a single-sign-on gateway to internal applications.
  • enforce dynamic access policy based on context, identity, and device identity.
  • aggregate access logs and telemetry data.
  • a VPN alternative.

Docs

For comprehensive docs, and tutorials see our documentation.

Integration Tests

To run the integration tests locally, first build a local development image:

./scripts/build-dev-docker.bash

Next go to the integration/clusters folder and pick a cluster, for example google-single, then use docker-compose to start the cluster. We use an environment variable to specify the dev docker image we built earlier:

cd integration/clusters/google-single
env POMERIUM_TAG=dev docker-compose up -V

Once that's up and running you can run the integration tests from another terminal:

go test -count=1 -v ./integration/...

If you need to make a change to the clusters themselves, there's a tpl folder that contains jsonnet files. Make a change and then rebuild the clusters by running:

go run ./integration/cmd/pomerium-integration-tests/ generate-configuration