@absolutejs/auth 0.25.1 → 0.26.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/audit/config.d.ts +8 -0
  2. package/dist/audit/inMemoryAuditStore.d.ts +2 -0
  3. package/dist/audit/postgresAuditStore.d.ts +142 -0
  4. package/dist/audit/types.d.ts +18 -0
  5. package/dist/audit/wrap.d.ts +9 -0
  6. package/dist/credentials/config.d.ts +61 -0
  7. package/dist/credentials/emailVerification.d.ts +83 -0
  8. package/dist/credentials/inMemoryCredentialStore.d.ts +2 -0
  9. package/dist/credentials/login.d.ts +75 -0
  10. package/dist/credentials/passwordPolicy.d.ts +14 -0
  11. package/dist/credentials/passwordReset.d.ts +87 -0
  12. package/dist/credentials/postgresCredentialStore.d.ts +279 -0
  13. package/dist/credentials/register.d.ts +54 -0
  14. package/dist/credentials/routes.d.ts +200 -0
  15. package/dist/credentials/types.d.ts +26 -0
  16. package/dist/crypto.d.ts +32 -0
  17. package/dist/{ui → htmx}/index.js +2 -2
  18. package/dist/{ui → htmx}/index.js.map +2 -2
  19. package/dist/{htmxRoutes.d.ts → htmx/routes.d.ts} +4 -4
  20. package/dist/index.d.ts +427 -27
  21. package/dist/index.js +3314 -1932
  22. package/dist/index.js.map +60 -27
  23. package/dist/{neonLinkedProviders.d.ts → linkedProviders/neonStores.d.ts} +619 -613
  24. package/dist/{oauthLinkedProviderResolver.d.ts → linkedProviders/oauthResolver.d.ts} +1 -1
  25. package/dist/lockout/config.d.ts +17 -0
  26. package/dist/lockout/inMemoryLockoutStore.d.ts +2 -0
  27. package/dist/lockout/postgresLockoutStore.d.ts +81 -0
  28. package/dist/lockout/types.d.ts +12 -0
  29. package/dist/mfa/backupCodes.d.ts +5 -0
  30. package/dist/mfa/challenge.d.ts +65 -0
  31. package/dist/mfa/config.d.ts +32 -0
  32. package/dist/mfa/gate.d.ts +2 -0
  33. package/dist/mfa/inMemoryMfaStore.d.ts +2 -0
  34. package/dist/mfa/postgresMfaStore.d.ts +134 -0
  35. package/dist/mfa/routes.d.ts +117 -0
  36. package/dist/mfa/secret.d.ts +2 -0
  37. package/dist/mfa/totp.d.ts +91 -0
  38. package/dist/mfa/types.d.ts +16 -0
  39. package/dist/{providerClients.d.ts → providers/clients.d.ts} +35 -19
  40. package/dist/{authorize.d.ts → routes/authorize.d.ts} +5 -5
  41. package/dist/{callback.d.ts → routes/callback.d.ts} +4 -4
  42. package/dist/{profile.d.ts → routes/profile.d.ts} +5 -5
  43. package/dist/{protectRoute.d.ts → routes/protectRoute.d.ts} +5 -5
  44. package/dist/{refresh.d.ts → routes/refresh.d.ts} +5 -5
  45. package/dist/{revoke.d.ts → routes/revoke.d.ts} +6 -6
  46. package/dist/routes/sessions.d.ts +103 -0
  47. package/dist/{signout.d.ts → routes/signout.d.ts} +4 -4
  48. package/dist/routes/stepUp.d.ts +48 -0
  49. package/dist/{userStatus.d.ts → routes/userStatus.d.ts} +4 -4
  50. package/dist/{sessionAccess.d.ts → session/access.d.ts} +12 -12
  51. package/dist/{sessionCleanup.d.ts → session/cleanup.d.ts} +2 -2
  52. package/dist/{authSessionStores.d.ts → session/inMemoryStore.d.ts} +2 -2
  53. package/dist/{neonAuthSessionStore.d.ts → session/neonStore.d.ts} +209 -175
  54. package/dist/session/promote.d.ts +13 -0
  55. package/dist/session/sessionsConfig.d.ts +9 -0
  56. package/dist/{sessionStore.d.ts → session/state.d.ts} +1 -1
  57. package/dist/{sessionTypes.d.ts → session/types.d.ts} +1 -1
  58. package/dist/session/userSessions.d.ts +16 -0
  59. package/dist/stores/postgres.d.ts +5 -0
  60. package/dist/tenancy.d.ts +9 -0
  61. package/dist/typeGuards.d.ts +2 -2
  62. package/dist/typebox.d.ts +3 -3
  63. package/dist/types.d.ts +33 -3
  64. package/dist/utils.d.ts +9 -9
  65. package/package.json +19 -16
  66. /package/dist/{ui → htmx}/index.d.ts +0 -0
  67. /package/dist/{ui → htmx}/renderers.d.ts +0 -0
  68. /package/dist/{ui → htmx}/types.d.ts +0 -0
  69. /package/dist/{linkedProviderStores.d.ts → linkedProviders/inMemoryStores.d.ts} +0 -0
  70. /package/dist/{linkedProviderResolver.d.ts → linkedProviders/resolver.d.ts} +0 -0
