Mirror of goauthentik/authentik@github.com - Open-source identity platform
Go to file
Jens Langhammer 4285175bba e2e: add tests for oauth and saml provider 2020-06-20 23:53:05 +02:00
.github ci: run full coverage including e2e 2020-06-19 20:57:42 +02:00
docker docker: fix import order on wait_for_db 2020-05-16 22:56:14 +02:00
docs docs: clarify post-installation login 2020-06-18 23:26:15 +02:00
e2e e2e: add tests for oauth and saml provider 2020-06-20 23:53:05 +02:00
gatekeeper gatekeeper: update upstream docker image 2020-06-09 09:26:03 +02:00
helm new release: 0.9.0-pre2 2020-06-15 19:08:17 +02:00
passbook providers/oauth: add support for consent stage, cleanup 2020-06-20 23:30:53 +02:00
scripts e2e: add OIDC Provider test against grafana, more formatting, minor bug fixes 2020-06-19 19:45:27 +02:00
.bumpversion.cfg new release: 0.9.0-pre2 2020-06-15 19:08:17 +02:00
.coveragerc
.dockerignore
.editorconfig
.fossa.yml
.gitignore
.isort.cfg
.prospector.yaml root: fix pylint not correctly ignoring migrations 2020-05-27 11:15:10 +02:00
.pylintrc root: fix pylint not correctly ignoring migrations 2020-05-27 11:15:10 +02:00
Dockerfile root: rewrite bootstrap in python, remove management command 2020-05-16 22:46:17 +02:00
LICENSE
Pipfile root: move all e2e dependencies into pipfile 2020-06-19 20:25:45 +02:00
Pipfile.lock root: move all e2e dependencies into pipfile 2020-06-19 20:25:45 +02:00
README.md root: add lgtm 2020-06-15 11:56:20 +02:00
SECURITY.md root: update readme 2020-05-27 17:26:35 +02:00
docker-compose.yml root: fix docker-compose not correctly redirecting to https 2020-06-16 21:34:48 +02:00
docker.env.yml e2e: add apply_default_data to load data from migrations after tables have been truncated 2020-06-07 19:31:16 +02:00
manage.py e2e: add OIDC Provider test against grafana, more formatting, minor bug fixes 2020-06-19 19:45:27 +02:00
mkdocs.yml *: make email naming consistent 2020-06-18 19:35:59 +02:00
pyproject.toml WIP Use Flows for Sources and Providers (#32) 2020-06-07 16:35:08 +02:00
pyrightconfig.json stages/password: fix possibility of password in logs 2020-05-09 20:53:32 +02:00
setup.cfg
static.Dockerfile
swagger.yaml *: make email naming consistent 2020-06-18 19:35:59 +02:00

README.md

passbook logopassbook

CI Build status Docker pulls Docker pulls (gatekeeper) Latest version LGTM Grade Code Coverage

What is passbook?

passbook is an open-source Identity Provider focused on flexibility and versatility. You can use passbook in an existing environment to add support for new protocols. passbook is also a great solution for implementing signup/recovery/etc in your application, so you don't have to deal with it.

Installation

For small/test setups it is recommended to use docker-compose.

wget https://raw.githubusercontent.com/BeryJu/passbook/master/docker-compose.yml
# Optionally enable Error-reporting
# export PASSBOOK_ERROR_REPORTING=true
# Optionally deploy a different version
# export PASSBOOK_TAG=0.8.15-beta
# If this is a productive installation, set a different PostgreSQL Password
# export PG_PASS=$(pwgen 40 1)
docker-compose pull
docker-compose up -d
docker-compose exec server ./manage.py migrate

For bigger setups, there is a Helm Chart in the helm/ directory. This is documented here

Screenshots

Development

To develop on passbook, you need a system with Python 3.7+ (3.8 is recommended). passbook uses pipenv for managing dependencies.

To get started, run

python3 -m pip install pipenv
git clone https://github.com/BeryJu/passbook.git
cd passbook
pipenv shell
pipenv sync -d

Since passbook uses PostgreSQL-specific fields, you also need a local PostgreSQL instance to develop. passbook also uses redis for caching and message queueing. For these databases you can use Postgres.app and Redis.app on macOS or use it via docker-comppose:

version: '3.7'

services:
  postgresql:
    container_name: postgres
    image: postgres:11
    volumes:
    - db-data:/var/lib/postgresql/data
    ports:
    - 127.0.0.1:5432:5432
    restart: always
  redis:
    container_name: redis
    image: redis
    ports:
    - 127.0.0.1:6379:6379
    restart: always

volumes:
  db-data:
    driver: local

To tell passbook about these databases, create a file in the project root called local.env.yml with the following contents:

debug: true
postgresql:
  user: postgres

log_level: debug
error_reporting: false

Security

See SECURITY.md