Add registration/access control to PasswordProvider and CodeProvider#278
Open
santiagomera wants to merge 2 commits intoanomalyco:masterfrom
Open
Add registration/access control to PasswordProvider and CodeProvider#278santiagomera wants to merge 2 commits intoanomalyco:masterfrom
santiagomera wants to merge 2 commits intoanomalyco:masterfrom
Conversation
|
Contributor
Author
|
Added access control to the CodeProvider since it's just a similar but simpler case than the PasswordProvider. |
andrewmd5
added a commit
to 6over3/openauth
that referenced
this pull request
Apr 26, 2026
Cherry-picks from anomalyco/openauth open PRs: - anomalyco#305 spec-compliant redirect_uri (require `allow`, RFC 9700 §4.1) - anomalyco#309 client-side JWT audience validation (RFC 7519 §4.1.3) - anomalyco#318 token_type=Bearer on token responses - anomalyco#304 implicit-flow no refresh token (RFC 6749 §4.2.2) - anomalyco#258 iat claim (deterministic across reuse interval) - anomalyco#323 fix Cloudflare KV runaway key creation under eventual consistency - anomalyco#315 loosen CloudflareStorageOptions to structural KV shape - anomalyco#319 refresh callback hook - anomalyco#156 OAuth2 scope (authorize, token, well-known, JWT claim) - anomalyco#236 basePath option - anomalyco#278 allowRegistration / userExists / allowClaims - anomalyco#221 configurable Select copy - anomalyco#310 anomalyco#308 code UI resend action + sendCode types - anomalyco#325 example actions: keep session when access token still valid - anomalyco#317 add MIT license to package.json Bump 0.3.12 -> 0.4.0 (breaking: `allow` is now required).
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
Fix #199
This PR adds flexible registration control to the PasswordProvider, enabling scenarios where sign-ups are restricted or completely disabled while supporting admin-created users through external system.
New Configuration Options
allowRegistration- Controls whether new user registration is allowed:true(default) allows user registration,falsedisables user registration(email: string) => boolean | Promise<boolean>for custom validation logic (e.g., domain restrictions)userExists- Callback to check if a user exists in an external system:(email: string) => boolean | Promise<boolean>allowRegistration === falseImplementation Details
Registration Flow Changes
allowRegistration: false: Registration routes redirect to login pageallowRegistration: function: Function validates each registration attempt on form submissionPassword Reset Flow for Admin-Created Users
First-time log in when registration is disabled is handled with the existing password reset flow (new users need to reset their password before being able to log in).
At the password update step, if the user if not found in
Storageand the user exists in external system, it is created inStorageand the regular reset logic continues.Examples
Admin-Created User First Login
Domain-Restricted Registration
Disabled Registration with External Users
Breaking Changes
There shouldn't be.