nuke/lib/policy/config
Xe Iaso dff2176beb
feat(lib): use new challenge creation flow (#749)
* feat(decaymap): add Delete method

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore(lib/challenge): refactor Validate to take ValidateInput

Signed-off-by: Xe Iaso <me@xeiaso.net>

* feat(lib): implement store interface

Signed-off-by: Xe Iaso <me@xeiaso.net>

* feat(lib/store): all metapackage to import all store implementations

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore(policy): import all store backends

Signed-off-by: Xe Iaso <me@xeiaso.net>

* feat(lib): use new challenge creation flow

Previously Anubis constructed challenge strings from request metadata.
This was a good idea in spirit, but has turned out to be a very bad idea
in practice. This new flow reuses the Store facility to dynamically
create challenge values with completely random data.

This is a fairly big rewrite of how Anubis processes challenges. Right
now it defaults to using the in-memory storage backend, but on-disk
(boltdb) and valkey-based adaptors will come soon.

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore(decaymap): fix documentation typo

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore(lib): fix SA4004

Signed-off-by: Xe Iaso <me@xeiaso.net>

* test(lib/store): make generic storage interface test adaptor

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore: spelling

Signed-off-by: Xe Iaso <me@xeiaso.net>

* fix(decaymap): invert locking process for Delete

Signed-off-by: Xe Iaso <me@xeiaso.net>

* feat(lib/store): add bbolt store implementation

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore: spelling

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore: go mod tidy

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore(devcontainer): adapt to docker compose, add valkey service

Signed-off-by: Xe Iaso <me@xeiaso.net>

* fix(lib): make challenges live for 30 minutes by default

Signed-off-by: Xe Iaso <me@xeiaso.net>

* feat(lib/store): implement valkey backend

Signed-off-by: Xe Iaso <me@xeiaso.net>

* test(lib/store/valkey): disable tests if not using docker

Signed-off-by: Xe Iaso <me@xeiaso.net>

* test(lib/policy/config): ensure valkey stores can be loaded

Signed-off-by: Xe Iaso <me@xeiaso.net>

* Update metadata

check-spelling run (pull_request) for Xe/store-interface

Signed-off-by: check-spelling-bot <check-spelling-bot@users.noreply.github.com>
on-behalf-of: @check-spelling <check-spelling-bot@check-spelling.dev>

* chore(devcontainer): remove port forwards because vs code handles that for you

Signed-off-by: Xe Iaso <me@xeiaso.net>

* docs(default-config): add a nudge to the storage backends section of the docs

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore(docs): listen on 0.0.0.0 for dev container support

Signed-off-by: Xe Iaso <me@xeiaso.net>

* docs(policy): document storage backends

Signed-off-by: Xe Iaso <me@xeiaso.net>

* docs: update CHANGELOG and internal links

Signed-off-by: Xe Iaso <me@xeiaso.net>

* docs(admin/policies): don't start a sentence with as

Signed-off-by: Xe Iaso <me@xeiaso.net>

* chore: fixes found in review

Signed-off-by: Xe Iaso <me@xeiaso.net>

---------

Signed-off-by: Xe Iaso <me@xeiaso.net>
Signed-off-by: check-spelling-bot <check-spelling-bot@users.noreply.github.com>
2025-07-04 20:42:28 +00:00
..
testdata feat: implement imprint/impressum support (#706) 2025-06-22 18:09:37 -04:00
asn.go feat: implement a client for Thoth, the IP reputation database for Anubis (#637) 2025-06-16 11:57:32 -04:00
asn_test.go fix(config): actually load threshold config (#696) 2025-06-19 17:13:01 -04:00
config.go feat(lib): use new challenge creation flow (#749) 2025-07-04 20:42:28 +00:00
config_test.go feat(lib): use new challenge creation flow (#749) 2025-07-04 20:42:28 +00:00
expressionorlist.go feat(config): custom weight thresholds via CEL (#688) 2025-06-18 16:58:31 -04:00
expressionorlist_test.go feat(config): custom weight thresholds via CEL (#688) 2025-06-18 16:58:31 -04:00
geoip.go fix(config): actually load threshold config (#696) 2025-06-19 17:13:01 -04:00
geoip_test.go fix(config): actually load threshold config (#696) 2025-06-19 17:13:01 -04:00
impressum.go feat: implement imprint/impressum support (#706) 2025-06-22 18:09:37 -04:00
impressum_test.go feat: implement imprint/impressum support (#706) 2025-06-22 18:09:37 -04:00
opengraph.go feat: add default OpenGraph tags to configuration file (#694) 2025-06-19 18:00:44 -04:00
opengraph_test.go feat: add default OpenGraph tags to configuration file (#694) 2025-06-19 18:00:44 -04:00
store.go feat(lib): use new challenge creation flow (#749) 2025-07-04 20:42:28 +00:00
store_test.go feat(lib): use new challenge creation flow (#749) 2025-07-04 20:42:28 +00:00
threshold.go feat(config): custom weight thresholds via CEL (#688) 2025-06-18 16:58:31 -04:00
threshold_test.go fix(config): actually load threshold config (#696) 2025-06-19 17:13:01 -04:00
weight.go feat: add robots2policy CLI to convert robots.txt to Anubis CEL (#657) 2025-06-14 23:41:00 -04:00