3brs/enterprise-security-bundle

Standalone Symfony bundle with reusable security logic — interfaces, services, validators, event listeners

Maintainers

Package info

github.com/3BRS/enterprise-security-bundle

Type:symfony-bundle

pkg:composer/3brs/enterprise-security-bundle

Statistics

Installs: 0

Dependents: 1

Suggesters: 0

Stars: 0

Open Issues: 0

dev-main 2026-06-15 12:38 UTC

This package is auto-updated.

Last update: 2026-06-15 12:52:08 UTC


README

Enterprise Security Bundle

A standalone Symfony bundle providing reusable security primitives — two-factor authentication, passkeys (WebAuthn/FIDO2), magic-link login, OAuth (Google, Apple, Microsoft), account lockout with rate limiting, session tracking, IP whitelist/blacklist, password policy / history / expiration, per-user password-login control, GDPR self-service account deletion, and a runtime-configurable settings store.

The bundle is framework-agnostic — drop it into any Symfony 6.4 / 7.4 app. It ships contracts and abstract flows, not a wired-up UI — you bind it to your app's entities, routes and templates. See the integration guide below for how to wire it into a Symfony project.

What the bundle provides

Authentication flows (abstract base controllers — you extend and bind to your app):

  • Passkey login + registration (WebAuthn ceremony, browser-side navigator.credentials.*)
  • Magic-link login request + verify
  • OAuth login + callback + confirm-link (Google, Apple, Microsoft)
  • Two-factor authentication setup wizard + recovery challenge

Self-service actions (abstract base controllers): session list / revoke / revoke-others · passkey list / delete · 2FA disable / regenerate recovery codes · OAuth account unlink · account deletion request (with grace period).

Admin actions (abstract base controllers): unlock user (after lockout) · cancel pending account deletion · locked users list.

Security engines & services (use directly via DI):

  • 2FA: TotpSecretGenerator, QrCodeGenerator, RecoveryCodeGenerator, TwoFactorEnforcementChecker (+ TwoFactorMode enum), TwoFactorAwareAuthenticationSuccessHandler
  • Magic link: MagicLinkTokenGenerator, MagicLinkTokenValidator
  • Passkey: PasskeyValidatorFactory, PasskeyCeremonyStepManagerFactory, PasskeyRelyingPartyEntityFactory, PasskeyWebauthnSerializer, SessionPasskeyOptionsStorage
  • OAuth: OAuthProviderRegistry + Google / Apple / Microsoft providers, AutoRegistrationPolicy
  • Lockout & rate limiting: LockoutPolicy, RateLimitGuard, DynamicRateLimiterFactory
  • Sessions: UserAgentParser, SessionFingerprintGenerator, GeoIpLookup (MaxMind + Null impls)
  • Passwords: PasswordExpirationChecker, PasswordSimilarityChecker (history), PasswordPolicyFilteringValidator + PasswordPolicy / PasswordHistory Symfony constraints
  • Network: CidrMatcher, CidrList constraint, AbstractIpRestrictionChecker / AbstractIpRestrictionListener (whitelist + blacklist enforcement)
  • Per-user password-login control: AbstractPasswordLoginCheckListener (forces stronger methods)
  • Account deletion (GDPR): GracePeriodCalculator, AbstractDueDeletionsProcessor (anonymization cron engine)
  • Settings store: FeatureToggle, PolicyFactory, YamlConfigDefaultsProvider (runtime-configurable, scoped CUSTOMER / ADMIN / GLOBAL)
  • Hardening: DeadlineTimingPadding — constant-time response padding against account enumeration
  • Twig extensions: MagicLinkExtension, PasskeyExtension, SocialProvidersExtension

Contracts you implement (the bundle ships interfaces; you provide Doctrine-backed impls): persisted-record contracts (MagicLinkRecordInterface, SessionRecordInterface, SocialAccountLinkRecordInterface, CustomerDeletionRequestRecordInterface, PasskeyCredentialRecordInterface), repository contracts, the UserAnonymizerInterface, and per-feature user mixins (TwoFactorAuth*, Lockable*, PasswordExpiration*). See Entities & persistence and Interface implementations.