@@ -0,0 +1,279 @@
1
+ import { type AnyPgDatabase } from '../stores/postgres';
2
+ import type { CredentialStore } from './types';
3
+ export declare const credentialsTable: import("drizzle-orm/pg-core").PgTableWithColumns<{
4
+ name: "auth_credentials";
5
+ schema: undefined;
6
+ columns: {
7
+ created_at_ms: import("drizzle-orm/pg-core").PgColumn<{
8
+ name: "created_at_ms";
9
+ tableName: "auth_credentials";
10
+ dataType: "number";
11
+ columnType: "PgBigInt53";
12
+ data: number;
13
+ driverParam: string | number;
14
+ notNull: true;
15
+ hasDefault: false;
16
+ isPrimaryKey: false;
17
+ isAutoincrement: false;
18
+ hasRuntimeDefault: false;
19
+ enumValues: undefined;
20
+ baseColumn: never;
21
+ identity: undefined;
22
+ generated: undefined;
23
+ }, {}, {}>;
24
+ email: import("drizzle-orm/pg-core").PgColumn<{
25
+ name: "email";
26
+ tableName: "auth_credentials";
27
+ dataType: "string";
28
+ columnType: "PgVarchar";
29
+ data: string;
30
+ driverParam: string;
31
+ notNull: true;
32
+ hasDefault: false;
33
+ isPrimaryKey: true;
34
+ isAutoincrement: false;
35
+ hasRuntimeDefault: false;
36
+ enumValues: [string, ...string[]];
37
+ baseColumn: never;
38
+ identity: undefined;
39
+ generated: undefined;
40
+ }, {}, {
41
+ length: 320;
42
+ }>;
43
+ email_verified: import("drizzle-orm/pg-core").PgColumn<{
44
+ name: "email_verified";
45
+ tableName: "auth_credentials";
46
+ dataType: "boolean";
47
+ columnType: "PgBoolean";
48
+ data: boolean;
49
+ driverParam: boolean;
50
+ notNull: true;
51
+ hasDefault: true;
52
+ isPrimaryKey: false;
53
+ isAutoincrement: false;
54
+ hasRuntimeDefault: false;
55
+ enumValues: undefined;
56
+ baseColumn: never;
57
+ identity: undefined;
58
+ generated: undefined;
59
+ }, {}, {}>;
60
+ organization_id: import("drizzle-orm/pg-core").PgColumn<{
61
+ name: "organization_id";
62
+ tableName: "auth_credentials";
63
+ dataType: "string";
64
+ columnType: "PgVarchar";
65
+ data: string;
66
+ driverParam: string;
67
+ notNull: false;
68
+ hasDefault: false;
69
+ isPrimaryKey: false;
70
+ isAutoincrement: false;
71
+ hasRuntimeDefault: false;
72
+ enumValues: [string, ...string[]];
73
+ baseColumn: never;
74
+ identity: undefined;
75
+ generated: undefined;
76
+ }, {}, {
77
+ length: 255;
78
+ }>;
79
+ password_hash: import("drizzle-orm/pg-core").PgColumn<{
80
+ name: "password_hash";
81
+ tableName: "auth_credentials";
82
+ dataType: "string";
83
+ columnType: "PgText";
84
+ data: string;
85
+ driverParam: string;
86
+ notNull: true;
87
+ hasDefault: false;
88
+ isPrimaryKey: false;
89
+ isAutoincrement: false;
90
+ hasRuntimeDefault: false;
91
+ enumValues: [string, ...string[]];
92
+ baseColumn: never;
93
+ identity: undefined;
94
+ generated: undefined;
95
+ }, {}, {}>;
96
+ status: import("drizzle-orm/pg-core").PgColumn<{
97
+ name: "status";
98
+ tableName: "auth_credentials";
99
+ dataType: "string";
100
+ columnType: "PgVarchar";
101
+ data: string;
102
+ driverParam: string;
103
+ notNull: true;
104
+ hasDefault: true;
105
+ isPrimaryKey: false;
106
+ isAutoincrement: false;
107
+ hasRuntimeDefault: false;
108
+ enumValues: [string, ...string[]];
109
+ baseColumn: never;
110
+ identity: undefined;
111
+ generated: undefined;
112
+ }, {}, {
113
+ length: 32;
114
+ }>;
115
+ updated_at_ms: import("drizzle-orm/pg-core").PgColumn<{
116
+ name: "updated_at_ms";
117
+ tableName: "auth_credentials";
118
+ dataType: "number";
119
+ columnType: "PgBigInt53";
120
+ data: number;
121
+ driverParam: string | number;
122
+ notNull: true;
123
+ hasDefault: false;
124
+ isPrimaryKey: false;
125
+ isAutoincrement: false;
126
+ hasRuntimeDefault: false;
127
+ enumValues: undefined;
128
+ baseColumn: never;
129
+ identity: undefined;
130
+ generated: undefined;
131
+ }, {}, {}>;
132
+ user_id: import("drizzle-orm/pg-core").PgColumn<{
133
+ name: "user_id";
134
+ tableName: "auth_credentials";
135
+ dataType: "string";
136
+ columnType: "PgVarchar";
137
+ data: string;
138
+ driverParam: string;
139
+ notNull: false;
140
+ hasDefault: false;
141
+ isPrimaryKey: false;
142
+ isAutoincrement: false;
143
+ hasRuntimeDefault: false;
144
+ enumValues: [string, ...string[]];
145
+ baseColumn: never;
146
+ identity: undefined;
147
+ generated: undefined;
148
+ }, {}, {
149
+ length: 255;
150
+ }>;
151
+ };
152
+ dialect: "pg";
153
+ }>;
154
+ export declare const credentialResetTokensTable: import("drizzle-orm/pg-core").PgTableWithColumns<{
155
+ name: string;
156
+ schema: undefined;
157
+ columns: {
158
+ email: import("drizzle-orm/pg-core").PgColumn<{
159
+ name: "email";
160
+ tableName: string;
161
+ dataType: "string";
162
+ columnType: "PgVarchar";
163
+ data: string;
164
+ driverParam: string;
165
+ notNull: true;
166
+ hasDefault: false;
167
+ isPrimaryKey: false;
168
+ isAutoincrement: false;
169
+ hasRuntimeDefault: false;
170
+ enumValues: [string, ...string[]];
171
+ baseColumn: never;
172
+ identity: undefined;
173
+ generated: undefined;
174
+ }, {}, {
175
+ length: 320;
176
+ }>;
177
+ expires_at_ms: import("drizzle-orm/pg-core").PgColumn<{
178
+ name: "expires_at_ms";
179
+ tableName: string;
180
+ dataType: "number";
181
+ columnType: "PgBigInt53";
182
+ data: number;
183
+ driverParam: string | number;
184
+ notNull: true;
185
+ hasDefault: false;
186
+ isPrimaryKey: false;
187
+ isAutoincrement: false;
188
+ hasRuntimeDefault: false;
189
+ enumValues: undefined;
190
+ baseColumn: never;
191
+ identity: undefined;
192
+ generated: undefined;
193
+ }, {}, {}>;
194
+ token_hash: import("drizzle-orm/pg-core").PgColumn<{
195
+ name: "token_hash";
196
+ tableName: string;
197
+ dataType: "string";
198
+ columnType: "PgVarchar";
199
+ data: string;
200
+ driverParam: string;
201
+ notNull: true;
202
+ hasDefault: false;
203
+ isPrimaryKey: true;
204
+ isAutoincrement: false;
205
+ hasRuntimeDefault: false;
206
+ enumValues: [string, ...string[]];
207
+ baseColumn: never;
208
+ identity: undefined;
209
+ generated: undefined;
210
+ }, {}, {
211
+ length: 255;
212
+ }>;
213
+ };
214
+ dialect: "pg";
215
+ }>;
216
+ export declare const credentialVerificationTokensTable: import("drizzle-orm/pg-core").PgTableWithColumns<{
217
+ name: string;
218
+ schema: undefined;
219
+ columns: {
220
+ email: import("drizzle-orm/pg-core").PgColumn<{
221
+ name: "email";
222
+ tableName: string;
223
+ dataType: "string";
224
+ columnType: "PgVarchar";
225
+ data: string;
226
+ driverParam: string;
227
+ notNull: true;
228
+ hasDefault: false;
229
+ isPrimaryKey: false;
230
+ isAutoincrement: false;
231
+ hasRuntimeDefault: false;
232
+ enumValues: [string, ...string[]];
233
+ baseColumn: never;
234
+ identity: undefined;
235
+ generated: undefined;
236
+ }, {}, {
237
+ length: 320;
238
+ }>;
239
+ expires_at_ms: import("drizzle-orm/pg-core").PgColumn<{
240
+ name: "expires_at_ms";
241
+ tableName: string;
242
+ dataType: "number";
243
+ columnType: "PgBigInt53";
244
+ data: number;
245
+ driverParam: string | number;
246
+ notNull: true;
247
+ hasDefault: false;
248
+ isPrimaryKey: false;
249
+ isAutoincrement: false;
250
+ hasRuntimeDefault: false;
251
+ enumValues: undefined;
252
+ baseColumn: never;
253
+ identity: undefined;
254
+ generated: undefined;
255
+ }, {}, {}>;
256
+ token_hash: import("drizzle-orm/pg-core").PgColumn<{
257
+ name: "token_hash";
258
+ tableName: string;
259
+ dataType: "string";
260
+ columnType: "PgVarchar";
261
+ data: string;
262
+ driverParam: string;
263
+ notNull: true;
264
+ hasDefault: false;
265
+ isPrimaryKey: true;
266
+ isAutoincrement: false;
267
+ hasRuntimeDefault: false;
268
+ enumValues: [string, ...string[]];
269
+ baseColumn: never;
270
+ identity: undefined;
271
+ generated: undefined;
272
+ }, {}, {
273
+ length: 255;
274
+ }>;
275
+ };
276
+ dialect: "pg";
277
+ }>;
278
+ export declare const createNeonCredentialStore: (databaseUrl: string) => CredentialStore;
279
+ export declare const createPostgresCredentialStore: (db: AnyPgDatabase) => CredentialStore;
@@ -0,0 +1,54 @@
1
+ import { Elysia } from 'elysia';
2
+ import { type CredentialRouteProps } from './config';
3
+ export declare const credentialsRegister: <UserType>({ authSessionStore, credentialStore, onCreateCredentialUser, onCredentialsLoginSuccess, onRegistrationSuccess, onSendEmail, passwordPolicy, registerRoute, requireEmailVerification, sessionDurationMs, verificationTokenDurationMs }: CredentialRouteProps<UserType>) => Elysia<"", {
4
+ decorator: {};
5
+ store: {
6
+ session: import("..").SessionRecord<UserType>;
7
+ unregisteredSession: import("..").UnregisteredSessionRecord;
8
+ };
9
+ derive: {};
10
+ resolve: {};
11
+ }, {
12
+ typebox: {};
13
+ error: {};
14
+ }, {
15
+ schema: {};
16
+ standaloneSchema: {};
17
+ macro: {};
18
+ macroFn: {};
19
+ parser: {};
20
+ response: {};
21
+ }, {
22
+ [x: string]: {
23
+ post: {
24
+ body: {
25
+ email: string;
26
+ password: string;
27
+ };
28
+ params: {};
29
+ query: unknown;
30
+ headers: unknown;
31
+ response: {
32
+ [x: string]: any;
33
+ };
34
+ };
35
+ };
36
+ }, {
37
+ derive: {};
38
+ resolve: {};
39
+ schema: {};
40
+ standaloneSchema: {};
41
+ response: {};
42
+ }, {
43
+ derive: {};
44
+ resolve: {};
45
+ schema: {};
46
+ standaloneSchema: {};
47
+ response: {};
48
+ } & {
49
+ derive: {};
50
+ resolve: {};
51
+ schema: {};
52
+ standaloneSchema: {};
53
+ response: {};
54
+ }>;
@@ -0,0 +1,200 @@
1
+ import { Elysia } from 'elysia';
2
+ import type { CredentialRouteProps } from './config';
3
+ export declare const credentialRoutes: <UserType>(config: CredentialRouteProps<UserType>) => Elysia<"", {
4
+ decorator: {};
5
+ store: {
6
+ session: import("..").SessionRecord<UserType>;
7
+ unregisteredSession: import("..").UnregisteredSessionRecord;
8
+ };
9
+ derive: {};
10
+ resolve: {};
11
+ }, {
12
+ typebox: {};
13
+ error: {};
14
+ }, {
15
+ schema: {};
16
+ standaloneSchema: {};
17
+ macro: {};
18
+ macroFn: {};
19
+ parser: {};
20
+ response: {};
21
+ }, {
22
+ [x: string]: {
23
+ post: {
24
+ body: {
25
+ email: string;
26
+ password: string;
27
+ };
28
+ params: {};
29
+ query: unknown;
30
+ headers: unknown;
31
+ response: {
32
+ [x: string]: any;
33
+ };
34
+ };
35
+ };
36
+ } & {
37
+ [x: string]: {
38
+ post: {
39
+ body: {
40
+ token: string;
41
+ };
42
+ params: {};
43
+ query: unknown;
44
+ headers: unknown;
45
+ response: {
46
+ 200: {
47
+ readonly status: "email_verified";
48
+ };
49
+ 400: "Invalid or expired verification token";
50
+ 422: {
51
+ type: "validation";
52
+ on: string;
53
+ summary?: string;
54
+ message?: string;
55
+ found?: unknown;
56
+ property?: string;
57
+ expected?: string;
58
+ };
59
+ };
60
+ };
61
+ };
62
+ } & {
63
+ [x: string]: {
64
+ request: {
65
+ post: {
66
+ body: {
67
+ email: string;
68
+ };
69
+ params: {};
70
+ query: unknown;
71
+ headers: unknown;
72
+ response: {
73
+ 200: {
74
+ readonly status: "verification_requested";
75
+ };
76
+ 422: {
77
+ type: "validation";
78
+ on: string;
79
+ summary?: string;
80
+ message?: string;
81
+ found?: unknown;
82
+ property?: string;
83
+ expected?: string;
84
+ };
85
+ };
86
+ };
87
+ };
88
+ };
89
+ } & {
90
+ [x: string]: {
91
+ post: {
92
+ body: {
93
+ email: string;
94
+ password: string;
95
+ };
96
+ params: {};
97
+ query: unknown;
98
+ headers: unknown;
99
+ response: {
100
+ 200: {
101
+ readonly status: "mfa_required";
102
+ } | {
103
+ readonly status: "authenticated";
104
+ };
105
+ 401: "Invalid email or password";
106
+ 403: {
107
+ readonly status: "email_not_verified";
108
+ };
109
+ 422: {
110
+ type: "validation";
111
+ on: string;
112
+ summary?: string;
113
+ message?: string;
114
+ found?: unknown;
115
+ property?: string;
116
+ expected?: string;
117
+ };
118
+ 429: {
119
+ readonly retryAfterMs: number | undefined;
120
+ readonly status: "account_locked";
121
+ };
122
+ };
123
+ };
124
+ };
125
+ } & {
126
+ [x: string]: {
127
+ request: {
128
+ post: {
129
+ body: {
130
+ email: string;
131
+ };
132
+ params: {};
133
+ query: unknown;
134
+ headers: unknown;
135
+ response: {
136
+ 200: {
137
+ readonly status: "reset_requested";
138
+ };
139
+ 422: {
140
+ type: "validation";
141
+ on: string;
142
+ summary?: string;
143
+ message?: string;
144
+ found?: unknown;
145
+ property?: string;
146
+ expected?: string;
147
+ };
148
+ };
149
+ };
150
+ };
151
+ };
152
+ } & {
153
+ [x: string]: {
154
+ post: {
155
+ body: {
156
+ token: string;
157
+ password: string;
158
+ };
159
+ params: {};
160
+ query: unknown;
161
+ headers: unknown;
162
+ response: {
163
+ 200: {
164
+ readonly status: "password_reset";
165
+ };
166
+ 400: "Invalid or expired reset token" | {
167
+ readonly message: "Password does not meet the policy";
168
+ readonly violations: import("./passwordPolicy").PasswordPolicyViolation[];
169
+ };
170
+ 422: {
171
+ type: "validation";
172
+ on: string;
173
+ summary?: string;
174
+ message?: string;
175
+ found?: unknown;
176
+ property?: string;
177
+ expected?: string;
178
+ };
179
+ };
180
+ };
181
+ };
182
+ }, {
183
+ derive: {};
184
+ resolve: {};
185
+ schema: {};
186
+ standaloneSchema: {};
187
+ response: {};
188
+ }, {
189
+ derive: {};
190
+ resolve: {};
191
+ schema: {};
192
+ standaloneSchema: {};
193
+ response: {};
194
+ } & {
195
+ derive: {};
196
+ resolve: {};
197
+ schema: {};
198
+ standaloneSchema: {};
199
+ response: {};
200
+ }>;
@@ -0,0 +1,26 @@
1
+ import type { OrganizationId } from '../tenancy';
2
+ export type CredentialStatus = 'active' | 'disabled';
3
+ export type CredentialRecord = {
4
+ createdAt: number;
5
+ email: string;
6
+ emailVerified: boolean;
7
+ organizationId?: OrganizationId;
8
+ passwordHash: string;
9
+ status: CredentialStatus;
10
+ updatedAt: number;
11
+ userId?: string;
12
+ };
13
+ export type CredentialToken = {
14
+ email: string;
15
+ expiresAt: number;
16
+ tokenHash: string;
17
+ };
18
+ export type CredentialStore = {
19
+ consumeResetToken: (tokenHash: string) => Promise<CredentialToken | undefined>;
20
+ consumeVerificationToken: (tokenHash: string) => Promise<CredentialToken | undefined>;
21
+ getCredentialByEmail: (email: string) => Promise<CredentialRecord | undefined>;
22
+ saveCredential: (credential: CredentialRecord) => Promise<void>;
23
+ saveResetToken: (token: CredentialToken) => Promise<void>;
24
+ saveVerificationToken: (token: CredentialToken) => Promise<void>;
25
+ setEmailVerified: (email: string) => Promise<void>;
26
+ };
@@ -0,0 +1,32 @@
1
+ export declare const base32Decode: (encoded: string) => Uint8Array<ArrayBuffer>;
2
+ export declare const base32Encode: (bytes: Uint8Array) => string;
3
+ export declare const constantTimeEqual: (left: string, right: string) => Promise<boolean>;
4
+ export declare const createTotpKeyUri: ({ accountName, digits, issuer, period, secret }: {
5
+ accountName: string;
6
+ digits?: number;
7
+ issuer: string;
8
+ period?: number;
9
+ secret: string;
10
+ }) => string;
11
+ export declare const decryptSecret: (ciphertext: string, keyMaterial: string) => Promise<string>;
12
+ export declare const encryptSecret: (plaintext: string, keyMaterial: string) => Promise<string>;
13
+ export declare const generateEncryptionKey: () => string;
14
+ export declare const generateSecureToken: (byteLength?: number) => string;
15
+ export declare const generateTotp: ({ digits, now, period, secret }: {
16
+ digits?: number;
17
+ now?: number;
18
+ period?: number;
19
+ secret: string;
20
+ }) => Promise<string>;
21
+ export declare const generateTotpSecret: (byteLength?: number) => string;
22
+ export declare const hashPassword: (password: string) => Promise<string>;
23
+ export declare const hashToken: (token: string) => Promise<string>;
24
+ export declare const verifyPassword: (password: string, hash: string) => Promise<boolean>;
25
+ export declare const verifyTotp: ({ digits, now, period, secret, token, window }: {
26
+ digits?: number;
27
+ now?: number;
28
+ period?: number;
29
+ secret: string;
30
+ token: string;
31
+ window?: number;
32
+ }) => Promise<boolean>;
@@ -2123,7 +2123,7 @@ var createOAuth2Client = async (providerName, config) => {
2123
2123
  };
2124
2124
  };
2125
2125
 
2126
- // src/ui/renderers.ts
2126
+ // src/htmx/renderers.ts
2127
2127
  var escapeHtml = (value) => value.replaceAll("&", "&amp;").replaceAll("<", "&lt;").replaceAll(">", "&gt;").replaceAll('"', "&quot;");
2128
2128
  var defaultAuthorizationHref = (provider, client) => client ? `/oauth2/${provider}/authorization?client=${client}` : `/oauth2/${provider}/authorization`;
2129
2129
  var resolveAuthHtmxRenderers = (config) => {
@@ -2208,5 +2208,5 @@ export {
2208
2208
  escapeHtml
2209
2209
  };
2210
2210
 
2211
- //# debugId=E4E67AE168C02C8A64756E2164756E21
2211
+ //# debugId=B47ECE588E07832964756E2164756E21
2212
2212
  //# sourceMappingURL=index.js.map