alepha 0.14.1 → 0.14.2
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 +3 -3
- package/dist/api/audits/index.d.ts +342 -342
- package/dist/api/audits/index.d.ts.map +1 -1
- package/dist/api/audits/index.js.map +1 -1
- package/dist/api/files/index.js.map +1 -1
- package/dist/api/jobs/index.d.ts +161 -161
- package/dist/api/jobs/index.js.map +1 -1
- package/dist/api/parameters/index.js.map +1 -1
- package/dist/api/users/index.d.ts +791 -791
- package/dist/api/users/index.d.ts.map +1 -1
- package/dist/api/users/index.js +4 -0
- package/dist/api/users/index.js.map +1 -1
- package/dist/api/verifications/index.d.ts +128 -128
- package/dist/api/verifications/index.d.ts.map +1 -1
- package/dist/batch/index.js.map +1 -1
- package/dist/cache/core/index.js.map +1 -1
- package/dist/cli/index.d.ts +173 -167
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +427 -409
- package/dist/cli/index.js.map +1 -1
- package/dist/command/index.d.ts +5 -5
- package/dist/command/index.js.map +1 -1
- package/dist/core/index.browser.js.map +1 -1
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +7 -6
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.native.js +7 -6
- package/dist/core/index.native.js.map +1 -1
- package/dist/datetime/index.js.map +1 -1
- package/dist/fake/index.js.map +1 -1
- package/dist/file/index.js.map +1 -1
- package/dist/lock/redis/index.js.map +1 -1
- package/dist/logger/index.js.map +1 -1
- package/dist/mcp/index.js.map +1 -1
- package/dist/orm/index.browser.js +26 -5
- package/dist/orm/index.browser.js.map +1 -1
- package/dist/orm/index.d.ts +115 -90
- package/dist/orm/index.d.ts.map +1 -1
- package/dist/orm/index.js +37 -12
- package/dist/orm/index.js.map +1 -1
- package/dist/redis/index.js.map +1 -1
- package/dist/retry/index.js.map +1 -1
- package/dist/router/index.js.map +1 -1
- package/dist/scheduler/index.d.ts +6 -6
- package/dist/scheduler/index.js.map +1 -1
- package/dist/security/index.d.ts +28 -28
- package/dist/security/index.d.ts.map +1 -1
- package/dist/security/index.js.map +1 -1
- package/dist/server/auth/index.d.ts +155 -155
- package/dist/server/auth/index.js.map +1 -1
- package/dist/server/cache/index.js.map +1 -1
- package/dist/server/cookies/index.browser.js.map +1 -1
- package/dist/server/cookies/index.js.map +1 -1
- package/dist/server/core/index.browser.js.map +1 -1
- package/dist/server/core/index.js.map +1 -1
- package/dist/server/health/index.d.ts +17 -17
- package/dist/server/helmet/index.js.map +1 -1
- package/dist/server/links/index.browser.js.map +1 -1
- package/dist/server/links/index.js.map +1 -1
- package/dist/server/multipart/index.js.map +1 -1
- package/dist/server/rate-limit/index.js.map +1 -1
- package/dist/server/security/index.d.ts +9 -9
- package/dist/server/security/index.js.map +1 -1
- package/dist/server/swagger/index.js.map +1 -1
- package/dist/thread/index.js.map +1 -1
- package/dist/topic/core/index.js.map +1 -1
- package/dist/vite/index.js.map +1 -1
- package/dist/websocket/index.browser.js.map +1 -1
- package/dist/websocket/index.d.ts +7 -7
- package/dist/websocket/index.js.map +1 -1
- package/package.json +3 -3
- package/src/api/users/index.ts +4 -0
- package/src/cli/apps/AlephaCli.ts +31 -14
- package/src/cli/apps/AlephaPackageBuilderCli.ts +2 -1
- package/src/cli/assets/appRouterTs.ts +1 -1
- package/src/cli/commands/{ViteCommands.ts → build.ts} +2 -105
- package/src/cli/commands/{ChangelogCommands.ts → changelog.ts} +7 -22
- package/src/cli/commands/clean.ts +14 -0
- package/src/cli/commands/{DrizzleCommands.ts → db.ts} +10 -117
- package/src/cli/commands/{DeployCommands.ts → deploy.ts} +1 -1
- package/src/cli/commands/dev.ts +57 -0
- package/src/cli/commands/format.ts +17 -0
- package/src/cli/commands/{CoreCommands.ts → init.ts} +2 -40
- package/src/cli/commands/lint.ts +17 -0
- package/src/cli/commands/root.ts +32 -0
- package/src/cli/commands/run.ts +24 -0
- package/src/cli/commands/test.ts +42 -0
- package/src/cli/commands/typecheck.ts +19 -0
- package/src/cli/commands/{VerifyCommands.ts → verify.ts} +1 -13
- package/src/cli/defineConfig.ts +10 -1
- package/src/cli/index.ts +16 -7
- package/src/cli/services/GitMessageParser.ts +1 -1
- package/src/core/Alepha.ts +7 -4
- package/src/orm/index.browser.ts +1 -1
- package/src/orm/index.ts +10 -6
- package/src/orm/providers/{PostgresTypeProvider.ts → DatabaseTypeProvider.ts} +25 -3
- package/src/cli/commands/BiomeCommands.ts +0 -29
package/dist/api/jobs/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as alepha226 from "alepha";
|
|
2
2
|
import { Alepha, Async, KIND, Primitive, Static, TNull, TObject, TOptional, TSchema, TUnion } from "alepha";
|
|
3
3
|
import * as alepha_server0 from "alepha/server";
|
|
4
4
|
import * as alepha_orm0 from "alepha/orm";
|
|
@@ -238,7 +238,7 @@ type PgAttr<T extends TSchema, TAttr extends PgSymbolKeys> = T & { [K in TAttr]:
|
|
|
238
238
|
declare module "alepha" {
|
|
239
239
|
interface Env extends Partial<Static<typeof envSchema$2>> {}
|
|
240
240
|
}
|
|
241
|
-
declare const envSchema$2:
|
|
241
|
+
declare const envSchema$2: alepha226.TObject<{
|
|
242
242
|
/**
|
|
243
243
|
* Main configuration for database connection.
|
|
244
244
|
* Accept a string in the format of a Postgres connection URL.
|
|
@@ -246,11 +246,11 @@ declare const envSchema$2: alepha224.TObject<{
|
|
|
246
246
|
* or
|
|
247
247
|
* Example: postgres://user:password@localhost:5432/database?sslmode=require
|
|
248
248
|
*/
|
|
249
|
-
DATABASE_URL:
|
|
249
|
+
DATABASE_URL: alepha226.TOptional<alepha226.TString>;
|
|
250
250
|
/**
|
|
251
251
|
* In addition to the DATABASE_URL, you can specify the postgres schema name.
|
|
252
252
|
*/
|
|
253
|
-
POSTGRES_SCHEMA:
|
|
253
|
+
POSTGRES_SCHEMA: alepha226.TOptional<alepha226.TString>;
|
|
254
254
|
}>;
|
|
255
255
|
/**
|
|
256
256
|
* Bun PostgreSQL provider using Drizzle ORM with Bun's native SQL client.
|
|
@@ -275,8 +275,8 @@ declare const envSchema$2: alepha224.TObject<{
|
|
|
275
275
|
/**
|
|
276
276
|
* Configuration options for the Bun SQLite database provider.
|
|
277
277
|
*/
|
|
278
|
-
declare const bunSqliteOptions:
|
|
279
|
-
path:
|
|
278
|
+
declare const bunSqliteOptions: alepha226.Atom<alepha226.TObject<{
|
|
279
|
+
path: alepha226.TOptional<alepha226.TString>;
|
|
280
280
|
}>, "alepha.postgres.bun-sqlite.options">;
|
|
281
281
|
type BunSqliteProviderOptions = Static<typeof bunSqliteOptions.schema>;
|
|
282
282
|
declare module "alepha" {
|
|
@@ -313,7 +313,7 @@ declare module "alepha" {
|
|
|
313
313
|
declare module "alepha" {
|
|
314
314
|
interface Env extends Partial<Static<typeof envSchema$1>> {}
|
|
315
315
|
}
|
|
316
|
-
declare const envSchema$1:
|
|
316
|
+
declare const envSchema$1: alepha226.TObject<{
|
|
317
317
|
/**
|
|
318
318
|
* Main configuration for database connection.
|
|
319
319
|
* Accept a string in the format of a Postgres connection URL.
|
|
@@ -321,21 +321,21 @@ declare const envSchema$1: alepha224.TObject<{
|
|
|
321
321
|
* or
|
|
322
322
|
* Example: postgres://user:password@localhost:5432/database?sslmode=require
|
|
323
323
|
*/
|
|
324
|
-
DATABASE_URL:
|
|
324
|
+
DATABASE_URL: alepha226.TOptional<alepha226.TString>;
|
|
325
325
|
/**
|
|
326
326
|
* In addition to the DATABASE_URL, you can specify the postgres schema name.
|
|
327
327
|
*
|
|
328
328
|
* It will monkey patch drizzle tables.
|
|
329
329
|
*/
|
|
330
|
-
POSTGRES_SCHEMA:
|
|
330
|
+
POSTGRES_SCHEMA: alepha226.TOptional<alepha226.TString>;
|
|
331
331
|
}>;
|
|
332
332
|
//#endregion
|
|
333
333
|
//#region ../../src/orm/providers/drivers/NodeSqliteProvider.d.ts
|
|
334
334
|
/**
|
|
335
335
|
* Configuration options for the Node.js SQLite database provider.
|
|
336
336
|
*/
|
|
337
|
-
declare const nodeSqliteOptions:
|
|
338
|
-
path:
|
|
337
|
+
declare const nodeSqliteOptions: alepha226.Atom<alepha226.TObject<{
|
|
338
|
+
path: alepha226.TOptional<alepha226.TString>;
|
|
339
339
|
}>, "alepha.postgres.node-sqlite.options">;
|
|
340
340
|
type NodeSqliteProviderOptions = Static<typeof nodeSqliteOptions.schema>;
|
|
341
341
|
declare module "alepha" {
|
|
@@ -419,76 +419,76 @@ declare module "alepha" {
|
|
|
419
419
|
}
|
|
420
420
|
//#endregion
|
|
421
421
|
//#region ../../src/api/jobs/schemas/jobExecutionQuerySchema.d.ts
|
|
422
|
-
declare const jobExecutionQuerySchema:
|
|
423
|
-
page:
|
|
424
|
-
size:
|
|
425
|
-
sort:
|
|
426
|
-
status:
|
|
427
|
-
job:
|
|
422
|
+
declare const jobExecutionQuerySchema: alepha226.TObject<{
|
|
423
|
+
page: alepha226.TOptional<alepha226.TInteger>;
|
|
424
|
+
size: alepha226.TOptional<alepha226.TInteger>;
|
|
425
|
+
sort: alepha226.TOptional<alepha226.TString>;
|
|
426
|
+
status: alepha226.TOptional<alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">>;
|
|
427
|
+
job: alepha226.TOptional<alepha226.TString>;
|
|
428
428
|
}>;
|
|
429
429
|
type JobExecutionQuery = Static<typeof jobExecutionQuerySchema>;
|
|
430
430
|
//#endregion
|
|
431
431
|
//#region ../../src/api/jobs/services/JobService.d.ts
|
|
432
432
|
declare class JobService {
|
|
433
433
|
protected readonly alepha: Alepha;
|
|
434
|
-
protected readonly executionRepository: alepha_orm0.Repository<
|
|
435
|
-
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
436
|
-
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
437
|
-
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
438
|
-
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
439
|
-
finishedAt:
|
|
440
|
-
job:
|
|
441
|
-
status:
|
|
442
|
-
error:
|
|
443
|
-
logs:
|
|
444
|
-
level:
|
|
445
|
-
message:
|
|
446
|
-
service:
|
|
447
|
-
module:
|
|
448
|
-
context:
|
|
449
|
-
app:
|
|
450
|
-
data:
|
|
451
|
-
timestamp:
|
|
434
|
+
protected readonly executionRepository: alepha_orm0.Repository<alepha226.TObject<{
|
|
435
|
+
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_PRIMARY_KEY>, typeof alepha_orm0.PG_DEFAULT>;
|
|
436
|
+
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TInteger, typeof alepha_orm0.PG_VERSION>, typeof alepha_orm0.PG_DEFAULT>;
|
|
437
|
+
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_CREATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
438
|
+
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_UPDATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
439
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
440
|
+
job: alepha226.TString;
|
|
441
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
442
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
443
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
444
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
445
|
+
message: alepha226.TString;
|
|
446
|
+
service: alepha226.TString;
|
|
447
|
+
module: alepha226.TString;
|
|
448
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
449
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
450
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
451
|
+
timestamp: alepha226.TNumber;
|
|
452
452
|
}>>>;
|
|
453
453
|
}>>;
|
|
454
454
|
getJobs(): Promise<string[]>;
|
|
455
|
-
getJobExecutions(query?: JobExecutionQuery): Promise<
|
|
456
|
-
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
457
|
-
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
458
|
-
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
459
|
-
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
460
|
-
finishedAt:
|
|
461
|
-
job:
|
|
462
|
-
status:
|
|
463
|
-
error:
|
|
464
|
-
logs:
|
|
465
|
-
level:
|
|
466
|
-
message:
|
|
467
|
-
service:
|
|
468
|
-
module:
|
|
469
|
-
context:
|
|
470
|
-
app:
|
|
471
|
-
data:
|
|
472
|
-
timestamp:
|
|
455
|
+
getJobExecutions(query?: JobExecutionQuery): Promise<alepha226.Page<alepha_orm0.PgStatic<alepha226.TObject<{
|
|
456
|
+
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_PRIMARY_KEY>, typeof alepha_orm0.PG_DEFAULT>;
|
|
457
|
+
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TInteger, typeof alepha_orm0.PG_VERSION>, typeof alepha_orm0.PG_DEFAULT>;
|
|
458
|
+
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_CREATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
459
|
+
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_UPDATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
460
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
461
|
+
job: alepha226.TString;
|
|
462
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
463
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
464
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
465
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
466
|
+
message: alepha226.TString;
|
|
467
|
+
service: alepha226.TString;
|
|
468
|
+
module: alepha226.TString;
|
|
469
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
470
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
471
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
472
|
+
timestamp: alepha226.TNumber;
|
|
473
473
|
}>>>;
|
|
474
|
-
}>, alepha_orm0.PgRelationMap<
|
|
475
|
-
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
476
|
-
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
477
|
-
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
478
|
-
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
479
|
-
finishedAt:
|
|
480
|
-
job:
|
|
481
|
-
status:
|
|
482
|
-
error:
|
|
483
|
-
logs:
|
|
484
|
-
level:
|
|
485
|
-
message:
|
|
486
|
-
service:
|
|
487
|
-
module:
|
|
488
|
-
context:
|
|
489
|
-
app:
|
|
490
|
-
data:
|
|
491
|
-
timestamp:
|
|
474
|
+
}>, alepha_orm0.PgRelationMap<alepha226.TObject<{
|
|
475
|
+
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_PRIMARY_KEY>, typeof alepha_orm0.PG_DEFAULT>;
|
|
476
|
+
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TInteger, typeof alepha_orm0.PG_VERSION>, typeof alepha_orm0.PG_DEFAULT>;
|
|
477
|
+
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_CREATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
478
|
+
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_UPDATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
479
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
480
|
+
job: alepha226.TString;
|
|
481
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
482
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
483
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
484
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
485
|
+
message: alepha226.TString;
|
|
486
|
+
service: alepha226.TString;
|
|
487
|
+
module: alepha226.TString;
|
|
488
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
489
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
490
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
491
|
+
timestamp: alepha226.TNumber;
|
|
492
492
|
}>>>;
|
|
493
493
|
}>>>>>;
|
|
494
494
|
triggerJob(name: string): Promise<{
|
|
@@ -502,75 +502,75 @@ declare class JobController {
|
|
|
502
502
|
protected readonly group: string;
|
|
503
503
|
protected readonly jobService: JobService;
|
|
504
504
|
readonly getJobs: alepha_server0.ActionPrimitiveFn<{
|
|
505
|
-
response:
|
|
505
|
+
response: alepha226.TArray<alepha226.TString>;
|
|
506
506
|
}>;
|
|
507
507
|
readonly getJobExecutions: alepha_server0.ActionPrimitiveFn<{
|
|
508
|
-
query:
|
|
509
|
-
page:
|
|
510
|
-
size:
|
|
511
|
-
sort:
|
|
512
|
-
status:
|
|
513
|
-
job:
|
|
508
|
+
query: alepha226.TObject<{
|
|
509
|
+
page: alepha226.TOptional<alepha226.TInteger>;
|
|
510
|
+
size: alepha226.TOptional<alepha226.TInteger>;
|
|
511
|
+
sort: alepha226.TOptional<alepha226.TString>;
|
|
512
|
+
status: alepha226.TOptional<alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">>;
|
|
513
|
+
job: alepha226.TOptional<alepha226.TString>;
|
|
514
514
|
}>;
|
|
515
|
-
response:
|
|
516
|
-
id: PgAttr<PgAttr<
|
|
517
|
-
version: PgAttr<PgAttr<
|
|
518
|
-
createdAt: PgAttr<PgAttr<
|
|
519
|
-
updatedAt: PgAttr<PgAttr<
|
|
520
|
-
finishedAt:
|
|
521
|
-
job:
|
|
522
|
-
status:
|
|
523
|
-
error:
|
|
524
|
-
logs:
|
|
525
|
-
level:
|
|
526
|
-
message:
|
|
527
|
-
service:
|
|
528
|
-
module:
|
|
529
|
-
context:
|
|
530
|
-
app:
|
|
531
|
-
data:
|
|
532
|
-
timestamp:
|
|
515
|
+
response: alepha226.TPage<alepha226.TObject<{
|
|
516
|
+
id: PgAttr<PgAttr<alepha226.TString, typeof PG_PRIMARY_KEY>, typeof PG_DEFAULT>;
|
|
517
|
+
version: PgAttr<PgAttr<alepha226.TInteger, typeof PG_VERSION>, typeof PG_DEFAULT>;
|
|
518
|
+
createdAt: PgAttr<PgAttr<alepha226.TString, typeof PG_CREATED_AT>, typeof PG_DEFAULT>;
|
|
519
|
+
updatedAt: PgAttr<PgAttr<alepha226.TString, typeof PG_UPDATED_AT>, typeof PG_DEFAULT>;
|
|
520
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
521
|
+
job: alepha226.TString;
|
|
522
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
523
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
524
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
525
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
526
|
+
message: alepha226.TString;
|
|
527
|
+
service: alepha226.TString;
|
|
528
|
+
module: alepha226.TString;
|
|
529
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
530
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
531
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
532
|
+
timestamp: alepha226.TNumber;
|
|
533
533
|
}>>>;
|
|
534
534
|
}>>;
|
|
535
535
|
}>;
|
|
536
536
|
readonly triggerJob: alepha_server0.ActionPrimitiveFn<{
|
|
537
|
-
body:
|
|
538
|
-
name:
|
|
537
|
+
body: alepha226.TObject<{
|
|
538
|
+
name: alepha226.TString;
|
|
539
539
|
}>;
|
|
540
|
-
response:
|
|
541
|
-
ok:
|
|
542
|
-
id:
|
|
543
|
-
count:
|
|
540
|
+
response: alepha226.TObject<{
|
|
541
|
+
ok: alepha226.TBoolean;
|
|
542
|
+
id: alepha226.TOptional<alepha226.TUnion<[alepha226.TString, alepha226.TInteger]>>;
|
|
543
|
+
count: alepha226.TOptional<alepha226.TNumber>;
|
|
544
544
|
}>;
|
|
545
545
|
}>;
|
|
546
546
|
}
|
|
547
547
|
//#endregion
|
|
548
548
|
//#region ../../src/api/jobs/entities/jobExecutions.d.ts
|
|
549
|
-
declare const jobExecutions: alepha_orm0.EntityPrimitive<
|
|
550
|
-
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
551
|
-
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
552
|
-
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
553
|
-
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
554
|
-
finishedAt:
|
|
555
|
-
job:
|
|
556
|
-
status:
|
|
557
|
-
error:
|
|
558
|
-
logs:
|
|
559
|
-
level:
|
|
560
|
-
message:
|
|
561
|
-
service:
|
|
562
|
-
module:
|
|
563
|
-
context:
|
|
564
|
-
app:
|
|
565
|
-
data:
|
|
566
|
-
timestamp:
|
|
549
|
+
declare const jobExecutions: alepha_orm0.EntityPrimitive<alepha226.TObject<{
|
|
550
|
+
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_PRIMARY_KEY>, typeof alepha_orm0.PG_DEFAULT>;
|
|
551
|
+
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TInteger, typeof alepha_orm0.PG_VERSION>, typeof alepha_orm0.PG_DEFAULT>;
|
|
552
|
+
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_CREATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
553
|
+
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_UPDATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
554
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
555
|
+
job: alepha226.TString;
|
|
556
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
557
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
558
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
559
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
560
|
+
message: alepha226.TString;
|
|
561
|
+
service: alepha226.TString;
|
|
562
|
+
module: alepha226.TString;
|
|
563
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
564
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
565
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
566
|
+
timestamp: alepha226.TNumber;
|
|
567
567
|
}>>>;
|
|
568
568
|
}>>;
|
|
569
569
|
type JobExecutionEntity = Static<typeof jobExecutions.schema>;
|
|
570
570
|
//#endregion
|
|
571
571
|
//#region ../../src/api/jobs/providers/JobProvider.d.ts
|
|
572
|
-
declare const envSchema:
|
|
573
|
-
JOB_PREFIX:
|
|
572
|
+
declare const envSchema: alepha226.TObject<{
|
|
573
|
+
JOB_PREFIX: alepha226.TOptional<alepha226.TString>;
|
|
574
574
|
}>;
|
|
575
575
|
declare module "alepha" {
|
|
576
576
|
interface Env extends Partial<Static<typeof envSchema>> {}
|
|
@@ -583,24 +583,24 @@ declare class JobProvider {
|
|
|
583
583
|
protected readonly alepha: Alepha;
|
|
584
584
|
protected readonly dateTimeProvider: DateTimeProvider;
|
|
585
585
|
protected readonly cronProvider: CronProvider;
|
|
586
|
-
protected readonly executionRepository: alepha_orm0.Repository<
|
|
587
|
-
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
588
|
-
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
589
|
-
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
590
|
-
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<
|
|
591
|
-
finishedAt:
|
|
592
|
-
job:
|
|
593
|
-
status:
|
|
594
|
-
error:
|
|
595
|
-
logs:
|
|
596
|
-
level:
|
|
597
|
-
message:
|
|
598
|
-
service:
|
|
599
|
-
module:
|
|
600
|
-
context:
|
|
601
|
-
app:
|
|
602
|
-
data:
|
|
603
|
-
timestamp:
|
|
586
|
+
protected readonly executionRepository: alepha_orm0.Repository<alepha226.TObject<{
|
|
587
|
+
id: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_PRIMARY_KEY>, typeof alepha_orm0.PG_DEFAULT>;
|
|
588
|
+
version: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TInteger, typeof alepha_orm0.PG_VERSION>, typeof alepha_orm0.PG_DEFAULT>;
|
|
589
|
+
createdAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_CREATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
590
|
+
updatedAt: alepha_orm0.PgAttr<alepha_orm0.PgAttr<alepha226.TString, typeof alepha_orm0.PG_UPDATED_AT>, typeof alepha_orm0.PG_DEFAULT>;
|
|
591
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
592
|
+
job: alepha226.TString;
|
|
593
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
594
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
595
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
596
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
597
|
+
message: alepha226.TString;
|
|
598
|
+
service: alepha226.TString;
|
|
599
|
+
module: alepha226.TString;
|
|
600
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
601
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
602
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
603
|
+
timestamp: alepha226.TNumber;
|
|
604
604
|
}>>>;
|
|
605
605
|
}>>;
|
|
606
606
|
protected readonly env: {
|
|
@@ -694,31 +694,31 @@ interface JobHandlerArguments {
|
|
|
694
694
|
}
|
|
695
695
|
//#endregion
|
|
696
696
|
//#region ../../src/api/jobs/schemas/jobExecutionResourceSchema.d.ts
|
|
697
|
-
declare const jobExecutionResourceSchema:
|
|
698
|
-
id: PgAttr<PgAttr<
|
|
699
|
-
version: PgAttr<PgAttr<
|
|
700
|
-
createdAt: PgAttr<PgAttr<
|
|
701
|
-
updatedAt: PgAttr<PgAttr<
|
|
702
|
-
finishedAt:
|
|
703
|
-
job:
|
|
704
|
-
status:
|
|
705
|
-
error:
|
|
706
|
-
logs:
|
|
707
|
-
level:
|
|
708
|
-
message:
|
|
709
|
-
service:
|
|
710
|
-
module:
|
|
711
|
-
context:
|
|
712
|
-
app:
|
|
713
|
-
data:
|
|
714
|
-
timestamp:
|
|
697
|
+
declare const jobExecutionResourceSchema: alepha226.TObject<{
|
|
698
|
+
id: PgAttr<PgAttr<alepha226.TString, typeof PG_PRIMARY_KEY>, typeof PG_DEFAULT>;
|
|
699
|
+
version: PgAttr<PgAttr<alepha226.TInteger, typeof PG_VERSION>, typeof PG_DEFAULT>;
|
|
700
|
+
createdAt: PgAttr<PgAttr<alepha226.TString, typeof PG_CREATED_AT>, typeof PG_DEFAULT>;
|
|
701
|
+
updatedAt: PgAttr<PgAttr<alepha226.TString, typeof PG_UPDATED_AT>, typeof PG_DEFAULT>;
|
|
702
|
+
finishedAt: alepha226.TOptional<alepha226.TString>;
|
|
703
|
+
job: alepha226.TString;
|
|
704
|
+
status: alepha226.TUnsafe<"STARTED" | "FAILED" | "COMPLETED">;
|
|
705
|
+
error: alepha226.TOptional<alepha226.TString>;
|
|
706
|
+
logs: alepha226.TOptional<alepha226.TArray<alepha226.TObject<{
|
|
707
|
+
level: alepha226.TUnsafe<"SILENT" | "TRACE" | "DEBUG" | "INFO" | "WARN" | "ERROR">;
|
|
708
|
+
message: alepha226.TString;
|
|
709
|
+
service: alepha226.TString;
|
|
710
|
+
module: alepha226.TString;
|
|
711
|
+
context: alepha226.TOptional<alepha226.TString>;
|
|
712
|
+
app: alepha226.TOptional<alepha226.TString>;
|
|
713
|
+
data: alepha226.TOptional<alepha226.TAny>;
|
|
714
|
+
timestamp: alepha226.TNumber;
|
|
715
715
|
}>>>;
|
|
716
716
|
}>;
|
|
717
717
|
type JobExecutionResource = Static<typeof jobExecutionResourceSchema>;
|
|
718
718
|
//#endregion
|
|
719
719
|
//#region ../../src/api/jobs/schemas/triggerJobSchema.d.ts
|
|
720
|
-
declare const triggerJobSchema:
|
|
721
|
-
name:
|
|
720
|
+
declare const triggerJobSchema: alepha226.TObject<{
|
|
721
|
+
name: alepha226.TString;
|
|
722
722
|
}>;
|
|
723
723
|
type TriggerJob = Static<typeof triggerJobSchema>;
|
|
724
724
|
//#endregion
|
|
@@ -731,7 +731,7 @@ type TriggerJob = Static<typeof triggerJobSchema>;
|
|
|
731
731
|
*
|
|
732
732
|
* @module alepha.api.jobs
|
|
733
733
|
*/
|
|
734
|
-
declare const AlephaApiJobs:
|
|
734
|
+
declare const AlephaApiJobs: alepha226.Service<alepha226.Module>;
|
|
735
735
|
//#endregion
|
|
736
736
|
export { $job, AlephaApiJobs, Job, JobController, JobExecutionEntity, JobExecutionQuery, JobExecutionResource, JobHandlerArguments, JobPrimitive, JobPrimitiveOptions, JobProvider, JobRegistration, JobService, TriggerJob, jobExecutionQuerySchema, jobExecutionResourceSchema, jobExecutions, triggerJobSchema };
|
|
737
737
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["registration: JobRegistration"],"sources":["../../../src/api/jobs/schemas/jobExecutionQuerySchema.ts","../../../src/api/jobs/entities/jobExecutions.ts","../../../src/api/jobs/schemas/jobExecutionResourceSchema.ts","../../../src/api/jobs/schemas/triggerJobSchema.ts","../../../src/api/jobs/providers/JobProvider.ts","../../../src/api/jobs/primitives/$job.ts","../../../src/api/jobs/services/JobService.ts","../../../src/api/jobs/controllers/JobController.ts","../../../src/api/jobs/index.ts"],"sourcesContent":["import type { Static } from \"alepha\";\nimport { t } from \"alepha\";\nimport { pageQuerySchema } from \"alepha/orm\";\n\nexport const jobExecutionQuerySchema = t.extend(pageQuerySchema, {\n status: t.optional(t.enum([\"STARTED\", \"FAILED\", \"COMPLETED\"])),\n job: t.optional(\n t.text({\n description: \"Filter by job name\",\n }),\n ),\n});\n\nexport type JobExecutionQuery = Static<typeof jobExecutionQuerySchema>;\n","import { type Static, t } from \"alepha\";\nimport { logEntrySchema } from \"alepha/logger\";\nimport { $entity, pg } from \"alepha/orm\";\n\nexport const jobExecutions = $entity({\n name: \"job_executions\",\n schema: t.object({\n id: pg.primaryKey(t.uuid()),\n version: pg.version(),\n createdAt: pg.createdAt(),\n updatedAt: pg.updatedAt(),\n finishedAt: t.optional(t.datetime()),\n job: t.string(),\n status: t.enum([\"STARTED\", \"FAILED\", \"COMPLETED\"]),\n error: t.optional(t.string()),\n logs: t.optional(t.array(logEntrySchema)),\n }),\n});\n\nexport type JobExecutionEntity = Static<typeof jobExecutions.schema>;\n","import { type Static, t } from \"alepha\";\nimport { jobExecutions } from \"../entities/jobExecutions.ts\";\n\nexport const jobExecutionResourceSchema = t.extend(\n jobExecutions.schema,\n {},\n {\n title: \"JobExecutionResource\",\n description:\n \"A job execution resource representing the execution details of a job.\",\n },\n);\n\nexport type JobExecutionResource = Static<typeof jobExecutionResourceSchema>;\n","import type { Static } from \"alepha\";\nimport { t } from \"alepha\";\n\nexport const triggerJobSchema = t.object({\n name: t.string(),\n});\n\nexport type TriggerJob = Static<typeof triggerJobSchema>;\n","import { $env, $inject, Alepha, type Async, type Static, t } from \"alepha\";\nimport { type DateTime, DateTimeProvider } from \"alepha/datetime\";\nimport { $lock, type LockPrimitive } from \"alepha/lock\";\nimport type { LogEntry } from \"alepha/logger\";\nimport { $repository } from \"alepha/orm\";\nimport { CronProvider } from \"alepha/scheduler\";\nimport { jobExecutions } from \"../entities/jobExecutions.ts\";\n\nconst envSchema = t.object({\n JOB_PREFIX: t.optional(\n t.text({\n description: \"Prefix for job lock keys\",\n }),\n ),\n});\n\ndeclare module \"alepha\" {\n interface Env extends Partial<Static<typeof envSchema>> {}\n}\n\n/**\n * Provider for job management and execution.\n * Handles job lifecycle, execution tracking, log capturing, and event emission.\n */\nexport class JobProvider {\n protected readonly alepha = $inject(Alepha);\n protected readonly dateTimeProvider = $inject(DateTimeProvider);\n protected readonly cronProvider = $inject(CronProvider);\n protected readonly executionRepository = $repository(jobExecutions);\n protected readonly env = $env(envSchema);\n protected readonly logs = new Map<string, LogEntry[]>();\n protected readonly jobs = new Map<string, JobRegistration>();\n\n /**\n * Register and set up a job for execution (called during primitive initialization).\n */\n public registerJob(options: Job): JobRegistration {\n const jobName = options.name;\n\n // Set up log capturing for this job (only once)\n if (this.jobs.size === 0) {\n this.alepha.events.on(\"log\", ({ entry }) => {\n const context = entry.context;\n if (!context) {\n return;\n }\n\n const entries = this.logs.get(context);\n if (!entries) {\n return;\n }\n\n entries.push(entry);\n this.logs.set(context, entries);\n });\n }\n\n // Create lock primitive if locking is enabled\n const lockPrimitive =\n options.lock !== false\n ? $lock({\n name: () => {\n const prefix = this.env.JOB_PREFIX\n ? `${this.env.JOB_PREFIX}:`\n : \"\";\n return `${prefix}job:${jobName}`;\n },\n handler: async () => {\n await this.executeJob(jobName, options.handler);\n },\n })\n : null;\n\n const registration: JobRegistration = {\n name: jobName,\n options,\n lockPrimitive,\n };\n\n this.jobs.set(jobName, registration);\n\n // Set up cron scheduling if provided\n if (options.cron) {\n this.cronProvider.createCronJob(jobName, options.cron, () =>\n this.triggerJob(jobName),\n );\n }\n\n return registration;\n }\n\n /**\n * Trigger a job by name.\n */\n public async triggerJob(jobName: string): Promise<void> {\n const registration = this.jobs.get(jobName);\n if (!registration) {\n throw new Error(`Job not registered: ${jobName}`);\n }\n\n // Execute handler with or without lock\n if (registration.options.lock !== false && registration.lockPrimitive) {\n await registration.lockPrimitive.run();\n } else {\n await this.executeJob(jobName, registration.options.handler);\n }\n }\n\n /**\n * Execute a job handler (called by the job primitive).\n */\n public async executeJob(\n jobName: string,\n handler: (args: { now: DateTime }) => Async<void>,\n ): Promise<void> {\n if (!this.alepha.isStarted()) {\n return;\n }\n\n const context = this.alepha.context.createContextId();\n\n await this.alepha.context.run(\n async () => {\n try {\n const now = this.dateTimeProvider.now();\n\n // Initialize log collection for this context\n this.logs.set(context, []);\n\n // Create execution record\n await this.executionRepository.create({\n job: jobName,\n status: \"STARTED\",\n });\n\n await this.alepha.events.emit(\"scheduler:begin\", {\n name: jobName,\n now,\n context,\n });\n\n // Execute the handler\n await handler({ now });\n\n // Update execution as completed\n const logs = this.logs.get(context) || [];\n const exec = await this.executionRepository.findOne({\n where: {\n job: jobName,\n status: \"STARTED\",\n },\n });\n\n exec.status = \"COMPLETED\";\n exec.logs = logs;\n exec.finishedAt = this.dateTimeProvider.nowISOString();\n\n await this.executionRepository.save(exec);\n\n await this.alepha.events.emit(\n \"scheduler:success\",\n {\n name: jobName,\n context,\n },\n {\n catch: true,\n },\n );\n } catch (error) {\n // Update execution as failed\n const logs = this.logs.get(context) || [];\n const exec = await this.executionRepository.findOne({\n where: {\n job: jobName,\n status: \"STARTED\",\n },\n });\n\n exec.status = \"FAILED\";\n exec.error = (error as Error).message;\n exec.logs = logs;\n exec.finishedAt = this.dateTimeProvider.nowISOString();\n\n await this.executionRepository.save(exec);\n\n await this.alepha.events.emit(\n \"scheduler:error\",\n {\n name: jobName,\n error: error as Error,\n context,\n },\n {\n catch: true,\n },\n );\n\n // Don't re-throw, jobs should handle errors gracefully\n }\n\n // Clean up logs\n this.logs.delete(context);\n\n await this.alepha.events.emit(\n \"scheduler:end\",\n {\n name: jobName,\n context,\n },\n {\n catch: true,\n },\n );\n },\n {\n context,\n },\n );\n }\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface Job {\n /**\n * Name of the job.\n */\n name: string;\n\n /**\n * Optional description of the job.\n */\n description?: string;\n\n /**\n * Function to run on schedule.\n */\n handler: (args: { now: DateTime }) => Async<void>;\n\n /**\n * Cron expression to run the job.\n */\n cron?: string;\n\n /**\n * If true, the job will be locked and only one instance will run at a time.\n * You probably need to import {@link AlephaLockRedis} for distributed locking.\n *\n * @default true\n */\n lock?: boolean;\n\n /**\n * Optional prefix for job lock keys.\n */\n lockPrefix?: string;\n}\n\nexport interface JobRegistration {\n name: string;\n options: Job;\n lockPrimitive: LockPrimitive<() => Promise<void>> | null;\n}\n","import { $inject, createPrimitive, KIND, Primitive } from \"alepha\";\nimport type { DateTime } from \"alepha/datetime\";\nimport { type Job, JobProvider } from \"../providers/JobProvider.ts\";\n\n/**\n * Job primitive - a drop-in replacement for $scheduler with built-in execution tracking.\n */\nexport const $job = (options: JobPrimitiveOptions): JobPrimitive => {\n return createPrimitive(JobPrimitive, options);\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport type JobPrimitiveOptions = Omit<Job, \"name\"> & {\n /**\n * Name of the job. Defaults to the primitive property name.\n */\n name?: string;\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport class JobPrimitive extends Primitive<JobPrimitiveOptions> {\n protected readonly jobProvider = $inject(JobProvider);\n\n public get name(): string {\n return (\n this.options.name ??\n `${this.config.service.name}.${this.config.propertyKey}`\n );\n }\n\n protected onInit() {\n // Register job with JobProvider\n this.jobProvider.registerJob({\n ...this.options,\n name: this.name,\n });\n }\n\n public async trigger(): Promise<void> {\n await this.jobProvider.triggerJob(this.name);\n }\n}\n\n$job[KIND] = JobPrimitive;\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface JobHandlerArguments {\n now: DateTime;\n}\n","import { $inject, Alepha } from \"alepha\";\nimport { $repository } from \"alepha/orm\";\nimport { jobExecutions } from \"../entities/jobExecutions.ts\";\nimport { $job } from \"../primitives/$job.ts\";\nimport type { JobExecutionQuery } from \"../schemas/jobExecutionQuerySchema.ts\";\n\nexport class JobService {\n protected readonly alepha = $inject(Alepha);\n protected readonly executionRepository = $repository(jobExecutions);\n\n public async getJobs(): Promise<string[]> {\n const jobPrimitives = this.alepha.primitives($job);\n return jobPrimitives.map((job) => job.name);\n }\n\n public async getJobExecutions(query: JobExecutionQuery = {}) {\n query.sort ??= \"-createdAt\";\n\n const where = this.executionRepository.createQueryWhere();\n\n if (query.job) {\n where.job = { eq: query.job };\n }\n\n if (query.status) {\n where.status = { eq: query.status };\n }\n\n return await this.executionRepository.paginate(\n query,\n { where },\n { count: true },\n );\n }\n\n public async triggerJob(name: string): Promise<{ ok: boolean }> {\n const jobPrimitives = this.alepha.primitives($job);\n const job = jobPrimitives.find((j) => j.name === name);\n\n if (!job) {\n throw new Error(`Job not found: ${name}`);\n }\n\n await job.trigger();\n return { ok: true };\n }\n}\n","import { $inject, t } from \"alepha\";\nimport { $action, okSchema } from \"alepha/server\";\nimport { jobExecutionQuerySchema } from \"../schemas/jobExecutionQuerySchema.ts\";\nimport { jobExecutionResourceSchema } from \"../schemas/jobExecutionResourceSchema.ts\";\nimport { triggerJobSchema } from \"../schemas/triggerJobSchema.ts\";\nimport { JobService } from \"../services/JobService.ts\";\n\nexport class JobController {\n protected readonly url: string = \"/jobs\";\n protected readonly group: string = \"jobs\";\n protected readonly jobService = $inject(JobService);\n\n public readonly getJobs = $action({\n path: this.url,\n group: this.group,\n schema: {\n response: t.array(t.string()),\n },\n handler: () => this.jobService.getJobs(),\n });\n\n public readonly getJobExecutions = $action({\n path: `${this.url}/executions`,\n group: this.group,\n schema: {\n query: jobExecutionQuerySchema,\n response: t.page(jobExecutionResourceSchema),\n },\n handler: ({ query }) => this.jobService.getJobExecutions(query),\n });\n\n public readonly triggerJob = $action({\n method: \"POST\",\n path: `${this.url}/trigger`,\n group: this.group,\n schema: {\n body: triggerJobSchema,\n response: okSchema,\n },\n handler: ({ body }) => this.jobService.triggerJob(body.name),\n });\n}\n","import { $module } from \"alepha\";\nimport { JobController } from \"./controllers/JobController.ts\";\nimport { JobProvider } from \"./providers/JobProvider.ts\";\nimport { JobService } from \"./services/JobService.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./controllers/JobController.ts\";\nexport * from \"./entities/jobExecutions.ts\";\nexport * from \"./primitives/$job.ts\";\nexport * from \"./providers/JobProvider.ts\";\nexport * from \"./schemas/jobExecutionQuerySchema.ts\";\nexport * from \"./schemas/jobExecutionResourceSchema.ts\";\nexport * from \"./schemas/triggerJobSchema.ts\";\nexport * from \"./services/JobService.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Provides job management API endpoints for Alepha applications.\n *\n * This module includes job queue operations, job status monitoring,\n * and background task management capabilities.\n *\n * @module alepha.api.jobs\n */\nexport const AlephaApiJobs = $module({\n name: \"alepha.api.jobs\",\n services: [JobController, JobProvider, JobService],\n});\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../src/api/jobs/schemas/jobExecutionQuerySchema.ts","../../../src/api/jobs/entities/jobExecutions.ts","../../../src/api/jobs/schemas/jobExecutionResourceSchema.ts","../../../src/api/jobs/schemas/triggerJobSchema.ts","../../../src/api/jobs/providers/JobProvider.ts","../../../src/api/jobs/primitives/$job.ts","../../../src/api/jobs/services/JobService.ts","../../../src/api/jobs/controllers/JobController.ts","../../../src/api/jobs/index.ts"],"sourcesContent":["import type { Static } from \"alepha\";\nimport { t } from \"alepha\";\nimport { pageQuerySchema } from \"alepha/orm\";\n\nexport const jobExecutionQuerySchema = t.extend(pageQuerySchema, {\n status: t.optional(t.enum([\"STARTED\", \"FAILED\", \"COMPLETED\"])),\n job: t.optional(\n t.text({\n description: \"Filter by job name\",\n }),\n ),\n});\n\nexport type JobExecutionQuery = Static<typeof jobExecutionQuerySchema>;\n","import { type Static, t } from \"alepha\";\nimport { logEntrySchema } from \"alepha/logger\";\nimport { $entity, pg } from \"alepha/orm\";\n\nexport const jobExecutions = $entity({\n name: \"job_executions\",\n schema: t.object({\n id: pg.primaryKey(t.uuid()),\n version: pg.version(),\n createdAt: pg.createdAt(),\n updatedAt: pg.updatedAt(),\n finishedAt: t.optional(t.datetime()),\n job: t.string(),\n status: t.enum([\"STARTED\", \"FAILED\", \"COMPLETED\"]),\n error: t.optional(t.string()),\n logs: t.optional(t.array(logEntrySchema)),\n }),\n});\n\nexport type JobExecutionEntity = Static<typeof jobExecutions.schema>;\n","import { type Static, t } from \"alepha\";\nimport { jobExecutions } from \"../entities/jobExecutions.ts\";\n\nexport const jobExecutionResourceSchema = t.extend(\n jobExecutions.schema,\n {},\n {\n title: \"JobExecutionResource\",\n description:\n \"A job execution resource representing the execution details of a job.\",\n },\n);\n\nexport type JobExecutionResource = Static<typeof jobExecutionResourceSchema>;\n","import type { Static } from \"alepha\";\nimport { t } from \"alepha\";\n\nexport const triggerJobSchema = t.object({\n name: t.string(),\n});\n\nexport type TriggerJob = Static<typeof triggerJobSchema>;\n","import { $env, $inject, Alepha, type Async, type Static, t } from \"alepha\";\nimport { type DateTime, DateTimeProvider } from \"alepha/datetime\";\nimport { $lock, type LockPrimitive } from \"alepha/lock\";\nimport type { LogEntry } from \"alepha/logger\";\nimport { $repository } from \"alepha/orm\";\nimport { CronProvider } from \"alepha/scheduler\";\nimport { jobExecutions } from \"../entities/jobExecutions.ts\";\n\nconst envSchema = t.object({\n JOB_PREFIX: t.optional(\n t.text({\n description: \"Prefix for job lock keys\",\n }),\n ),\n});\n\ndeclare module \"alepha\" {\n interface Env extends Partial<Static<typeof envSchema>> {}\n}\n\n/**\n * Provider for job management and execution.\n * Handles job lifecycle, execution tracking, log capturing, and event emission.\n */\nexport class JobProvider {\n protected readonly alepha = $inject(Alepha);\n protected readonly dateTimeProvider = $inject(DateTimeProvider);\n protected readonly cronProvider = $inject(CronProvider);\n protected readonly executionRepository = $repository(jobExecutions);\n protected readonly env = $env(envSchema);\n protected readonly logs = new Map<string, LogEntry[]>();\n protected readonly jobs = new Map<string, JobRegistration>();\n\n /**\n * Register and set up a job for execution (called during primitive initialization).\n */\n public registerJob(options: Job): JobRegistration {\n const jobName = options.name;\n\n // Set up log capturing for this job (only once)\n if (this.jobs.size === 0) {\n this.alepha.events.on(\"log\", ({ entry }) => {\n const context = entry.context;\n if (!context) {\n return;\n }\n\n const entries = this.logs.get(context);\n if (!entries) {\n return;\n }\n\n entries.push(entry);\n this.logs.set(context, entries);\n });\n }\n\n // Create lock primitive if locking is enabled\n const lockPrimitive =\n options.lock !== false\n ? $lock({\n name: () => {\n const prefix = this.env.JOB_PREFIX\n ? `${this.env.JOB_PREFIX}:`\n : \"\";\n return `${prefix}job:${jobName}`;\n },\n handler: async () => {\n await this.executeJob(jobName, options.handler);\n },\n })\n : null;\n\n const registration: JobRegistration = {\n name: jobName,\n options,\n lockPrimitive,\n };\n\n this.jobs.set(jobName, registration);\n\n // Set up cron scheduling if provided\n if (options.cron) {\n this.cronProvider.createCronJob(jobName, options.cron, () =>\n this.triggerJob(jobName),\n );\n }\n\n return registration;\n }\n\n /**\n * Trigger a job by name.\n */\n public async triggerJob(jobName: string): Promise<void> {\n const registration = this.jobs.get(jobName);\n if (!registration) {\n throw new Error(`Job not registered: ${jobName}`);\n }\n\n // Execute handler with or without lock\n if (registration.options.lock !== false && registration.lockPrimitive) {\n await registration.lockPrimitive.run();\n } else {\n await this.executeJob(jobName, registration.options.handler);\n }\n }\n\n /**\n * Execute a job handler (called by the job primitive).\n */\n public async executeJob(\n jobName: string,\n handler: (args: { now: DateTime }) => Async<void>,\n ): Promise<void> {\n if (!this.alepha.isStarted()) {\n return;\n }\n\n const context = this.alepha.context.createContextId();\n\n await this.alepha.context.run(\n async () => {\n try {\n const now = this.dateTimeProvider.now();\n\n // Initialize log collection for this context\n this.logs.set(context, []);\n\n // Create execution record\n await this.executionRepository.create({\n job: jobName,\n status: \"STARTED\",\n });\n\n await this.alepha.events.emit(\"scheduler:begin\", {\n name: jobName,\n now,\n context,\n });\n\n // Execute the handler\n await handler({ now });\n\n // Update execution as completed\n const logs = this.logs.get(context) || [];\n const exec = await this.executionRepository.findOne({\n where: {\n job: jobName,\n status: \"STARTED\",\n },\n });\n\n exec.status = \"COMPLETED\";\n exec.logs = logs;\n exec.finishedAt = this.dateTimeProvider.nowISOString();\n\n await this.executionRepository.save(exec);\n\n await this.alepha.events.emit(\n \"scheduler:success\",\n {\n name: jobName,\n context,\n },\n {\n catch: true,\n },\n );\n } catch (error) {\n // Update execution as failed\n const logs = this.logs.get(context) || [];\n const exec = await this.executionRepository.findOne({\n where: {\n job: jobName,\n status: \"STARTED\",\n },\n });\n\n exec.status = \"FAILED\";\n exec.error = (error as Error).message;\n exec.logs = logs;\n exec.finishedAt = this.dateTimeProvider.nowISOString();\n\n await this.executionRepository.save(exec);\n\n await this.alepha.events.emit(\n \"scheduler:error\",\n {\n name: jobName,\n error: error as Error,\n context,\n },\n {\n catch: true,\n },\n );\n\n // Don't re-throw, jobs should handle errors gracefully\n }\n\n // Clean up logs\n this.logs.delete(context);\n\n await this.alepha.events.emit(\n \"scheduler:end\",\n {\n name: jobName,\n context,\n },\n {\n catch: true,\n },\n );\n },\n {\n context,\n },\n );\n }\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface Job {\n /**\n * Name of the job.\n */\n name: string;\n\n /**\n * Optional description of the job.\n */\n description?: string;\n\n /**\n * Function to run on schedule.\n */\n handler: (args: { now: DateTime }) => Async<void>;\n\n /**\n * Cron expression to run the job.\n */\n cron?: string;\n\n /**\n * If true, the job will be locked and only one instance will run at a time.\n * You probably need to import {@link AlephaLockRedis} for distributed locking.\n *\n * @default true\n */\n lock?: boolean;\n\n /**\n * Optional prefix for job lock keys.\n */\n lockPrefix?: string;\n}\n\nexport interface JobRegistration {\n name: string;\n options: Job;\n lockPrimitive: LockPrimitive<() => Promise<void>> | null;\n}\n","import { $inject, createPrimitive, KIND, Primitive } from \"alepha\";\nimport type { DateTime } from \"alepha/datetime\";\nimport { type Job, JobProvider } from \"../providers/JobProvider.ts\";\n\n/**\n * Job primitive - a drop-in replacement for $scheduler with built-in execution tracking.\n */\nexport const $job = (options: JobPrimitiveOptions): JobPrimitive => {\n return createPrimitive(JobPrimitive, options);\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport type JobPrimitiveOptions = Omit<Job, \"name\"> & {\n /**\n * Name of the job. Defaults to the primitive property name.\n */\n name?: string;\n};\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport class JobPrimitive extends Primitive<JobPrimitiveOptions> {\n protected readonly jobProvider = $inject(JobProvider);\n\n public get name(): string {\n return (\n this.options.name ??\n `${this.config.service.name}.${this.config.propertyKey}`\n );\n }\n\n protected onInit() {\n // Register job with JobProvider\n this.jobProvider.registerJob({\n ...this.options,\n name: this.name,\n });\n }\n\n public async trigger(): Promise<void> {\n await this.jobProvider.triggerJob(this.name);\n }\n}\n\n$job[KIND] = JobPrimitive;\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport interface JobHandlerArguments {\n now: DateTime;\n}\n","import { $inject, Alepha } from \"alepha\";\nimport { $repository } from \"alepha/orm\";\nimport { jobExecutions } from \"../entities/jobExecutions.ts\";\nimport { $job } from \"../primitives/$job.ts\";\nimport type { JobExecutionQuery } from \"../schemas/jobExecutionQuerySchema.ts\";\n\nexport class JobService {\n protected readonly alepha = $inject(Alepha);\n protected readonly executionRepository = $repository(jobExecutions);\n\n public async getJobs(): Promise<string[]> {\n const jobPrimitives = this.alepha.primitives($job);\n return jobPrimitives.map((job) => job.name);\n }\n\n public async getJobExecutions(query: JobExecutionQuery = {}) {\n query.sort ??= \"-createdAt\";\n\n const where = this.executionRepository.createQueryWhere();\n\n if (query.job) {\n where.job = { eq: query.job };\n }\n\n if (query.status) {\n where.status = { eq: query.status };\n }\n\n return await this.executionRepository.paginate(\n query,\n { where },\n { count: true },\n );\n }\n\n public async triggerJob(name: string): Promise<{ ok: boolean }> {\n const jobPrimitives = this.alepha.primitives($job);\n const job = jobPrimitives.find((j) => j.name === name);\n\n if (!job) {\n throw new Error(`Job not found: ${name}`);\n }\n\n await job.trigger();\n return { ok: true };\n }\n}\n","import { $inject, t } from \"alepha\";\nimport { $action, okSchema } from \"alepha/server\";\nimport { jobExecutionQuerySchema } from \"../schemas/jobExecutionQuerySchema.ts\";\nimport { jobExecutionResourceSchema } from \"../schemas/jobExecutionResourceSchema.ts\";\nimport { triggerJobSchema } from \"../schemas/triggerJobSchema.ts\";\nimport { JobService } from \"../services/JobService.ts\";\n\nexport class JobController {\n protected readonly url: string = \"/jobs\";\n protected readonly group: string = \"jobs\";\n protected readonly jobService = $inject(JobService);\n\n public readonly getJobs = $action({\n path: this.url,\n group: this.group,\n schema: {\n response: t.array(t.string()),\n },\n handler: () => this.jobService.getJobs(),\n });\n\n public readonly getJobExecutions = $action({\n path: `${this.url}/executions`,\n group: this.group,\n schema: {\n query: jobExecutionQuerySchema,\n response: t.page(jobExecutionResourceSchema),\n },\n handler: ({ query }) => this.jobService.getJobExecutions(query),\n });\n\n public readonly triggerJob = $action({\n method: \"POST\",\n path: `${this.url}/trigger`,\n group: this.group,\n schema: {\n body: triggerJobSchema,\n response: okSchema,\n },\n handler: ({ body }) => this.jobService.triggerJob(body.name),\n });\n}\n","import { $module } from \"alepha\";\nimport { JobController } from \"./controllers/JobController.ts\";\nimport { JobProvider } from \"./providers/JobProvider.ts\";\nimport { JobService } from \"./services/JobService.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./controllers/JobController.ts\";\nexport * from \"./entities/jobExecutions.ts\";\nexport * from \"./primitives/$job.ts\";\nexport * from \"./providers/JobProvider.ts\";\nexport * from \"./schemas/jobExecutionQuerySchema.ts\";\nexport * from \"./schemas/jobExecutionResourceSchema.ts\";\nexport * from \"./schemas/triggerJobSchema.ts\";\nexport * from \"./services/JobService.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Provides job management API endpoints for Alepha applications.\n *\n * This module includes job queue operations, job status monitoring,\n * and background task management capabilities.\n *\n * @module alepha.api.jobs\n */\nexport const AlephaApiJobs = $module({\n name: \"alepha.api.jobs\",\n services: [JobController, JobProvider, JobService],\n});\n"],"mappings":"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"}
|