Features

The bundle covers 16 security features. Each row maps the feature to the bundle primitives that power it — follow the link for the feature-level narrative, config options and defaults.

Feature Bundle primitives Doc
Password Policy PasswordPolicy constraint + PasswordPolicyFilteringValidator password-policy
Password History PasswordHistory constraint + PasswordSimilarityChecker password-history
Password Expiration PasswordExpirationChecker + user mixins password-expiration
Password Change Notifications password_change_notification.enabled settings toggle (notification is app-level) password-change-notifications
Two-Factor Authentication TOTP / QR / recovery generators + enforcement checker + flow controllers two-factor-authentication
3rd-party OAuth (Social Login) provider registry + Google/Apple/Microsoft + auto-registration policy oauth-social-login
Magic Link Login token generator/validator + timing padding + flow controllers magic-link-login
Passkey Login (WebAuthn/FIDO2) WebAuthn serializer + validator factories + flow controllers passkey-login
Account Lockout & Rate Limiting LockoutPolicy + RateLimitGuard + DynamicRateLimiterFactory account-lockout-rate-limiting
Session Management & Login Notifications session tracker + fingerprint + UA parser + GeoIP session-management-login-notifications
Centralized Security Settings UI settings provider/writer contracts + feature toggle + policy factory centralized-security-settings-ui
Self-Service Account Deletion (GDPR) grace-period calculator + due-deletions processor + anonymizer contract account-deletion-gdpr
Admin IP Whitelist CidrMatcher + CidrList constraint + IP restriction listener admin-ip-whitelist
Admin IP Blacklist same IP restriction primitives (global deny list) admin-ip-blacklist
Admin Customer Management session / lockout / password primitives admin-customer-management
Per-User Password Login Control AbstractPasswordLoginCheckListener + preference contracts per-user-password-login-control

Requirements

  • PHP 8.3+
  • Symfony 6.4 or 7.4
  • A Doctrine ORM (the bundle itself has no ORM dep, but your app needs one to persist sessions, passkey credentials, magic-link tokens, etc.)
  • A user entity implementing Symfony\Component\Security\Core\User\UserInterface

Installation

composer require 3brs/enterprise-security-bundle

Then register the bundle in config/bundles.php:

return [
    // ... your existing bundles
    Scheb\TwoFactorBundle\SchebTwoFactorBundle::class => ['all' => true],
    ThreeBRS\EnterpriseSecurityBundle\ThreeBRSEnterpriseSecurityBundle::class => ['all' => true],
];

The bundle requires scheb/2fa-bundle for the 2FA flows; composer require pulls it in automatically.

Integration guide

The bundle is contract-first: you wire each feature you want. These pages walk through it (start at the top — each builds on the previous):

Guide Covers
Configuration Rate-limiter cache pool, settings store, feature-flag defaults, required scalar parameters
Entities & persistence User-entity mixins + the Doctrine records/repositories you provide
Interface implementations The contracts you implement — with full reference impls (settings, magic-link, passkey)
Controllers Extending the abstract flow controllers + the full shipped-controller reference + security checklist
Controllers your app must provide UI pieces intentionally not abstracted (settings UI, force-password-change, recovery-codes page, GDPR cron, …)
Routes reference Every controller, its verb and a sample path
Symfony security configuration Firewall / scheb_2fa / OAuth provider wiring
Passkey front-end The browser-side WebAuthn JavaScript
Templates & translations Template variables, Twig extensions, translation domains

Running tests

The bundle is self-contained — clone it, install its own deps, and run the tooling directly (no Docker required):

composer install
vendor/bin/phpunit              # 326 unit tests (services + abstract controllers)
vendor/bin/phpstan analyse      # level max, generics + symfony extensions
vendor/bin/ecs check            # coding standard (--fix to apply)

Using this bundle on Sylius

Building a Sylius store? You don't need to wire any of this by hand — the ThreeBRS Enterprise Security Plugin implements the ready-made Sylius UI on top of this bundle.

License

MIT License. See LICENSE for details.

Credits

Developed by 3BRS