@aura-stack/auth 0.4.0-rc.5 → 0.5.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.
- package/dist/@types/index.d.ts +8 -3
- package/dist/@types/router.d.cjs +0 -17
- package/dist/@types/router.d.d.ts +7 -2
- package/dist/@types/router.d.js +0 -1
- package/dist/actions/callback/access-token.cjs +130 -71
- package/dist/actions/callback/access-token.d.ts +9 -4
- package/dist/actions/callback/access-token.js +3 -4
- package/dist/actions/callback/callback.cjs +428 -152
- package/dist/actions/callback/callback.d.ts +11 -3
- package/dist/actions/callback/callback.js +12 -10
- package/dist/actions/callback/userinfo.cjs +159 -65
- package/dist/actions/callback/userinfo.d.ts +8 -3
- package/dist/actions/callback/userinfo.js +7 -6
- package/dist/actions/csrfToken/csrfToken.cjs +70 -19
- package/dist/actions/csrfToken/csrfToken.js +8 -7
- package/dist/actions/index.cjs +780 -348
- package/dist/actions/index.d.ts +6 -2
- package/dist/actions/index.js +23 -18
- package/dist/actions/session/session.cjs +107 -26
- package/dist/actions/session/session.js +7 -5
- package/dist/actions/signIn/authorization-url.cjs +288 -0
- package/dist/actions/signIn/authorization-url.d.ts +31 -0
- package/dist/actions/signIn/authorization-url.js +16 -0
- package/dist/actions/signIn/authorization.cjs +209 -211
- package/dist/actions/signIn/authorization.d.ts +32 -21
- package/dist/actions/signIn/authorization.js +12 -9
- package/dist/actions/signIn/signIn.cjs +470 -235
- package/dist/actions/signIn/signIn.d.ts +12 -3
- package/dist/actions/signIn/signIn.js +11 -8
- package/dist/actions/signOut/signOut.cjs +376 -228
- package/dist/actions/signOut/signOut.d.ts +1 -1
- package/dist/actions/signOut/signOut.js +10 -9
- package/dist/api/createApi.cjs +750 -0
- package/dist/api/createApi.d.ts +12 -0
- package/dist/api/createApi.js +19 -0
- package/dist/api/getSession.cjs +141 -0
- package/dist/api/getSession.d.ts +16 -0
- package/dist/api/getSession.js +10 -0
- package/dist/api/signIn.cjs +549 -0
- package/dist/api/signIn.d.ts +26 -0
- package/dist/api/signIn.js +15 -0
- package/dist/api/signOut.cjs +279 -0
- package/dist/api/signOut.d.ts +16 -0
- package/dist/api/signOut.js +13 -0
- package/dist/assert.cjs +150 -5
- package/dist/assert.d.ts +26 -3
- package/dist/assert.js +17 -3
- package/dist/{chunk-YRCB5FLE.js → chunk-2A5B7GWR.js} +52 -6
- package/dist/chunk-2GQLSIJ2.js +40 -0
- package/dist/chunk-2IR674WX.js +44 -0
- package/dist/chunk-3J5TUH2I.js +50 -0
- package/dist/chunk-4RWSYUKX.js +98 -0
- package/dist/chunk-4YHJ4IEQ.js +25 -0
- package/dist/chunk-54CZPKR4.js +25 -0
- package/dist/chunk-5LZ7TOM3.js +25 -0
- package/dist/chunk-7BE46WWS.js +88 -0
- package/dist/chunk-7YYXFKLR.js +35 -0
- package/dist/chunk-C3A37LQC.js +33 -0
- package/dist/chunk-CITNGXDA.js +31 -0
- package/dist/chunk-CWX724AG.js +78 -0
- package/dist/chunk-D2CSIUKP.js +74 -0
- package/dist/chunk-E6G5YCI6.js +25 -0
- package/dist/chunk-EBAMFRB7.js +34 -0
- package/dist/chunk-EEE7UM5T.js +25 -0
- package/dist/{chunk-HT4YLL7N.js → chunk-FPCVZUVG.js} +10 -8
- package/dist/chunk-FW4W3REU.js +25 -0
- package/dist/chunk-GNNBM2WJ.js +83 -0
- package/dist/chunk-IPKO6UQN.js +25 -0
- package/dist/chunk-JOCGX3RP.js +59 -0
- package/dist/chunk-KBXWTD6E.js +94 -0
- package/dist/chunk-KMMAZFSJ.js +25 -0
- package/dist/chunk-LATR3NIV.js +117 -0
- package/dist/chunk-LAYPUDQF.js +39 -0
- package/dist/chunk-LDU7A2JE.js +25 -0
- package/dist/chunk-LX3TJ2TJ.js +294 -0
- package/dist/chunk-NHZBQNRR.js +143 -0
- package/dist/chunk-OVHNRULD.js +33 -0
- package/dist/chunk-PDP3PHB3.js +127 -0
- package/dist/chunk-PHYNROD4.js +47 -0
- package/dist/chunk-QQEKY4XP.js +29 -0
- package/dist/chunk-U4RK4LKJ.js +348 -0
- package/dist/{chunk-RRLIF4PQ.js → chunk-U5663F2U.js} +16 -1
- package/dist/chunk-UN7X6SU5.js +53 -0
- package/dist/chunk-UZQJJD6A.js +100 -0
- package/dist/chunk-V6LLEAR4.js +80 -0
- package/dist/chunk-WHNDRO3N.js +50 -0
- package/dist/{chunk-W6LG7BFW.js → chunk-XY5R3EHH.js} +30 -23
- package/dist/client/client.cjs +135 -0
- package/dist/client/client.d.ts +85 -0
- package/dist/client/client.js +9 -0
- package/dist/client/index.cjs +135 -0
- package/dist/client/index.d.ts +14 -0
- package/dist/client/index.js +10 -0
- package/dist/context.cjs +1237 -0
- package/dist/context.d.ts +16 -0
- package/dist/context.js +28 -0
- package/dist/cookie.cjs +57 -22
- package/dist/cookie.d.ts +11 -6
- package/dist/cookie.js +3 -2
- package/dist/createAuth.cjs +2320 -0
- package/dist/createAuth.d.ts +12 -0
- package/dist/createAuth.js +48 -0
- package/dist/env.cjs +78 -0
- package/dist/env.d.ts +10 -0
- package/dist/env.js +12 -0
- package/dist/errors.cjs +17 -0
- package/dist/errors.d.ts +15 -4
- package/dist/errors.js +5 -1
- package/dist/headers.cjs +28 -2
- package/dist/headers.d.ts +25 -1
- package/dist/headers.js +9 -3
- package/dist/index-_aXtxb_s.d.ts +1377 -0
- package/dist/index.cjs +1843 -610
- package/dist/index.d.ts +11 -92
- package/dist/index.js +53 -85
- package/dist/jose.cjs +113 -38
- package/dist/jose.d.ts +12 -23
- package/dist/jose.js +17 -7
- package/dist/logger.cjs +424 -0
- package/dist/logger.d.ts +12 -0
- package/dist/logger.js +17 -0
- package/dist/oauth/atlassian.cjs +57 -0
- package/dist/oauth/atlassian.d.ts +12 -0
- package/dist/oauth/atlassian.js +6 -0
- package/dist/oauth/bitbucket.cjs +19 -15
- package/dist/oauth/bitbucket.d.ts +7 -2
- package/dist/oauth/bitbucket.js +1 -1
- package/dist/oauth/discord.cjs +27 -24
- package/dist/oauth/discord.d.ts +7 -2
- package/dist/oauth/discord.js +1 -1
- package/dist/oauth/dropbox.cjs +53 -0
- package/dist/oauth/dropbox.d.ts +12 -0
- package/dist/oauth/dropbox.js +6 -0
- package/dist/oauth/figma.cjs +19 -16
- package/dist/oauth/figma.d.ts +7 -2
- package/dist/oauth/figma.js +1 -1
- package/dist/oauth/github.cjs +19 -8
- package/dist/oauth/github.d.ts +7 -2
- package/dist/oauth/github.js +1 -1
- package/dist/oauth/gitlab.cjs +19 -16
- package/dist/oauth/gitlab.d.ts +7 -2
- package/dist/oauth/gitlab.js +1 -1
- package/dist/oauth/index.cjs +529 -239
- package/dist/oauth/index.d.ts +7 -2
- package/dist/oauth/index.js +39 -22
- package/dist/oauth/mailchimp.cjs +19 -16
- package/dist/oauth/mailchimp.d.ts +7 -2
- package/dist/oauth/mailchimp.js +1 -1
- package/dist/oauth/notion.cjs +131 -0
- package/dist/oauth/notion.d.ts +12 -0
- package/dist/oauth/notion.js +9 -0
- package/dist/oauth/pinterest.cjs +19 -16
- package/dist/oauth/pinterest.d.ts +7 -2
- package/dist/oauth/pinterest.js +1 -1
- package/dist/oauth/spotify.cjs +19 -16
- package/dist/oauth/spotify.d.ts +7 -2
- package/dist/oauth/spotify.js +1 -1
- package/dist/oauth/strava.cjs +19 -16
- package/dist/oauth/strava.d.ts +7 -2
- package/dist/oauth/strava.js +1 -1
- package/dist/oauth/twitch.cjs +95 -0
- package/dist/oauth/twitch.d.ts +12 -0
- package/dist/oauth/twitch.js +7 -0
- package/dist/oauth/x.cjs +19 -16
- package/dist/oauth/x.d.ts +7 -2
- package/dist/oauth/x.js +1 -1
- package/dist/schemas.cjs +89 -42
- package/dist/schemas.d.ts +114 -18
- package/dist/schemas.js +5 -3
- package/dist/secure.cjs +73 -31
- package/dist/secure.d.ts +11 -11
- package/dist/secure.js +7 -6
- package/dist/utils.cjs +203 -90
- package/dist/utils.d.ts +21 -40
- package/dist/utils.js +21 -12
- package/package.json +9 -6
- package/dist/chunk-3EUWD5BB.js +0 -63
- package/dist/chunk-42XB3YCW.js +0 -22
- package/dist/chunk-6R2YZ4AC.js +0 -22
- package/dist/chunk-A3N4PVAT.js +0 -70
- package/dist/chunk-B737EUJV.js +0 -22
- package/dist/chunk-CXLATHS5.js +0 -143
- package/dist/chunk-E3OXBRYF.js +0 -22
- package/dist/chunk-EIL2FPSS.js +0 -22
- package/dist/chunk-EMKJA2GJ.js +0 -89
- package/dist/chunk-FIPU4MLT.js +0 -21
- package/dist/chunk-FKRDCWBF.js +0 -22
- package/dist/chunk-GA2SMTJO.js +0 -58
- package/dist/chunk-HP34YGGJ.js +0 -22
- package/dist/chunk-IKHPGFCW.js +0 -14
- package/dist/chunk-IUYZQTJV.js +0 -30
- package/dist/chunk-IVET23KF.js +0 -58
- package/dist/chunk-JVFTCTTE.js +0 -33
- package/dist/chunk-KRNOMBXQ.js +0 -22
- package/dist/chunk-KSWLO5ZU.js +0 -102
- package/dist/chunk-N2APGLXA.js +0 -71
- package/dist/chunk-N4SX7TZT.js +0 -96
- package/dist/chunk-STHEPPUZ.js +0 -11
- package/dist/chunk-TLE4PXY3.js +0 -39
- package/dist/index-B8jeIElf.d.ts +0 -679
- /package/dist/{chunk-DIVDFNAP.js → chunk-5X7JZMEF.js} +0 -0
|
@@ -0,0 +1,348 @@
|
|
|
1
|
+
import {
|
|
2
|
+
createStructuredData
|
|
3
|
+
} from "./chunk-LX3TJ2TJ.js";
|
|
4
|
+
import {
|
|
5
|
+
getEnv,
|
|
6
|
+
getEnvBoolean
|
|
7
|
+
} from "./chunk-WHNDRO3N.js";
|
|
8
|
+
|
|
9
|
+
// src/logger.ts
|
|
10
|
+
var logMessages = {
|
|
11
|
+
ROUTER_INTERNAL_ERROR: {
|
|
12
|
+
facility: 10,
|
|
13
|
+
severity: "error",
|
|
14
|
+
msgId: "ROUTER_INTERNAL_ERROR",
|
|
15
|
+
message: "Unhandled router error while processing the request"
|
|
16
|
+
},
|
|
17
|
+
INVALID_REQUEST: {
|
|
18
|
+
facility: 10,
|
|
19
|
+
severity: "warning",
|
|
20
|
+
msgId: "INVALID_REQUEST",
|
|
21
|
+
message: "Request validation failed against the expected schema"
|
|
22
|
+
},
|
|
23
|
+
SERVER_ERROR: {
|
|
24
|
+
facility: 10,
|
|
25
|
+
severity: "error",
|
|
26
|
+
msgId: "SERVER_ERROR",
|
|
27
|
+
message: "Unexpected internal server error during authentication"
|
|
28
|
+
},
|
|
29
|
+
OAUTH_PROTOCOL_ERROR: {
|
|
30
|
+
facility: 10,
|
|
31
|
+
severity: "warning",
|
|
32
|
+
msgId: "OAUTH_PROTOCOL_ERROR",
|
|
33
|
+
message: "OAuth provider returned an invalid or unexpected protocol response"
|
|
34
|
+
},
|
|
35
|
+
OAUTH_AUTHORIZATION_ERROR: {
|
|
36
|
+
facility: 10,
|
|
37
|
+
severity: "error",
|
|
38
|
+
msgId: "OAUTH_AUTHORIZATION_ERROR",
|
|
39
|
+
message: "OAuth authorization request was rejected or failed"
|
|
40
|
+
},
|
|
41
|
+
INVALID_OAUTH_CONFIGURATION: {
|
|
42
|
+
facility: 10,
|
|
43
|
+
severity: "error",
|
|
44
|
+
msgId: "INVALID_OAUTH_CONFIGURATION",
|
|
45
|
+
message: "The OAuth provider configuration is invalid or incomplete"
|
|
46
|
+
},
|
|
47
|
+
OAUTH_ACCESS_TOKEN_REQUEST_INITIATED: {
|
|
48
|
+
facility: 10,
|
|
49
|
+
severity: "debug",
|
|
50
|
+
msgId: "OAUTH_ACCESS_TOKEN_REQUEST_INITIATED",
|
|
51
|
+
message: "Starting OAuth access token request to the provider"
|
|
52
|
+
},
|
|
53
|
+
INVALID_OAUTH_ACCESS_TOKEN_RESPONSE: {
|
|
54
|
+
facility: 10,
|
|
55
|
+
severity: "error",
|
|
56
|
+
msgId: "INVALID_OAUTH_ACCESS_TOKEN_RESPONSE",
|
|
57
|
+
message: "OAuth access token endpoint returned an invalid or malformed response"
|
|
58
|
+
},
|
|
59
|
+
OAUTH_ACCESS_TOKEN_ERROR: {
|
|
60
|
+
facility: 10,
|
|
61
|
+
severity: "error",
|
|
62
|
+
msgId: "OAUTH_ACCESS_TOKEN_ERROR",
|
|
63
|
+
message: "OAuth access token endpoint returned an error response"
|
|
64
|
+
},
|
|
65
|
+
OAUTH_ACCESS_TOKEN_SUCCESS: {
|
|
66
|
+
facility: 10,
|
|
67
|
+
severity: "info",
|
|
68
|
+
msgId: "OAUTH_ACCESS_TOKEN_SUCCESS",
|
|
69
|
+
message: "Successfully retrieved OAuth access token from the provider"
|
|
70
|
+
},
|
|
71
|
+
OAUTH_ACCESS_TOKEN_REQUEST_FAILED: {
|
|
72
|
+
facility: 10,
|
|
73
|
+
severity: "error",
|
|
74
|
+
msgId: "OAUTH_ACCESS_TOKEN_REQUEST_FAILED",
|
|
75
|
+
message: "Network or server error while requesting OAuth access token"
|
|
76
|
+
},
|
|
77
|
+
OAUTH_USERINFO_REQUEST_INITIATED: {
|
|
78
|
+
facility: 10,
|
|
79
|
+
severity: "debug",
|
|
80
|
+
msgId: "OAUTH_USERINFO_REQUEST_INITIATED",
|
|
81
|
+
message: "Starting OAuth userinfo request to the provider"
|
|
82
|
+
},
|
|
83
|
+
OAUTH_USERINFO_INVALID_RESPONSE: {
|
|
84
|
+
facility: 10,
|
|
85
|
+
severity: "error",
|
|
86
|
+
msgId: "OAUTH_USERINFO_INVALID_RESPONSE",
|
|
87
|
+
message: "OAuth userinfo endpoint returned an invalid or malformed response"
|
|
88
|
+
},
|
|
89
|
+
OAUTH_USERINFO_ERROR: {
|
|
90
|
+
facility: 10,
|
|
91
|
+
severity: "error",
|
|
92
|
+
msgId: "OAUTH_USERINFO_ERROR",
|
|
93
|
+
message: "OAuth userinfo endpoint returned an error response"
|
|
94
|
+
},
|
|
95
|
+
OAUTH_USERINFO_SUCCESS: {
|
|
96
|
+
facility: 10,
|
|
97
|
+
severity: "info",
|
|
98
|
+
msgId: "OAUTH_USERINFO_SUCCESS",
|
|
99
|
+
message: "Successfully retrieved user information from the OAuth provider"
|
|
100
|
+
},
|
|
101
|
+
OAUTH_USERINFO_REQUEST_FAILED: {
|
|
102
|
+
facility: 10,
|
|
103
|
+
severity: "error",
|
|
104
|
+
msgId: "OAUTH_USERINFO_REQUEST_FAILED",
|
|
105
|
+
message: "Network or server error while requesting user information from the OAuth provider"
|
|
106
|
+
},
|
|
107
|
+
OAUTH_CALLBACK_SUCCESS: {
|
|
108
|
+
facility: 4,
|
|
109
|
+
severity: "info",
|
|
110
|
+
msgId: "OAUTH_CALLBACK_SUCCESS",
|
|
111
|
+
message: "OAuth callback completed successfully and session was created"
|
|
112
|
+
},
|
|
113
|
+
MISMATCHING_STATE: {
|
|
114
|
+
facility: 4,
|
|
115
|
+
severity: "critical",
|
|
116
|
+
msgId: "MISMATCHING_STATE",
|
|
117
|
+
message: "OAuth response state parameter does not match the stored state value"
|
|
118
|
+
},
|
|
119
|
+
POTENTIAL_OPEN_REDIRECT_ATTACK_DETECTED: {
|
|
120
|
+
facility: 4,
|
|
121
|
+
severity: "critical",
|
|
122
|
+
msgId: "POTENTIAL_OPEN_REDIRECT_ATTACK_DETECTED",
|
|
123
|
+
message: "Blocked redirect to untrusted or external URL (potential open redirect attack)"
|
|
124
|
+
},
|
|
125
|
+
OPEN_REDIRECT_ATTACK: {
|
|
126
|
+
facility: 4,
|
|
127
|
+
severity: "warning",
|
|
128
|
+
msgId: "OPEN_REDIRECT_ATTACK",
|
|
129
|
+
message: "Detected redirect target that does not match the trusted origin"
|
|
130
|
+
},
|
|
131
|
+
SESSION_TOKEN_MISSING: {
|
|
132
|
+
facility: 4,
|
|
133
|
+
severity: "warning",
|
|
134
|
+
msgId: "SESSION_TOKEN_MISSING",
|
|
135
|
+
message: "Session cookie is missing from the request"
|
|
136
|
+
},
|
|
137
|
+
CSRF_TOKEN_MISSING: {
|
|
138
|
+
facility: 4,
|
|
139
|
+
severity: "warning",
|
|
140
|
+
msgId: "CSRF_TOKEN_MISSING",
|
|
141
|
+
message: "CSRF token cookie is missing from the request"
|
|
142
|
+
},
|
|
143
|
+
CSRF_HEADER_MISSING: {
|
|
144
|
+
facility: 4,
|
|
145
|
+
severity: "warning",
|
|
146
|
+
msgId: "CSRF_HEADER_MISSING",
|
|
147
|
+
message: "CSRF header is missing from the request"
|
|
148
|
+
},
|
|
149
|
+
CSRF_TOKEN_INVALID: {
|
|
150
|
+
facility: 4,
|
|
151
|
+
severity: "error",
|
|
152
|
+
msgId: "CSRF_TOKEN_INVALID",
|
|
153
|
+
message: "CSRF token verification failed or token is invalid"
|
|
154
|
+
},
|
|
155
|
+
SIGN_IN_INITIATED: {
|
|
156
|
+
facility: 4,
|
|
157
|
+
severity: "info",
|
|
158
|
+
msgId: "SIGN_IN_INITIATED",
|
|
159
|
+
message: "Starting OAuth sign-in flow for the selected provider"
|
|
160
|
+
},
|
|
161
|
+
SIGN_OUT_ATTEMPT: {
|
|
162
|
+
facility: 4,
|
|
163
|
+
severity: "debug",
|
|
164
|
+
msgId: "SIGN_OUT_ATTEMPT",
|
|
165
|
+
message: "Received sign-out request from client"
|
|
166
|
+
},
|
|
167
|
+
SIGN_OUT_CSRF_VERIFIED: {
|
|
168
|
+
facility: 4,
|
|
169
|
+
severity: "info",
|
|
170
|
+
msgId: "SIGN_OUT_CSRF_VERIFIED",
|
|
171
|
+
message: "CSRF token was successfully verified during sign-out"
|
|
172
|
+
},
|
|
173
|
+
SIGN_OUT_SUCCESS: {
|
|
174
|
+
facility: 4,
|
|
175
|
+
severity: "info",
|
|
176
|
+
msgId: "SIGN_OUT_SUCCESS",
|
|
177
|
+
message: "User session was cleared and sign-out completed successfully"
|
|
178
|
+
},
|
|
179
|
+
SIGN_OUT_REDIRECT: {
|
|
180
|
+
facility: 4,
|
|
181
|
+
severity: "debug",
|
|
182
|
+
msgId: "SIGN_OUT_REDIRECT",
|
|
183
|
+
message: "Redirecting client after successful sign-out"
|
|
184
|
+
},
|
|
185
|
+
AUTH_SESSION_VALID: {
|
|
186
|
+
facility: 4,
|
|
187
|
+
severity: "info",
|
|
188
|
+
msgId: "AUTH_SESSION_VALID",
|
|
189
|
+
message: "Session token is valid and user session was returned"
|
|
190
|
+
},
|
|
191
|
+
AUTH_SESSION_INVALID: {
|
|
192
|
+
facility: 4,
|
|
193
|
+
severity: "notice",
|
|
194
|
+
msgId: "AUTH_SESSION_INVALID",
|
|
195
|
+
message: "Session token is missing, expired, or invalid"
|
|
196
|
+
},
|
|
197
|
+
INVALID_JWT_TOKEN: {
|
|
198
|
+
facility: 4,
|
|
199
|
+
severity: "warning",
|
|
200
|
+
msgId: "INVALID_JWT_TOKEN",
|
|
201
|
+
message: "JWT session token failed validation during sign-out"
|
|
202
|
+
},
|
|
203
|
+
CSRF_TOKEN_REQUESTED: {
|
|
204
|
+
facility: 4,
|
|
205
|
+
severity: "debug",
|
|
206
|
+
msgId: "CSRF_TOKEN_REQUESTED",
|
|
207
|
+
message: "Client requested a CSRF token"
|
|
208
|
+
},
|
|
209
|
+
CSRF_TOKEN_ISSUED: {
|
|
210
|
+
facility: 4,
|
|
211
|
+
severity: "debug",
|
|
212
|
+
msgId: "CSRF_TOKEN_ISSUED",
|
|
213
|
+
message: "Issued a new CSRF token to the client"
|
|
214
|
+
},
|
|
215
|
+
INVALID_URL: {
|
|
216
|
+
facility: 10,
|
|
217
|
+
severity: "error",
|
|
218
|
+
msgId: "INVALID_URL",
|
|
219
|
+
message: "Derived origin URL is invalid or malformed"
|
|
220
|
+
},
|
|
221
|
+
COOKIE_HTTPONLY_DISABLED: {
|
|
222
|
+
facility: 10,
|
|
223
|
+
severity: "critical",
|
|
224
|
+
msgId: "COOKIE_HTTPONLY_DISABLED",
|
|
225
|
+
message: "Cookie is configured without HttpOnly. This allows JavaScript access via document.cookie and increases XSS exposure."
|
|
226
|
+
},
|
|
227
|
+
COOKIE_WILDCARD_DOMAIN: {
|
|
228
|
+
facility: 10,
|
|
229
|
+
severity: "critical",
|
|
230
|
+
msgId: "COOKIE_WILDCARD_DOMAIN",
|
|
231
|
+
message: "Cookie 'Domain' is set to a wildcard, which is insecure and should be avoided."
|
|
232
|
+
},
|
|
233
|
+
COOKIE_SECURE_DISABLED: {
|
|
234
|
+
facility: 10,
|
|
235
|
+
severity: "warning",
|
|
236
|
+
msgId: "COOKIE_SECURE_DISABLED",
|
|
237
|
+
message: "Cookie is configured with 'Secure' but the request is not HTTPS. The 'Secure' attribute will be ignored by the browser."
|
|
238
|
+
},
|
|
239
|
+
COOKIE_SAMESITE_NONE_WITHOUT_SECURE: {
|
|
240
|
+
facility: 10,
|
|
241
|
+
severity: "warning",
|
|
242
|
+
msgId: "COOKIE_SAMESITE_NONE_WITHOUT_SECURE",
|
|
243
|
+
message: "Cookie uses SameSite=None without Secure. Falling back to SameSite=Lax for safer defaults."
|
|
244
|
+
},
|
|
245
|
+
COOKIE_INSECURE_IN_PRODUCTION: {
|
|
246
|
+
facility: 10,
|
|
247
|
+
severity: "critical",
|
|
248
|
+
msgId: "COOKIE_INSECURE_IN_PRODUCTION",
|
|
249
|
+
message: "Cookies are being served over an insecure connection in production, which is a serious security risk."
|
|
250
|
+
},
|
|
251
|
+
COOKIE_HOST_STRATEGY_INSECURE: {
|
|
252
|
+
facility: 10,
|
|
253
|
+
severity: "critical",
|
|
254
|
+
msgId: "COOKIE_HOST_STRATEGY_INSECURE",
|
|
255
|
+
message: "__Host- cookies require a secure HTTPS context. Falling back to standard cookie settings."
|
|
256
|
+
},
|
|
257
|
+
UNTRUSTED_ORIGIN: {
|
|
258
|
+
facility: 10,
|
|
259
|
+
severity: "error",
|
|
260
|
+
msgId: "UNTRUSTED_ORIGIN",
|
|
261
|
+
message: "The constructed origin URL is not trusted."
|
|
262
|
+
}
|
|
263
|
+
};
|
|
264
|
+
var createLogEntry = (key, overrides) => {
|
|
265
|
+
const message = logMessages[key];
|
|
266
|
+
return {
|
|
267
|
+
...message,
|
|
268
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
269
|
+
hostname: "aura-auth",
|
|
270
|
+
procId: typeof process !== "undefined" && process.pid ? process.pid.toString() : "-",
|
|
271
|
+
...overrides
|
|
272
|
+
};
|
|
273
|
+
};
|
|
274
|
+
var logLevelToSeverity = {
|
|
275
|
+
debug: ["debug", "info", "notice", "warning", "error", "critical", "alert", "emergency"],
|
|
276
|
+
info: ["info", "notice", "warning", "error", "critical", "alert", "emergency"],
|
|
277
|
+
warn: ["warning", "error", "critical", "alert", "emergency"],
|
|
278
|
+
error: ["error", "critical", "alert", "emergency"]
|
|
279
|
+
};
|
|
280
|
+
var isValidLogLevel = (value) => {
|
|
281
|
+
return value === "debug" || value === "info" || value === "warn" || value === "error";
|
|
282
|
+
};
|
|
283
|
+
var getSeverityLevel = (severity) => {
|
|
284
|
+
const severities = {
|
|
285
|
+
emergency: 0,
|
|
286
|
+
alert: 1,
|
|
287
|
+
critical: 2,
|
|
288
|
+
error: 3,
|
|
289
|
+
warning: 4,
|
|
290
|
+
notice: 5,
|
|
291
|
+
info: 6,
|
|
292
|
+
debug: 7
|
|
293
|
+
};
|
|
294
|
+
return severities[severity] ?? 6;
|
|
295
|
+
};
|
|
296
|
+
var createSyslogMessage = (options) => {
|
|
297
|
+
const { timestamp, hostname, appName = "aura-auth", procId = "-", msgId, structuredData, message } = options;
|
|
298
|
+
const pri = (options.facility ?? 16) * 8 + getSeverityLevel(options.severity);
|
|
299
|
+
const structuredDataStr = createStructuredData(structuredData ?? {});
|
|
300
|
+
return `<${pri}>1 ${timestamp} ${hostname} ${appName} ${procId} ${msgId} ${structuredDataStr} ${message}`;
|
|
301
|
+
};
|
|
302
|
+
var createLogger = (logger) => {
|
|
303
|
+
if (!logger) return void 0;
|
|
304
|
+
const level = logger.level;
|
|
305
|
+
const allowedSeverities = logLevelToSeverity[level] ?? [];
|
|
306
|
+
return {
|
|
307
|
+
level,
|
|
308
|
+
log(key, overrides) {
|
|
309
|
+
const entry = createLogEntry(key, overrides);
|
|
310
|
+
if (!allowedSeverities.includes(entry.severity)) return entry;
|
|
311
|
+
logger.log({
|
|
312
|
+
timestamp: entry.timestamp,
|
|
313
|
+
appName: entry.appName ?? "aura-auth",
|
|
314
|
+
hostname: entry.hostname ?? "aura-auth",
|
|
315
|
+
...entry
|
|
316
|
+
});
|
|
317
|
+
return entry;
|
|
318
|
+
}
|
|
319
|
+
};
|
|
320
|
+
};
|
|
321
|
+
var createProxyLogger = (config) => {
|
|
322
|
+
const level = getEnv("LOG_LEVEL");
|
|
323
|
+
const debug = getEnvBoolean("DEBUG");
|
|
324
|
+
if (typeof config?.logger === "object") {
|
|
325
|
+
return createLogger({
|
|
326
|
+
log: config.logger?.log || createSyslogMessage,
|
|
327
|
+
level: isValidLogLevel(config.logger?.level) ? config.logger?.level : isValidLogLevel(level) ? level : "error"
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
if (debug || config?.logger === true || level) {
|
|
331
|
+
return createLogger({
|
|
332
|
+
level: isValidLogLevel(level) ? level : "debug",
|
|
333
|
+
log: (options) => {
|
|
334
|
+
const message = createSyslogMessage(options);
|
|
335
|
+
console.log(message);
|
|
336
|
+
}
|
|
337
|
+
});
|
|
338
|
+
}
|
|
339
|
+
return void 0;
|
|
340
|
+
};
|
|
341
|
+
|
|
342
|
+
export {
|
|
343
|
+
logMessages,
|
|
344
|
+
createLogEntry,
|
|
345
|
+
createSyslogMessage,
|
|
346
|
+
createLogger,
|
|
347
|
+
createProxyLogger
|
|
348
|
+
};
|
|
@@ -31,6 +31,16 @@ var AuthSecurityError = class extends Error {
|
|
|
31
31
|
Error.captureStackTrace(this, new.target);
|
|
32
32
|
}
|
|
33
33
|
};
|
|
34
|
+
var AuthClientError = class extends Error {
|
|
35
|
+
type = "AUTH_CLIENT_ERROR";
|
|
36
|
+
code;
|
|
37
|
+
constructor(code, message, options) {
|
|
38
|
+
super(message, options);
|
|
39
|
+
this.code = code;
|
|
40
|
+
this.name = new.target.name;
|
|
41
|
+
Error.captureStackTrace(this, new.target);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
34
44
|
var isNativeError = (error) => {
|
|
35
45
|
return error instanceof Error;
|
|
36
46
|
};
|
|
@@ -43,13 +53,18 @@ var isAuthInternalError = (error) => {
|
|
|
43
53
|
var isAuthSecurityError = (error) => {
|
|
44
54
|
return error instanceof AuthSecurityError;
|
|
45
55
|
};
|
|
56
|
+
var isAuthClientError = (error) => {
|
|
57
|
+
return error instanceof AuthClientError;
|
|
58
|
+
};
|
|
46
59
|
|
|
47
60
|
export {
|
|
48
61
|
OAuthProtocolError,
|
|
49
62
|
AuthInternalError,
|
|
50
63
|
AuthSecurityError,
|
|
64
|
+
AuthClientError,
|
|
51
65
|
isNativeError,
|
|
52
66
|
isOAuthProtocolError,
|
|
53
67
|
isAuthInternalError,
|
|
54
|
-
isAuthSecurityError
|
|
68
|
+
isAuthSecurityError,
|
|
69
|
+
isAuthClientError
|
|
55
70
|
};
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import {
|
|
2
|
+
signIn
|
|
3
|
+
} from "./chunk-JOCGX3RP.js";
|
|
4
|
+
|
|
5
|
+
// src/actions/signIn/signIn.ts
|
|
6
|
+
import { z } from "zod/v4";
|
|
7
|
+
import { createEndpoint, createEndpointConfig } from "@aura-stack/router";
|
|
8
|
+
var signInConfig = (oauth) => {
|
|
9
|
+
return createEndpointConfig("/signIn/:oauth", {
|
|
10
|
+
schemas: {
|
|
11
|
+
params: z.object({
|
|
12
|
+
oauth: z.enum(
|
|
13
|
+
Object.keys(oauth),
|
|
14
|
+
"The OAuth provider is not supported or invalid."
|
|
15
|
+
)
|
|
16
|
+
}),
|
|
17
|
+
searchParams: z.object({
|
|
18
|
+
redirect: z.stringbool().optional().default(true),
|
|
19
|
+
redirectTo: z.string().optional()
|
|
20
|
+
})
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
};
|
|
24
|
+
var signInAction = (oauth) => {
|
|
25
|
+
return createEndpoint(
|
|
26
|
+
"GET",
|
|
27
|
+
"/signIn/:oauth",
|
|
28
|
+
async (ctx) => {
|
|
29
|
+
const {
|
|
30
|
+
request,
|
|
31
|
+
params: { oauth: oauth2 },
|
|
32
|
+
searchParams: { redirectTo, redirect },
|
|
33
|
+
context
|
|
34
|
+
} = ctx;
|
|
35
|
+
const signInResult = await signIn(oauth2, {
|
|
36
|
+
ctx: context,
|
|
37
|
+
headers: request.headers,
|
|
38
|
+
redirect,
|
|
39
|
+
redirectTo,
|
|
40
|
+
request
|
|
41
|
+
});
|
|
42
|
+
if (!redirect) {
|
|
43
|
+
return Response.json(signInResult, { status: 200 });
|
|
44
|
+
}
|
|
45
|
+
return signInResult;
|
|
46
|
+
},
|
|
47
|
+
signInConfig(oauth)
|
|
48
|
+
);
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export {
|
|
52
|
+
signInAction
|
|
53
|
+
};
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getEnv
|
|
3
|
+
} from "./chunk-WHNDRO3N.js";
|
|
4
|
+
import {
|
|
5
|
+
AuthInternalError
|
|
6
|
+
} from "./chunk-U5663F2U.js";
|
|
7
|
+
|
|
8
|
+
// src/jose.ts
|
|
9
|
+
import {
|
|
10
|
+
createJWT,
|
|
11
|
+
createJWS,
|
|
12
|
+
createJWE,
|
|
13
|
+
createDeriveKey,
|
|
14
|
+
createSecret
|
|
15
|
+
} from "@aura-stack/jose";
|
|
16
|
+
import { base64url } from "@aura-stack/jose/jose";
|
|
17
|
+
import { encoder, getRandomBytes, getSubtleCrypto } from "@aura-stack/jose/crypto";
|
|
18
|
+
var createJoseInstance = (secret) => {
|
|
19
|
+
secret ??= getEnv("SECRET");
|
|
20
|
+
if (!secret) {
|
|
21
|
+
throw new AuthInternalError(
|
|
22
|
+
"JOSE_INITIALIZATION_FAILED",
|
|
23
|
+
"AURA_AUTH_SECRET environment variable is not set and no secret was provided."
|
|
24
|
+
);
|
|
25
|
+
}
|
|
26
|
+
const salt = getEnv("SALT");
|
|
27
|
+
if (!salt) {
|
|
28
|
+
throw new AuthInternalError(
|
|
29
|
+
"JOSE_INITIALIZATION_FAILED",
|
|
30
|
+
"AURA_AUTH_SALT or AUTH_SALT environment variable is not set. A salt value is required for key derivation."
|
|
31
|
+
);
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
createSecret(salt);
|
|
35
|
+
} catch (error) {
|
|
36
|
+
throw new AuthInternalError(
|
|
37
|
+
"INVALID_SALT_SECRET_VALUE",
|
|
38
|
+
"AURA_AUTH_SALT/AUTH_SALT is invalid. It must be at least 32 bytes long and meet entropy requirements.",
|
|
39
|
+
{ cause: error }
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
const jose = (async () => {
|
|
43
|
+
const derivedSigningKey = await createDeriveKey(secret, salt, "signing");
|
|
44
|
+
const derivedEncryptionKey = await createDeriveKey(secret, salt, "encryption");
|
|
45
|
+
const derivedCsrfTokenKey = await createDeriveKey(secret, salt, "csrfToken");
|
|
46
|
+
return {
|
|
47
|
+
jwt: createJWT({ jws: derivedSigningKey, jwe: derivedEncryptionKey }),
|
|
48
|
+
jws: createJWS(derivedCsrfTokenKey),
|
|
49
|
+
jwe: createJWE(derivedEncryptionKey)
|
|
50
|
+
};
|
|
51
|
+
})();
|
|
52
|
+
jose.catch(() => {
|
|
53
|
+
});
|
|
54
|
+
return {
|
|
55
|
+
decodeJWT: async (token, options) => {
|
|
56
|
+
const { jwt } = await jose;
|
|
57
|
+
return jwt.decodeJWT(token, options);
|
|
58
|
+
},
|
|
59
|
+
encodeJWT: async (payload) => {
|
|
60
|
+
const { jwt } = await jose;
|
|
61
|
+
return jwt.encodeJWT(payload);
|
|
62
|
+
},
|
|
63
|
+
signJWS: async (...args) => {
|
|
64
|
+
const { jws } = await jose;
|
|
65
|
+
return jws.signJWS(...args);
|
|
66
|
+
},
|
|
67
|
+
verifyJWS: async (...args) => {
|
|
68
|
+
const { jws } = await jose;
|
|
69
|
+
return jws.verifyJWS(...args);
|
|
70
|
+
},
|
|
71
|
+
encryptJWE: async (...args) => {
|
|
72
|
+
const { jwe } = await jose;
|
|
73
|
+
return jwe.encryptJWE(...args);
|
|
74
|
+
},
|
|
75
|
+
decryptJWE: async (...args) => {
|
|
76
|
+
const { jwe } = await jose;
|
|
77
|
+
return jwe.decryptJWE(...args);
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
};
|
|
81
|
+
var jwtVerificationOptions = {
|
|
82
|
+
algorithms: ["HS256"],
|
|
83
|
+
typ: "JWT"
|
|
84
|
+
};
|
|
85
|
+
var decodeJWTOptions = {
|
|
86
|
+
jws: jwtVerificationOptions,
|
|
87
|
+
jwt: {
|
|
88
|
+
typ: "JWT"
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export {
|
|
93
|
+
createJoseInstance,
|
|
94
|
+
jwtVerificationOptions,
|
|
95
|
+
decodeJWTOptions,
|
|
96
|
+
base64url,
|
|
97
|
+
encoder,
|
|
98
|
+
getRandomBytes,
|
|
99
|
+
getSubtleCrypto
|
|
100
|
+
};
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import {
|
|
2
|
+
base64url,
|
|
3
|
+
encoder,
|
|
4
|
+
getRandomBytes,
|
|
5
|
+
getSubtleCrypto,
|
|
6
|
+
jwtVerificationOptions
|
|
7
|
+
} from "./chunk-UZQJJD6A.js";
|
|
8
|
+
import {
|
|
9
|
+
equals,
|
|
10
|
+
isJWTPayloadWithToken,
|
|
11
|
+
timingSafeEqual
|
|
12
|
+
} from "./chunk-LX3TJ2TJ.js";
|
|
13
|
+
import {
|
|
14
|
+
AuthSecurityError
|
|
15
|
+
} from "./chunk-U5663F2U.js";
|
|
16
|
+
|
|
17
|
+
// src/secure.ts
|
|
18
|
+
var generateSecure = (length = 32) => {
|
|
19
|
+
return base64url.encode(getRandomBytes(length));
|
|
20
|
+
};
|
|
21
|
+
var createSecretValue = (length = 32) => {
|
|
22
|
+
return base64url.encode(getRandomBytes(length));
|
|
23
|
+
};
|
|
24
|
+
var createHash = async (data) => {
|
|
25
|
+
const subtle = getSubtleCrypto();
|
|
26
|
+
const digest = await subtle.digest("SHA-256", encoder.encode(data));
|
|
27
|
+
return base64url.encode(new Uint8Array(digest));
|
|
28
|
+
};
|
|
29
|
+
var createPKCE = async (verifier) => {
|
|
30
|
+
const byteLength = verifier ? void 0 : Math.floor(Math.random() * (96 - 32 + 1) + 32);
|
|
31
|
+
const codeVerifier = verifier ?? generateSecure(byteLength ?? 64);
|
|
32
|
+
if (codeVerifier.length < 43 || codeVerifier.length > 128) {
|
|
33
|
+
throw new AuthSecurityError("PKCE_VERIFIER_INVALID", "The code verifier must be between 43 and 128 characters in length.");
|
|
34
|
+
}
|
|
35
|
+
const codeChallenge = await createHash(codeVerifier);
|
|
36
|
+
return { codeVerifier, codeChallenge, method: "S256" };
|
|
37
|
+
};
|
|
38
|
+
var createCSRF = async (jose, csrfCookie) => {
|
|
39
|
+
try {
|
|
40
|
+
const token = generateSecure(32);
|
|
41
|
+
if (csrfCookie) {
|
|
42
|
+
await jose.verifyJWS(csrfCookie, jwtVerificationOptions);
|
|
43
|
+
return csrfCookie;
|
|
44
|
+
}
|
|
45
|
+
return jose.signJWS({ token });
|
|
46
|
+
} catch {
|
|
47
|
+
const token = generateSecure(32);
|
|
48
|
+
return jose.signJWS({ token });
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
var verifyCSRF = async (jose, cookie, header) => {
|
|
52
|
+
try {
|
|
53
|
+
const cookiePayload = await jose.verifyJWS(cookie, jwtVerificationOptions);
|
|
54
|
+
const headerPayload = await jose.verifyJWS(header, jwtVerificationOptions);
|
|
55
|
+
if (!isJWTPayloadWithToken(cookiePayload)) {
|
|
56
|
+
throw new AuthSecurityError("CSRF_TOKEN_INVALID", "Cookie payload missing token field.");
|
|
57
|
+
}
|
|
58
|
+
if (!isJWTPayloadWithToken(headerPayload)) {
|
|
59
|
+
throw new AuthSecurityError("CSRF_TOKEN_INVALID", "Header payload missing token field.");
|
|
60
|
+
}
|
|
61
|
+
if (!equals(cookiePayload.token.length, headerPayload.token.length)) {
|
|
62
|
+
throw new AuthSecurityError("CSRF_TOKEN_INVALID", "The CSRF tokens do not match.");
|
|
63
|
+
}
|
|
64
|
+
if (!timingSafeEqual(cookiePayload.token, headerPayload.token)) {
|
|
65
|
+
throw new AuthSecurityError("CSRF_TOKEN_INVALID", "The CSRF tokens do not match.");
|
|
66
|
+
}
|
|
67
|
+
return true;
|
|
68
|
+
} catch {
|
|
69
|
+
throw new AuthSecurityError("CSRF_TOKEN_INVALID", "The CSRF tokens do not match.");
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export {
|
|
74
|
+
generateSecure,
|
|
75
|
+
createSecretValue,
|
|
76
|
+
createHash,
|
|
77
|
+
createPKCE,
|
|
78
|
+
createCSRF,
|
|
79
|
+
verifyCSRF
|
|
80
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
// src/env.ts
|
|
2
|
+
var env = new Proxy({}, {
|
|
3
|
+
get(_, prop) {
|
|
4
|
+
if (typeof prop !== "string") return void 0;
|
|
5
|
+
const hasProperty = (process2) => {
|
|
6
|
+
return process2 && Object.prototype.hasOwnProperty.call(process2, prop);
|
|
7
|
+
};
|
|
8
|
+
try {
|
|
9
|
+
if (typeof process !== "undefined" && hasProperty(process.env)) {
|
|
10
|
+
return process.env[prop];
|
|
11
|
+
}
|
|
12
|
+
if (typeof import.meta !== "undefined" && hasProperty(import.meta.env)) {
|
|
13
|
+
return import.meta.env[prop];
|
|
14
|
+
}
|
|
15
|
+
if (typeof Deno !== "undefined" && Deno.env?.get) {
|
|
16
|
+
return Deno.env.get(prop);
|
|
17
|
+
}
|
|
18
|
+
if (typeof Bun !== "undefined" && hasProperty(Bun.env)) {
|
|
19
|
+
return Bun.env[prop];
|
|
20
|
+
}
|
|
21
|
+
const globalValue = globalThis[prop];
|
|
22
|
+
return typeof globalValue === "string" ? globalValue : void 0;
|
|
23
|
+
} catch {
|
|
24
|
+
return void 0;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
var getEnv = (key) => {
|
|
29
|
+
const keys = [`AURA_AUTH_${key.toUpperCase()}`, `AURA_${key.toUpperCase()}`, `AUTH_${key.toUpperCase()}`, key.toUpperCase()];
|
|
30
|
+
return env[keys.find((k) => env[k]) ?? ""];
|
|
31
|
+
};
|
|
32
|
+
var getEnvBoolean = (key) => {
|
|
33
|
+
const value = getEnv(key);
|
|
34
|
+
if (value === void 0) return false;
|
|
35
|
+
const normalized = value.trim().toLowerCase();
|
|
36
|
+
if (["1", "true", "yes", "on", "debug"].includes(normalized)) return true;
|
|
37
|
+
return false;
|
|
38
|
+
};
|
|
39
|
+
var getEnvArray = (key, defaultValue = []) => {
|
|
40
|
+
const value = getEnv(key);
|
|
41
|
+
if (!value) return defaultValue;
|
|
42
|
+
return value.split(/[,;\n]+/).map((v) => v.trim()).filter(Boolean);
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export {
|
|
46
|
+
env,
|
|
47
|
+
getEnv,
|
|
48
|
+
getEnvBoolean,
|
|
49
|
+
getEnvArray
|
|
50
|
+
};
|