Go to file
2023-02-13 01:14:19 +00:00
.github 🔄 Synced local '.github/settings.yml' with remote 'erlang/.github/settings.yml' 2023-02-13 01:14:19 +00:00
config TD-187: Add Prometheus (#5) 2022-02-21 11:57:24 +03:00
src TD-222: Reuse valitydev/action-deploy-docker@v2 (#24) 2022-07-13 11:15:36 +03:00
test TD-222: Reuse valitydev/action-deploy-docker@v2 (#24) 2022-07-13 11:15:36 +03:00
.dockerignore TD-187: Add CI/CD (#4) 2022-02-21 11:56:58 +03:00
.env TD-222: Reuse valitydev/action-deploy-docker@v2 (#24) 2022-07-13 11:15:36 +03:00
.gitignore TD-187: Add CI/CD (#4) 2022-02-21 11:56:58 +03:00
docker-compose.yml TD-187: Add CI/CD (#4) 2022-02-21 11:56:58 +03:00
Dockerfile TD-222: Reuse valitydev/action-deploy-docker@v2 (#24) 2022-07-13 11:15:36 +03:00
Dockerfile.dev TD-222: Reuse valitydev/action-deploy-docker@v2 (#24) 2022-07-13 11:15:36 +03:00
elvis.config TD-222: Reuse valitydev/action-deploy-docker@v2 (#24) 2022-07-13 11:15:36 +03:00
LICENSE Update file(s) from valitydev/.github 2022-02-21 22:05:01 +00:00
Makefile TD-187: Add CI/CD (#4) 2022-02-21 11:56:58 +03:00
README.md Fix a typo in README.md file (#34) 2021-08-24 09:27:43 +03:00
rebar.config TD-187: Add Prometheus (#5) 2022-02-21 11:57:24 +03:00
rebar.lock Update bouncer-proto (#28) 2022-12-28 12:02:51 +05:00
renovate.json Update renovate config 2022-02-21 13:43:28 +03:00

Bouncer

Does someone look like a troublemaker?

Primary Arbiter thrift service implementation.

In a nutshell this service maps incoming contexts into OPA input documents and asks OPA to compute a judgement allowing, restricting or forbidding actions under given input context.

From the service's point of view a ruleset id is a path to OPA document that define a subdocument named judgement with a rudimentary schema. See https://github.com/rbkmoney/bouncer-policies#authoring for more detailed information.

Things to keep in mind

  • When upgrading service to a newer Erlang OTP release please be aware of potential breakages in bouncer_audit_log not strictly related to usual API deprecations and removals which is an essintial part of a release. That is because this module relies on some OTP libraries' internal implementation details. See module-level notes for additional details.