alepha 0.15.3 → 0.15.5
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/README.md +26 -11
- package/dist/api/audits/index.d.ts +335 -335
- package/dist/api/audits/index.d.ts.map +1 -1
- package/dist/api/audits/index.js +11 -3
- package/dist/api/audits/index.js.map +1 -1
- package/dist/api/files/index.d.ts +3 -3
- package/dist/api/files/index.js +4 -3
- package/dist/api/files/index.js.map +1 -1
- package/dist/api/jobs/index.d.ts +198 -155
- package/dist/api/jobs/index.d.ts.map +1 -1
- package/dist/api/jobs/index.js +103 -5
- package/dist/api/jobs/index.js.map +1 -1
- package/dist/api/keys/index.d.ts +198 -198
- package/dist/api/keys/index.d.ts.map +1 -1
- package/dist/api/keys/index.js +3 -3
- package/dist/api/keys/index.js.map +1 -1
- package/dist/api/notifications/index.browser.js +1 -0
- package/dist/api/notifications/index.browser.js.map +1 -1
- package/dist/api/notifications/index.d.ts +3 -3
- package/dist/api/notifications/index.js +4 -3
- package/dist/api/notifications/index.js.map +1 -1
- package/dist/api/parameters/index.d.ts +263 -263
- package/dist/api/parameters/index.d.ts.map +1 -1
- package/dist/api/parameters/index.js +41 -30
- package/dist/api/parameters/index.js.map +1 -1
- package/dist/api/users/index.d.ts +383 -77
- package/dist/api/users/index.d.ts.map +1 -1
- package/dist/api/users/index.js +284 -72
- package/dist/api/users/index.js.map +1 -1
- package/dist/api/verifications/index.d.ts +131 -131
- package/dist/api/verifications/index.d.ts.map +1 -1
- package/dist/api/verifications/index.js +3 -3
- package/dist/api/verifications/index.js.map +1 -1
- package/dist/batch/index.d.ts +3 -3
- package/dist/batch/index.js +3 -3
- package/dist/batch/index.js.map +1 -1
- package/dist/bucket/index.d.ts +3 -3
- package/dist/bucket/index.js +6 -6
- package/dist/bucket/index.js.map +1 -1
- package/dist/cache/core/index.d.ts +3 -3
- package/dist/cache/core/index.js +3 -3
- package/dist/cache/core/index.js.map +1 -1
- package/dist/cli/index.d.ts +5612 -20
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +122 -91
- package/dist/cli/index.js.map +1 -1
- package/dist/command/index.d.ts +11 -4
- package/dist/command/index.d.ts.map +1 -1
- package/dist/command/index.js +8 -6
- package/dist/command/index.js.map +1 -1
- package/dist/core/index.browser.js.map +1 -1
- package/dist/core/index.d.ts +4 -8
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +3 -3
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.native.js.map +1 -1
- package/dist/datetime/index.d.ts +3 -3
- package/dist/datetime/index.js +3 -3
- package/dist/datetime/index.js.map +1 -1
- package/dist/email/index.d.ts +16 -16
- package/dist/email/index.d.ts.map +1 -1
- package/dist/email/index.js +10562 -10
- package/dist/email/index.js.map +1 -1
- package/dist/fake/index.d.ts +3 -3
- package/dist/fake/index.js +3 -3
- package/dist/fake/index.js.map +1 -1
- package/dist/lock/core/index.d.ts +9 -4
- package/dist/lock/core/index.d.ts.map +1 -1
- package/dist/lock/core/index.js +12 -4
- package/dist/lock/core/index.js.map +1 -1
- package/dist/logger/index.d.ts +3 -3
- package/dist/logger/index.js +6 -3
- package/dist/logger/index.js.map +1 -1
- package/dist/mcp/index.d.ts +3 -3
- package/dist/mcp/index.js +3 -3
- package/dist/mcp/index.js.map +1 -1
- package/dist/orm/index.d.ts +12 -12
- package/dist/orm/index.js +4 -4
- package/dist/orm/index.js.map +1 -1
- package/dist/queue/core/index.d.ts +3 -3
- package/dist/queue/core/index.js +3 -3
- package/dist/queue/core/index.js.map +1 -1
- package/dist/react/auth/index.browser.js +2 -1
- package/dist/react/auth/index.browser.js.map +1 -1
- package/dist/react/auth/index.d.ts +3 -3
- package/dist/react/auth/index.js +5 -4
- package/dist/react/auth/index.js.map +1 -1
- package/dist/react/core/index.d.ts +6 -6
- package/dist/react/core/index.js +3 -3
- package/dist/react/core/index.js.map +1 -1
- package/dist/react/form/index.d.ts +3 -3
- package/dist/react/form/index.js +3 -3
- package/dist/react/form/index.js.map +1 -1
- package/dist/react/head/index.d.ts +3 -3
- package/dist/react/head/index.js +3 -3
- package/dist/react/head/index.js.map +1 -1
- package/dist/react/i18n/index.d.ts +3 -3
- package/dist/react/i18n/index.js +3 -3
- package/dist/react/i18n/index.js.map +1 -1
- package/dist/react/intro/index.css +337 -0
- package/dist/react/intro/index.css.map +1 -0
- package/dist/react/intro/index.d.ts +10 -0
- package/dist/react/intro/index.d.ts.map +1 -0
- package/dist/react/intro/index.js +222 -0
- package/dist/react/intro/index.js.map +1 -0
- package/dist/react/router/index.browser.js +2 -2
- package/dist/react/router/index.browser.js.map +1 -1
- package/dist/react/router/index.d.ts +11 -1
- package/dist/react/router/index.d.ts.map +1 -1
- package/dist/react/router/index.js +21 -11
- package/dist/react/router/index.js.map +1 -1
- package/dist/redis/index.d.ts +22 -22
- package/dist/redis/index.js +3 -3
- package/dist/redis/index.js.map +1 -1
- package/dist/retry/index.d.ts +3 -3
- package/dist/retry/index.js +3 -3
- package/dist/retry/index.js.map +1 -1
- package/dist/scheduler/index.d.ts +16 -4
- package/dist/scheduler/index.d.ts.map +1 -1
- package/dist/scheduler/index.js +45 -7
- package/dist/scheduler/index.js.map +1 -1
- package/dist/security/index.d.ts +3 -3
- package/dist/security/index.js +5 -5
- package/dist/security/index.js.map +1 -1
- package/dist/server/auth/index.d.ts +3 -3
- package/dist/server/auth/index.js +3 -3
- package/dist/server/auth/index.js.map +1 -1
- package/dist/server/cache/index.d.ts +3 -3
- package/dist/server/cache/index.js +3 -3
- package/dist/server/cache/index.js.map +1 -1
- package/dist/server/compress/index.d.ts +3 -3
- package/dist/server/compress/index.d.ts.map +1 -1
- package/dist/server/compress/index.js +4 -3
- package/dist/server/compress/index.js.map +1 -1
- package/dist/server/cookies/index.d.ts +3 -3
- package/dist/server/cookies/index.js +3 -3
- package/dist/server/cookies/index.js.map +1 -1
- package/dist/server/core/index.d.ts +14 -25
- package/dist/server/core/index.d.ts.map +1 -1
- package/dist/server/core/index.js +13 -29
- package/dist/server/core/index.js.map +1 -1
- package/dist/server/cors/index.d.ts +3 -3
- package/dist/server/cors/index.js +3 -3
- package/dist/server/cors/index.js.map +1 -1
- package/dist/server/health/index.d.ts +20 -20
- package/dist/server/health/index.js +3 -3
- package/dist/server/health/index.js.map +1 -1
- package/dist/server/helmet/index.d.ts +3 -3
- package/dist/server/helmet/index.js +3 -3
- package/dist/server/helmet/index.js.map +1 -1
- package/dist/server/links/index.d.ts +42 -42
- package/dist/server/links/index.d.ts.map +1 -1
- package/dist/server/links/index.js +4 -4
- package/dist/server/links/index.js.map +1 -1
- package/dist/server/metrics/index.d.ts +3 -3
- package/dist/server/metrics/index.js +3 -3
- package/dist/server/metrics/index.js.map +1 -1
- package/dist/server/multipart/index.d.ts +3 -3
- package/dist/server/multipart/index.js +3 -3
- package/dist/server/multipart/index.js.map +1 -1
- package/dist/server/proxy/index.d.ts +3 -3
- package/dist/server/proxy/index.js +3 -3
- package/dist/server/proxy/index.js.map +1 -1
- package/dist/server/rate-limit/index.d.ts +3 -3
- package/dist/server/rate-limit/index.js +3 -3
- package/dist/server/rate-limit/index.js.map +1 -1
- package/dist/server/static/index.d.ts +3 -3
- package/dist/server/static/index.js +6 -6
- package/dist/server/static/index.js.map +1 -1
- package/dist/server/swagger/index.d.ts +3 -3
- package/dist/server/swagger/index.js +6 -6
- package/dist/server/swagger/index.js.map +1 -1
- package/dist/sms/index.d.ts +3 -3
- package/dist/sms/index.js +6 -6
- package/dist/sms/index.js.map +1 -1
- package/dist/system/index.d.ts +3 -3
- package/dist/system/index.js +3 -3
- package/dist/system/index.js.map +1 -1
- package/dist/thread/index.d.ts +3 -3
- package/dist/thread/index.js +3 -3
- package/dist/thread/index.js.map +1 -1
- package/dist/topic/core/index.d.ts +3 -3
- package/dist/topic/core/index.js +3 -3
- package/dist/topic/core/index.js.map +1 -1
- package/dist/vite/index.d.ts +6286 -4
- package/dist/vite/index.d.ts.map +1 -1
- package/dist/vite/index.js +28 -2
- package/dist/vite/index.js.map +1 -1
- package/dist/websocket/index.d.ts +37 -37
- package/dist/websocket/index.d.ts.map +1 -1
- package/dist/websocket/index.js +3 -3
- package/dist/websocket/index.js.map +1 -1
- package/package.json +12 -4
- package/src/api/audits/controllers/AdminAuditController.ts +8 -0
- package/src/api/audits/index.ts +3 -3
- package/src/api/files/controllers/AdminFileStatsController.ts +1 -0
- package/src/api/files/index.ts +3 -3
- package/src/api/jobs/controllers/AdminJobController.ts +18 -2
- package/src/api/jobs/index.ts +4 -3
- package/src/api/jobs/services/JobAudits.spec.ts +89 -0
- package/src/api/jobs/services/JobAudits.ts +101 -0
- package/src/api/keys/index.ts +3 -3
- package/src/api/notifications/controllers/AdminNotificationController.ts +1 -0
- package/src/api/notifications/index.ts +3 -3
- package/src/api/parameters/controllers/AdminConfigController.ts +10 -0
- package/src/api/parameters/index.ts +5 -3
- package/src/api/users/__tests__/ApiKeys-integration.spec.ts +1 -1
- package/src/api/users/__tests__/ApiKeys.spec.ts +1 -1
- package/src/api/users/__tests__/EmailVerification.spec.ts +16 -1
- package/src/api/users/__tests__/PasswordReset.spec.ts +11 -0
- package/src/api/users/atoms/realmAuthSettingsAtom.ts +10 -0
- package/src/api/users/controllers/AdminIdentityController.ts +3 -0
- package/src/api/users/controllers/AdminSessionController.ts +3 -0
- package/src/api/users/controllers/AdminUserController.ts +5 -0
- package/src/api/users/index.ts +8 -9
- package/src/api/users/primitives/$realm.ts +117 -19
- package/src/api/users/providers/RealmProvider.ts +15 -7
- package/src/api/users/services/CredentialService.spec.ts +11 -0
- package/src/api/users/services/CredentialService.ts +47 -24
- package/src/api/users/services/IdentityService.ts +12 -4
- package/src/api/users/services/RegistrationService.spec.ts +11 -0
- package/src/api/users/services/RegistrationService.ts +33 -12
- package/src/api/users/services/SessionService.ts +83 -12
- package/src/api/users/services/UserAudits.ts +47 -0
- package/src/api/users/services/UserFiles.ts +19 -0
- package/src/api/users/services/UserJobs.spec.ts +107 -0
- package/src/api/users/services/UserJobs.ts +62 -0
- package/src/api/users/services/UserParameters.ts +23 -0
- package/src/api/users/services/UserService.ts +34 -17
- package/src/api/verifications/index.ts +3 -3
- package/src/batch/index.ts +3 -3
- package/src/bucket/index.ts +3 -3
- package/src/cache/core/index.ts +3 -3
- package/src/cli/commands/build.ts +1 -0
- package/src/cli/commands/db.ts +9 -0
- package/src/cli/commands/init.spec.ts +2 -17
- package/src/cli/commands/init.ts +37 -1
- package/src/cli/providers/ViteDevServerProvider.ts +36 -2
- package/src/cli/services/AlephaCliUtils.ts +17 -0
- package/src/cli/services/PackageManagerUtils.ts +15 -1
- package/src/cli/services/ProjectScaffolder.ts +8 -13
- package/src/cli/templates/agentMd.ts +2 -25
- package/src/cli/templates/apiAppSecurityTs.ts +37 -2
- package/src/cli/templates/mainCss.ts +2 -32
- package/src/cli/templates/webAppRouterTs.ts +5 -5
- package/src/cli/templates/webHomeComponentTsx.ts +10 -0
- package/src/command/helpers/Runner.ts +14 -1
- package/src/command/index.ts +3 -3
- package/src/core/helpers/primitive.ts +0 -5
- package/src/core/index.ts +3 -3
- package/src/datetime/index.ts +3 -3
- package/src/email/index.ts +3 -3
- package/src/email/index.workerd.ts +36 -0
- package/src/email/providers/LocalEmailProvider.ts +2 -2
- package/src/email/providers/WorkermailerEmailProvider.ts +221 -0
- package/src/fake/index.ts +3 -3
- package/src/lock/core/index.ts +3 -3
- package/src/lock/core/primitives/$lock.ts +13 -1
- package/src/logger/index.ts +3 -3
- package/src/logger/providers/PrettyFormatterProvider.ts +7 -0
- package/src/mcp/index.ts +3 -3
- package/src/orm/index.ts +3 -3
- package/src/orm/providers/drivers/NodeSqliteProvider.ts +1 -1
- package/src/queue/core/index.ts +3 -3
- package/src/react/auth/index.ts +3 -3
- package/src/react/auth/services/ReactAuth.ts +3 -1
- package/src/react/core/index.ts +3 -3
- package/src/react/form/index.ts +3 -3
- package/src/react/head/index.ts +3 -3
- package/src/react/i18n/index.ts +3 -3
- package/src/react/intro/components/GettingStarted.css +334 -0
- package/src/react/intro/components/GettingStarted.tsx +276 -0
- package/src/react/intro/index.ts +1 -0
- package/src/react/router/atoms/ssrManifestAtom.ts +7 -0
- package/src/react/router/index.browser.ts +2 -0
- package/src/react/router/index.ts +2 -0
- package/src/react/router/providers/ReactServerProvider.ts +14 -4
- package/src/react/router/providers/SSRManifestProvider.ts +7 -0
- package/src/redis/index.ts +3 -3
- package/src/retry/index.ts +3 -3
- package/src/router/index.ts +3 -3
- package/src/scheduler/index.ts +3 -3
- package/src/scheduler/index.workerd.ts +43 -0
- package/src/scheduler/providers/CronProvider.ts +53 -6
- package/src/scheduler/providers/WorkerdCronProvider.ts +102 -0
- package/src/security/index.ts +3 -3
- package/src/security/providers/JwtProvider.ts +2 -2
- package/src/server/auth/index.ts +3 -3
- package/src/server/cache/index.ts +3 -3
- package/src/server/compress/index.ts +3 -3
- package/src/server/compress/providers/ServerCompressProvider.ts +6 -0
- package/src/server/cookies/index.ts +3 -3
- package/src/server/core/index.ts +3 -3
- package/src/server/core/primitives/$action.spec.ts +3 -2
- package/src/server/core/primitives/$action.ts +6 -2
- package/src/server/core/providers/NodeHttpServerProvider.ts +2 -15
- package/src/server/core/providers/ServerProvider.ts +4 -2
- package/src/server/core/providers/ServerRouterProvider.ts +5 -27
- package/src/server/cors/index.ts +3 -3
- package/src/server/health/index.ts +3 -3
- package/src/server/helmet/index.ts +3 -3
- package/src/server/links/index.ts +3 -3
- package/src/server/links/providers/ServerLinksProvider.spec.ts +332 -0
- package/src/server/links/providers/ServerLinksProvider.ts +1 -1
- package/src/server/metrics/index.ts +3 -3
- package/src/server/multipart/index.ts +3 -3
- package/src/server/proxy/index.ts +3 -3
- package/src/server/rate-limit/index.ts +3 -3
- package/src/server/static/index.ts +3 -3
- package/src/server/swagger/index.ts +3 -3
- package/src/sms/index.ts +3 -3
- package/src/system/index.ts +3 -3
- package/src/thread/index.ts +3 -3
- package/src/topic/core/index.ts +3 -3
- package/src/vite/tasks/generateCloudflare.ts +38 -2
- package/src/websocket/index.ts +3 -3
- package/src/cli/templates/webHelloComponentTsx.ts +0 -30
- /package/src/api/users/{notifications → services}/UserNotifications.ts +0 -0
|
@@ -46,11 +46,11 @@ export class LocalEmailProvider implements EmailProvider {
|
|
|
46
46
|
try {
|
|
47
47
|
await this.fs.mkdir(this.directory, { recursive: true });
|
|
48
48
|
this.log.info("Email directory OK", {
|
|
49
|
-
|
|
49
|
+
at: this.directory,
|
|
50
50
|
});
|
|
51
51
|
} catch (error) {
|
|
52
52
|
const message = `Failed to create email directory: ${error instanceof Error ? error.message : String(error)}`;
|
|
53
|
-
this.log.error(message, {
|
|
53
|
+
this.log.error(message, { at: this.directory });
|
|
54
54
|
throw new EmailError(
|
|
55
55
|
message,
|
|
56
56
|
error instanceof Error ? error : undefined,
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
import { $atom, $env, $use, type Static, t } from "alepha";
|
|
2
|
+
import { $logger } from "alepha/logger";
|
|
3
|
+
import { WorkerMailer } from "worker-mailer";
|
|
4
|
+
import { EmailError } from "../errors/EmailError.ts";
|
|
5
|
+
import type { EmailProvider, EmailSendOptions } from "./EmailProvider.ts";
|
|
6
|
+
|
|
7
|
+
// ---------------------------------------------------------------------------------------------------------------------
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Environment variables for worker-mailer configuration
|
|
11
|
+
*/
|
|
12
|
+
const envSchema = t.object({
|
|
13
|
+
EMAIL_HOST: t.optional(
|
|
14
|
+
t.text({
|
|
15
|
+
description: "SMTP server host",
|
|
16
|
+
}),
|
|
17
|
+
),
|
|
18
|
+
EMAIL_PORT: t.number({
|
|
19
|
+
default: 587,
|
|
20
|
+
description: "SMTP server port (465 or 587, not 25)",
|
|
21
|
+
}),
|
|
22
|
+
EMAIL_USER: t.optional(
|
|
23
|
+
t.text({
|
|
24
|
+
description: "SMTP authentication username",
|
|
25
|
+
}),
|
|
26
|
+
),
|
|
27
|
+
EMAIL_PASS: t.optional(
|
|
28
|
+
t.text({
|
|
29
|
+
description: "SMTP authentication password",
|
|
30
|
+
}),
|
|
31
|
+
),
|
|
32
|
+
EMAIL_FROM: t.optional(
|
|
33
|
+
t.text({
|
|
34
|
+
description: "Default from email address",
|
|
35
|
+
}),
|
|
36
|
+
),
|
|
37
|
+
EMAIL_FROM_NAME: t.optional(
|
|
38
|
+
t.text({
|
|
39
|
+
description: "Default from name",
|
|
40
|
+
}),
|
|
41
|
+
),
|
|
42
|
+
EMAIL_SECURE: t.boolean({
|
|
43
|
+
default: true,
|
|
44
|
+
description: "Use secure connection (TLS/STARTTLS)",
|
|
45
|
+
}),
|
|
46
|
+
EMAIL_AUTH_TYPE: t.optional(
|
|
47
|
+
t.enum(["plain", "login", "cram-md5"], {
|
|
48
|
+
default: "plain",
|
|
49
|
+
description: "SMTP authentication type",
|
|
50
|
+
}),
|
|
51
|
+
),
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
// ---------------------------------------------------------------------------------------------------------------------
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Worker-mailer specific options
|
|
58
|
+
*/
|
|
59
|
+
export const workermailerEmailOptions = $atom({
|
|
60
|
+
name: "alepha.email.workermailer.options",
|
|
61
|
+
schema: t.object({
|
|
62
|
+
authType: t.optional(
|
|
63
|
+
t.enum(["plain", "login", "cram-md5"], {
|
|
64
|
+
description: "SMTP authentication type (default: plain)",
|
|
65
|
+
}),
|
|
66
|
+
),
|
|
67
|
+
}),
|
|
68
|
+
default: {},
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
export type WorkermailerEmailProviderOptions = Static<
|
|
72
|
+
typeof workermailerEmailOptions.schema
|
|
73
|
+
>;
|
|
74
|
+
|
|
75
|
+
declare module "alepha" {
|
|
76
|
+
interface State {
|
|
77
|
+
[workermailerEmailOptions.key]: WorkermailerEmailProviderOptions;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// ---------------------------------------------------------------------------------------------------------------------
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* Email provider using worker-mailer for Cloudflare Workers.
|
|
85
|
+
*
|
|
86
|
+
* This provider uses Cloudflare's TCP Sockets API to send emails via SMTP,
|
|
87
|
+
* making it suitable for edge runtime environments.
|
|
88
|
+
*
|
|
89
|
+
* Configuration is provided via environment variables:
|
|
90
|
+
* - EMAIL_HOST: SMTP server host
|
|
91
|
+
* - EMAIL_PORT: SMTP server port (default: 587, note: port 25 is blocked)
|
|
92
|
+
* - EMAIL_USER: SMTP authentication username
|
|
93
|
+
* - EMAIL_PASS: SMTP authentication password
|
|
94
|
+
* - EMAIL_FROM: Default from email address
|
|
95
|
+
* - EMAIL_FROM_NAME: Default from name (optional)
|
|
96
|
+
* - EMAIL_SECURE: Use secure connection (default: true)
|
|
97
|
+
* - EMAIL_AUTH_TYPE: Authentication type - plain, login, or cram-md5 (default: plain)
|
|
98
|
+
*
|
|
99
|
+
* @example
|
|
100
|
+
* ```typescript
|
|
101
|
+
* // Configure via environment variables
|
|
102
|
+
* // EMAIL_HOST=smtp.example.com
|
|
103
|
+
* // EMAIL_PORT=587
|
|
104
|
+
* // EMAIL_USER=user@example.com
|
|
105
|
+
* // EMAIL_PASS=secret
|
|
106
|
+
* // EMAIL_FROM=noreply@example.com
|
|
107
|
+
* // EMAIL_FROM_NAME=My App
|
|
108
|
+
* // EMAIL_SECURE=true
|
|
109
|
+
* // EMAIL_AUTH_TYPE=plain
|
|
110
|
+
* ```
|
|
111
|
+
*
|
|
112
|
+
* @see https://github.com/zou-yu/worker-mailer
|
|
113
|
+
*/
|
|
114
|
+
export class WorkermailerEmailProvider implements EmailProvider {
|
|
115
|
+
protected readonly env = $env(envSchema);
|
|
116
|
+
protected readonly log = $logger();
|
|
117
|
+
protected readonly options = $use(workermailerEmailOptions);
|
|
118
|
+
|
|
119
|
+
protected get host(): string {
|
|
120
|
+
const host = this.env.EMAIL_HOST;
|
|
121
|
+
if (!host) {
|
|
122
|
+
throw new EmailError(
|
|
123
|
+
"Email host not configured. Set EMAIL_HOST env var.",
|
|
124
|
+
);
|
|
125
|
+
}
|
|
126
|
+
return host;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
protected get port(): number {
|
|
130
|
+
return this.env.EMAIL_PORT;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
protected get secure(): boolean {
|
|
134
|
+
return this.env.EMAIL_SECURE;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
protected get user(): string | undefined {
|
|
138
|
+
return this.env.EMAIL_USER;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
protected get pass(): string | undefined {
|
|
142
|
+
return this.env.EMAIL_PASS;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
protected get fromAddress(): string {
|
|
146
|
+
const from = this.env.EMAIL_FROM;
|
|
147
|
+
if (!from) {
|
|
148
|
+
throw new EmailError(
|
|
149
|
+
"Email from address not configured. Set EMAIL_FROM env var.",
|
|
150
|
+
);
|
|
151
|
+
}
|
|
152
|
+
return from;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
protected get fromName(): string | undefined {
|
|
156
|
+
return this.env.EMAIL_FROM_NAME;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
protected get authType(): "plain" | "login" | "cram-md5" {
|
|
160
|
+
return this.options.authType ?? this.env.EMAIL_AUTH_TYPE ?? "plain";
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
public async send(options: EmailSendOptions): Promise<void> {
|
|
164
|
+
const { to, subject, body } = options;
|
|
165
|
+
this.log.debug("Sending email via worker-mailer", { to, subject });
|
|
166
|
+
|
|
167
|
+
const user = this.user;
|
|
168
|
+
const pass = this.pass;
|
|
169
|
+
|
|
170
|
+
if (!user || !pass) {
|
|
171
|
+
throw new EmailError(
|
|
172
|
+
"Email credentials not configured. Set EMAIL_USER and EMAIL_PASS env vars.",
|
|
173
|
+
);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
let mailer: WorkerMailer | undefined;
|
|
177
|
+
|
|
178
|
+
try {
|
|
179
|
+
mailer = await WorkerMailer.connect({
|
|
180
|
+
credentials: {
|
|
181
|
+
username: user,
|
|
182
|
+
password: pass,
|
|
183
|
+
},
|
|
184
|
+
authType: this.authType,
|
|
185
|
+
host: this.host,
|
|
186
|
+
port: this.port,
|
|
187
|
+
secure: this.secure,
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
const recipients = Array.isArray(to) ? to : [to];
|
|
191
|
+
|
|
192
|
+
for (const recipient of recipients) {
|
|
193
|
+
await mailer.send({
|
|
194
|
+
from: this.fromName
|
|
195
|
+
? { name: this.fromName, email: this.fromAddress }
|
|
196
|
+
: { email: this.fromAddress },
|
|
197
|
+
to: { email: recipient },
|
|
198
|
+
subject,
|
|
199
|
+
html: body,
|
|
200
|
+
});
|
|
201
|
+
|
|
202
|
+
this.log.info("Email sent successfully", {
|
|
203
|
+
to: recipient,
|
|
204
|
+
subject,
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
} catch (error) {
|
|
208
|
+
const message = `Failed to send email via worker-mailer: ${error instanceof Error ? error.message : String(error)}`;
|
|
209
|
+
this.log.error(message, { to, subject });
|
|
210
|
+
throw new EmailError(message, error instanceof Error ? error : undefined);
|
|
211
|
+
} finally {
|
|
212
|
+
if (mailer) {
|
|
213
|
+
try {
|
|
214
|
+
await mailer.close();
|
|
215
|
+
} catch {
|
|
216
|
+
// Ignore close errors
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
package/src/fake/index.ts
CHANGED
|
@@ -9,9 +9,9 @@ export * from "./providers/FakeProvider.ts";
|
|
|
9
9
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
10
10
|
|
|
11
11
|
/**
|
|
12
|
-
* |
|
|
13
|
-
*
|
|
14
|
-
* |
|
|
12
|
+
* | Stability | Since | Runtime |
|
|
13
|
+
* |-----------|-------|---------|
|
|
14
|
+
* | 3 - stable | 0.11.0 | node, bun, workerd, browser|
|
|
15
15
|
*
|
|
16
16
|
* Test data generation with Faker.js.
|
|
17
17
|
*
|
package/src/lock/core/index.ts
CHANGED
|
@@ -15,9 +15,9 @@ export * from "./providers/MemoryLockProvider.ts";
|
|
|
15
15
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
16
16
|
|
|
17
17
|
/**
|
|
18
|
-
* |
|
|
19
|
-
*
|
|
20
|
-
* |
|
|
18
|
+
* | Stability | Since | Runtime |
|
|
19
|
+
* |-----------|-------|---------|
|
|
20
|
+
* | 3 - stable | 0.8.0 | node, bun, workerd|
|
|
21
21
|
*
|
|
22
22
|
* Resource locking for distributed systems.
|
|
23
23
|
*
|
|
@@ -302,7 +302,19 @@ export class LockPrimitive<TFunc extends AsyncFn> extends Primitive<
|
|
|
302
302
|
protected readonly provider = $inject(LockProvider);
|
|
303
303
|
protected readonly env = $env(envSchema);
|
|
304
304
|
protected readonly dateTimeProvider = $inject(DateTimeProvider);
|
|
305
|
-
|
|
305
|
+
|
|
306
|
+
/**
|
|
307
|
+
* Lazy-initialized UUID to avoid calling crypto.randomUUID() in global scope.
|
|
308
|
+
* Cloudflare Workers doesn't allow random value generation during initialization.
|
|
309
|
+
*/
|
|
310
|
+
protected _id?: string;
|
|
311
|
+
protected get id(): string {
|
|
312
|
+
if (!this._id) {
|
|
313
|
+
this._id = crypto.randomUUID();
|
|
314
|
+
}
|
|
315
|
+
return this._id;
|
|
316
|
+
}
|
|
317
|
+
|
|
306
318
|
public readonly maxDuration = this.dateTimeProvider.duration(
|
|
307
319
|
this.options.maxDuration ?? [5, "minutes"],
|
|
308
320
|
);
|
package/src/logger/index.ts
CHANGED
|
@@ -27,9 +27,9 @@ export * from "./services/Logger.ts";
|
|
|
27
27
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
28
28
|
|
|
29
29
|
/**
|
|
30
|
-
* |
|
|
31
|
-
*
|
|
32
|
-
* |
|
|
30
|
+
* | Stability | Since | Runtime |
|
|
31
|
+
* |-----------|-------|---------|
|
|
32
|
+
* | 3 - stable | 0.5.0 | node, bun, workerd, browser, expo|
|
|
33
33
|
*
|
|
34
34
|
* Configurable logging with multiple outputs.
|
|
35
35
|
*
|
|
@@ -107,10 +107,17 @@ export class PrettyFormatterProvider extends LogFormatterProvider {
|
|
|
107
107
|
return "";
|
|
108
108
|
}
|
|
109
109
|
|
|
110
|
+
// hack: use vite's stack trace formatter if available
|
|
111
|
+
const vite = this.alepha.store.get("alepha.vite.server" as any);
|
|
112
|
+
|
|
113
|
+
vite?.ssrFixStacktrace(error);
|
|
114
|
+
|
|
110
115
|
let str = error.stack ?? error.message;
|
|
111
116
|
|
|
112
117
|
const anyError = error as any;
|
|
113
118
|
while (anyError.cause && anyError.cause instanceof Error) {
|
|
119
|
+
vite?.ssrFixStacktrace(anyError.cause);
|
|
120
|
+
|
|
114
121
|
str += `\nCaused by: ${anyError.cause.stack ?? anyError.cause.message}`;
|
|
115
122
|
anyError.cause = anyError.cause.cause;
|
|
116
123
|
}
|
package/src/mcp/index.ts
CHANGED
|
@@ -93,9 +93,9 @@ export { StdioMcpTransport } from "./transports/StdioMcpTransport.ts";
|
|
|
93
93
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
94
94
|
|
|
95
95
|
/**
|
|
96
|
-
* |
|
|
97
|
-
*
|
|
98
|
-
* |
|
|
96
|
+
* | Stability | Since | Runtime |
|
|
97
|
+
* |-----------|-------|---------|
|
|
98
|
+
* | 3 - stable | 0.18.0 | node, bun|
|
|
99
99
|
*
|
|
100
100
|
* Model Context Protocol for AI tool integration.
|
|
101
101
|
*
|
package/src/orm/index.ts
CHANGED
|
@@ -99,9 +99,9 @@ export const SqliteProvider = NodeSqliteProvider;
|
|
|
99
99
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
100
100
|
|
|
101
101
|
/**
|
|
102
|
-
* |
|
|
103
|
-
*
|
|
104
|
-
* |
|
|
102
|
+
* | Stability | Since | Runtime |
|
|
103
|
+
* |-----------|-------|---------|
|
|
104
|
+
* | 3 - stable | 0.1.0 | node, bun, workerd|
|
|
105
105
|
*
|
|
106
106
|
* Full-featured database abstraction built on Drizzle ORM with complete type safety.
|
|
107
107
|
*
|
package/src/queue/core/index.ts
CHANGED
|
@@ -16,9 +16,9 @@ export * from "./providers/WorkerProvider.ts";
|
|
|
16
16
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
17
17
|
|
|
18
18
|
/**
|
|
19
|
-
* |
|
|
20
|
-
*
|
|
21
|
-
* |
|
|
19
|
+
* | Stability | Since | Runtime |
|
|
20
|
+
* |-----------|-------|---------|
|
|
21
|
+
* | 3 - stable | 0.6.0 | node, bun|
|
|
22
22
|
*
|
|
23
23
|
* Asynchronous message processing with automatic worker management.
|
|
24
24
|
*
|
package/src/react/auth/index.ts
CHANGED
|
@@ -22,9 +22,9 @@ declare module "alepha/react/router" {
|
|
|
22
22
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
23
23
|
|
|
24
24
|
/**
|
|
25
|
-
* |
|
|
26
|
-
*
|
|
27
|
-
* |
|
|
25
|
+
* | Stability | Since | Runtime |
|
|
26
|
+
* |-----------|-------|---------|
|
|
27
|
+
* | 3 - stable | 0.8.0 | node, bun, browser|
|
|
28
28
|
*
|
|
29
29
|
* Auth-related React components and hooks.
|
|
30
30
|
*
|
|
@@ -130,6 +130,8 @@ export class ReactAuth {
|
|
|
130
130
|
}
|
|
131
131
|
|
|
132
132
|
public logout() {
|
|
133
|
-
|
|
133
|
+
// Add cache-busting parameter to prevent browser from using cached redirect
|
|
134
|
+
const cacheBuster = Date.now();
|
|
135
|
+
window.location.href = `${alephaServerAuthRoutes.logout}?post_logout_redirect_uri=${encodeURIComponent(window.location.origin)}&_=${cacheBuster}`;
|
|
134
136
|
}
|
|
135
137
|
}
|
package/src/react/core/index.ts
CHANGED
|
@@ -58,9 +58,9 @@ declare module "alepha" {
|
|
|
58
58
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
59
59
|
|
|
60
60
|
/**
|
|
61
|
-
* |
|
|
62
|
-
*
|
|
63
|
-
* |
|
|
61
|
+
* | Stability | Since | Runtime |
|
|
62
|
+
* |-----------|-------|---------|
|
|
63
|
+
* | 3 - stable | 0.2.0 | node, bun, workerd, browser, expo|
|
|
64
64
|
*
|
|
65
65
|
* Full-stack React framework with server-side rendering.
|
|
66
66
|
*
|
package/src/react/form/index.ts
CHANGED
|
@@ -24,9 +24,9 @@ declare module "alepha" {
|
|
|
24
24
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
25
25
|
|
|
26
26
|
/**
|
|
27
|
-
* |
|
|
28
|
-
*
|
|
29
|
-
* |
|
|
27
|
+
* | Stability | Since | Runtime |
|
|
28
|
+
* |-----------|-------|---------|
|
|
29
|
+
* | 3 - stable | 0.12.0 | node, bun, workerd, browser|
|
|
30
30
|
*
|
|
31
31
|
* Type-safe forms with validation.
|
|
32
32
|
*
|
package/src/react/head/index.ts
CHANGED
|
@@ -18,9 +18,9 @@ export * from "./providers/ServerHeadProvider.ts";
|
|
|
18
18
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
19
19
|
|
|
20
20
|
/**
|
|
21
|
-
* |
|
|
22
|
-
*
|
|
23
|
-
* |
|
|
21
|
+
* | Stability | Since | Runtime |
|
|
22
|
+
* |-----------|-------|---------|
|
|
23
|
+
* | 3 - stable | 0.4.0 | node, bun, browser|
|
|
24
24
|
*
|
|
25
25
|
* HTML head element management.
|
|
26
26
|
*
|
package/src/react/i18n/index.ts
CHANGED
|
@@ -21,9 +21,9 @@ declare module "alepha" {
|
|
|
21
21
|
// ---------------------------------------------------------------------------------------------------------------------
|
|
22
22
|
|
|
23
23
|
/**
|
|
24
|
-
* |
|
|
25
|
-
*
|
|
26
|
-
* |
|
|
24
|
+
* | Stability | Since | Runtime |
|
|
25
|
+
* |-----------|-------|---------|
|
|
26
|
+
* | 3 - stable | 0.10.0 | node, bun, workerd, browser|
|
|
27
27
|
*
|
|
28
28
|
* Multi-language support.
|
|
29
29
|
*
|