@bgord/bun 1.18.11 → 1.18.13
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/index.d.ts +17 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -1
- package/dist/job-claimer-sqlite.adapter.d.ts.map +1 -1
- package/dist/job-claimer-sqlite.adapter.js +3 -2
- package/dist/job-claimer-sqlite.adapter.js.map +1 -1
- package/dist/job-completer-sqlite.adapter.d.ts.map +1 -1
- package/dist/job-completer-sqlite.adapter.js +2 -1
- package/dist/job-completer-sqlite.adapter.js.map +1 -1
- package/dist/job-enqueuer-sqlite.adapter.d.ts.map +1 -1
- package/dist/job-enqueuer-sqlite.adapter.js +2 -1
- package/dist/job-enqueuer-sqlite.adapter.js.map +1 -1
- package/dist/job-failer-sqlite.adapter.d.ts.map +1 -1
- package/dist/job-failer-sqlite.adapter.js +4 -1
- package/dist/job-failer-sqlite.adapter.js.map +1 -1
- package/dist/job-pruner-collecting.adapter.d.ts +7 -0
- package/dist/job-pruner-collecting.adapter.d.ts.map +1 -0
- package/dist/job-pruner-collecting.adapter.js +10 -0
- package/dist/job-pruner-collecting.adapter.js.map +1 -0
- package/dist/job-pruner-noop.adapter.d.ts +6 -0
- package/dist/job-pruner-noop.adapter.d.ts.map +1 -0
- package/dist/job-pruner-noop.adapter.js +7 -0
- package/dist/job-pruner-noop.adapter.js.map +1 -0
- package/dist/job-pruner-sqlite.adapter.d.ts +15 -0
- package/dist/job-pruner-sqlite.adapter.d.ts.map +1 -0
- package/dist/job-pruner-sqlite.adapter.js +15 -0
- package/dist/job-pruner-sqlite.adapter.js.map +1 -0
- package/dist/job-pruner.port.d.ts +5 -0
- package/dist/job-pruner.port.d.ts.map +1 -0
- package/dist/job-pruner.port.js +2 -0
- package/dist/job-pruner.port.js.map +1 -0
- package/dist/job-pruner.service.d.ts +14 -0
- package/dist/job-pruner.service.d.ts.map +1 -0
- package/dist/job-pruner.service.js +10 -0
- package/dist/job-pruner.service.js.map +1 -0
- package/dist/job-queue-sqlite-store.service.d.ts.map +1 -1
- package/dist/job-queue-sqlite-store.service.js +2 -1
- package/dist/job-queue-sqlite-store.service.js.map +1 -1
- package/dist/job-queue-stats-provider-sqlite.adapter.d.ts.map +1 -1
- package/dist/job-queue-stats-provider-sqlite.adapter.js +4 -3
- package/dist/job-queue-stats-provider-sqlite.adapter.js.map +1 -1
- package/dist/job-queue.adapter.d.ts +1 -1
- package/dist/job-queue.adapter.d.ts.map +1 -1
- package/dist/job-queue.adapter.js +2 -5
- package/dist/job-queue.adapter.js.map +1 -1
- package/dist/job-queue.port.d.ts +1 -1
- package/dist/job-queue.port.d.ts.map +1 -1
- package/dist/job-requeuer-sqlite.adapter.d.ts.map +1 -1
- package/dist/job-requeuer-sqlite.adapter.js +2 -1
- package/dist/job-requeuer-sqlite.adapter.js.map +1 -1
- package/dist/job-status.vo.d.ts +7 -0
- package/dist/job-status.vo.d.ts.map +1 -0
- package/dist/job-status.vo.js +8 -0
- package/dist/job-status.vo.js.map +1 -0
- package/dist/sitemap-changefreq.vo.d.ts +10 -0
- package/dist/sitemap-changefreq.vo.d.ts.map +1 -0
- package/dist/sitemap-changefreq.vo.js +11 -0
- package/dist/sitemap-changefreq.vo.js.map +1 -0
- package/dist/sitemap-entries-provider-dynamic.adapter.d.ts +13 -0
- package/dist/sitemap-entries-provider-dynamic.adapter.d.ts.map +1 -0
- package/dist/sitemap-entries-provider-dynamic.adapter.js +11 -0
- package/dist/sitemap-entries-provider-dynamic.adapter.js.map +1 -0
- package/dist/sitemap-entries-provider-static.adapter.d.ts +8 -0
- package/dist/sitemap-entries-provider-static.adapter.d.ts.map +1 -0
- package/dist/sitemap-entries-provider-static.adapter.js +10 -0
- package/dist/sitemap-entries-provider-static.adapter.js.map +1 -0
- package/dist/sitemap-entries-provider-with-cache.adapter.d.ts +20 -0
- package/dist/sitemap-entries-provider-with-cache.adapter.d.ts.map +1 -0
- package/dist/sitemap-entries-provider-with-cache.adapter.js +19 -0
- package/dist/sitemap-entries-provider-with-cache.adapter.js.map +1 -0
- package/dist/sitemap-entries-provider.port.d.ts +5 -0
- package/dist/sitemap-entries-provider.port.d.ts.map +1 -0
- package/dist/sitemap-entries-provider.port.js +2 -0
- package/dist/sitemap-entries-provider.port.js.map +1 -0
- package/dist/sitemap-entry.vo.d.ts +16 -0
- package/dist/sitemap-entry.vo.d.ts.map +1 -0
- package/dist/sitemap-entry.vo.js +14 -0
- package/dist/sitemap-entry.vo.js.map +1 -0
- package/dist/sitemap-hono.handler.d.ts +8 -0
- package/dist/sitemap-hono.handler.d.ts.map +1 -0
- package/dist/sitemap-hono.handler.js +17 -0
- package/dist/sitemap-hono.handler.js.map +1 -0
- package/dist/sitemap-priority.vo.d.ts +7 -0
- package/dist/sitemap-priority.vo.d.ts.map +1 -0
- package/dist/sitemap-priority.vo.js +6 -0
- package/dist/sitemap-priority.vo.js.map +1 -0
- package/dist/sitemap-url.vo.d.ts +7 -0
- package/dist/sitemap-url.vo.d.ts.map +1 -0
- package/dist/sitemap-url.vo.js +7 -0
- package/dist/sitemap-url.vo.js.map +1 -0
- package/dist/sitemap.handler.d.ts +10 -0
- package/dist/sitemap.handler.d.ts.map +1 -0
- package/dist/sitemap.handler.js +10 -0
- package/dist/sitemap.handler.js.map +1 -0
- package/dist/sitemap.service.d.ts +8 -0
- package/dist/sitemap.service.d.ts.map +1 -0
- package/dist/sitemap.service.js +17 -0
- package/dist/sitemap.service.js.map +1 -0
- package/package.json +6 -6
- package/readme.md +17 -0
- package/src/index.ts +17 -0
- package/src/job-claimer-sqlite.adapter.ts +3 -2
- package/src/job-completer-sqlite.adapter.ts +5 -1
- package/src/job-enqueuer-sqlite.adapter.ts +2 -1
- package/src/job-failer-sqlite.adapter.ts +4 -1
- package/src/job-pruner-collecting.adapter.ts +14 -0
- package/src/job-pruner-noop.adapter.ts +8 -0
- package/src/job-pruner-sqlite.adapter.ts +23 -0
- package/src/job-pruner.port.ts +5 -0
- package/src/job-pruner.service.ts +16 -0
- package/src/job-queue-sqlite-store.service.ts +2 -1
- package/src/job-queue-stats-provider-sqlite.adapter.ts +4 -3
- package/src/job-queue.adapter.ts +5 -5
- package/src/job-queue.port.ts +1 -1
- package/src/job-requeuer-sqlite.adapter.ts +2 -1
- package/src/job-status.vo.ts +6 -0
- package/src/sitemap-changefreq.vo.ts +9 -0
- package/src/sitemap-entries-provider-dynamic.adapter.ts +14 -0
- package/src/sitemap-entries-provider-static.adapter.ts +10 -0
- package/src/sitemap-entries-provider-with-cache.adapter.ts +32 -0
- package/src/sitemap-entries-provider.port.ts +5 -0
- package/src/sitemap-entry.vo.ts +28 -0
- package/src/sitemap-hono.handler.ts +22 -0
- package/src/sitemap-priority.vo.ts +13 -0
- package/src/sitemap-url.vo.ts +12 -0
- package/src/sitemap.handler.ts +11 -0
- package/src/sitemap.service.ts +20 -0
package/dist/job-queue.port.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ import type { GenericJob } from "./job.types";
|
|
|
3
3
|
import type { JobHandler } from "./job-registry.port";
|
|
4
4
|
import type { JobRetryPolicyStrategy } from "./job-retry-policy.strategy";
|
|
5
5
|
export interface JobDispatcherPort<Job extends GenericJob> {
|
|
6
|
-
enqueue<EnqueuedJob extends Job>(job: EnqueuedJob): Promise<EnqueuedJob>;
|
|
6
|
+
enqueue<EnqueuedJob extends Job>(job: EnqueuedJob, delay?: tools.Duration): Promise<EnqueuedJob>;
|
|
7
7
|
}
|
|
8
8
|
export interface JobQueuePort<Job extends GenericJob> extends JobDispatcherPort<Job> {
|
|
9
9
|
claim(limit: tools.IntegerPositiveType): Promise<ReadonlyArray<Job>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"job-queue.port.d.ts","sourceRoot":"","sources":["../src/job-queue.port.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAE1E,MAAM,WAAW,iBAAiB,CAAC,GAAG,SAAS,UAAU;IACvD,OAAO,CAAC,WAAW,SAAS,GAAG,EAAE,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"job-queue.port.d.ts","sourceRoot":"","sources":["../src/job-queue.port.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAE1E,MAAM,WAAW,iBAAiB,CAAC,GAAG,SAAS,UAAU;IACvD,OAAO,CAAC,WAAW,SAAS,GAAG,EAAE,GAAG,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;CAClG;AAED,MAAM,WAAW,YAAY,CAAC,GAAG,SAAS,UAAU,CAAE,SAAQ,iBAAiB,CAAC,GAAG,CAAC;IAClF,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,mBAAmB,GAAG,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;IAErE,QAAQ,CAAC,EAAE,EAAE,UAAU,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9C,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE1C,OAAO,CAAC,EAAE,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,UAAU,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtG,cAAc,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,GAAG,sBAAsB,CAAC;IAEjE,UAAU,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;CACvD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"job-requeuer-sqlite.adapter.d.ts","sourceRoot":"","sources":["../src/job-requeuer-sqlite.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"job-requeuer-sqlite.adapter.d.ts","sourceRoot":"","sources":["../src/job-requeuer-sqlite.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAG3D,KAAK,YAAY,GAAG;IAAE,EAAE,EAAE,QAAQ,CAAC;IAAC,KAAK,EAAE,SAAS,CAAA;CAAE,CAAC;AAEvD,qBAAa,wBAAyB,YAAW,eAAe;IAClD,OAAO,CAAC,QAAQ,CAAC,IAAI;IAAjC,YAA6B,IAAI,EAAE,YAAY,EAAI;IAE7C,OAAO,CACX,EAAE,EAAE,UAAU,CAAC,IAAI,CAAC,EACpB,QAAQ,EAAE,UAAU,CAAC,UAAU,CAAC,EAChC,KAAK,EAAE,KAAK,CAAC,QAAQ,GACpB,OAAO,CAAC,IAAI,CAAC,CAKf;CACF"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
+
import { JobStatusEnum } from "./job-status.vo";
|
|
1
2
|
export class JobRequeuerSqliteAdapter {
|
|
2
3
|
deps;
|
|
3
4
|
constructor(deps) {
|
|
4
5
|
this.deps = deps;
|
|
5
6
|
}
|
|
6
7
|
async requeue(id, revision, delay) {
|
|
7
|
-
this.deps.db.run(
|
|
8
|
+
this.deps.db.run(`UPDATE jobs SET status = '${JobStatusEnum.pending}', revision = ?, claimableAt = ? WHERE id = ?`, [revision, this.deps.Clock.now().add(delay).ms, id]);
|
|
8
9
|
}
|
|
9
10
|
}
|
|
10
11
|
//# sourceMappingURL=job-requeuer-sqlite.adapter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"job-requeuer-sqlite.adapter.js","sourceRoot":"","sources":["../src/job-requeuer-sqlite.adapter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"job-requeuer-sqlite.adapter.js","sourceRoot":"","sources":["../src/job-requeuer-sqlite.adapter.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAIhD,MAAM,OAAO,wBAAwB;IACN,IAAI;IAAjC,YAA6B,IAAkB;oBAAlB,IAAI;IAAiB,CAAC;IAEnD,KAAK,CAAC,OAAO,CACX,EAAoB,EACpB,QAAgC,EAChC,KAAqB;QAErB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CACd,6BAA6B,aAAa,CAAC,OAAO,+CAA+C,EACjG,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CACpD,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"job-status.vo.d.ts","sourceRoot":"","sources":["../src/job-status.vo.ts"],"names":[],"mappings":"AAAA,oBAAY,aAAa;IACvB,OAAO,YAAY;IACnB,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,MAAM,WAAW;CAClB"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export var JobStatusEnum;
|
|
2
|
+
(function (JobStatusEnum) {
|
|
3
|
+
JobStatusEnum["pending"] = "pending";
|
|
4
|
+
JobStatusEnum["claimed"] = "claimed";
|
|
5
|
+
JobStatusEnum["completed"] = "completed";
|
|
6
|
+
JobStatusEnum["failed"] = "failed";
|
|
7
|
+
})(JobStatusEnum || (JobStatusEnum = {}));
|
|
8
|
+
//# sourceMappingURL=job-status.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"job-status.vo.js","sourceRoot":"","sources":["../src/job-status.vo.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,aAKX;AALD,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,oCAAmB,CAAA;IACnB,wCAAuB,CAAA;IACvB,kCAAiB,CAAA;AACnB,CAAC,EALW,aAAa,KAAb,aAAa,QAKxB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-changefreq.vo.d.ts","sourceRoot":"","sources":["../src/sitemap-changefreq.vo.ts"],"names":[],"mappings":"AAAA,oBAAY,qBAAqB;IAC/B,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,KAAK,UAAU;IACf,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,MAAM,WAAW;IACjB,KAAK,UAAU;CAChB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export var SitemapChangefreqEnum;
|
|
2
|
+
(function (SitemapChangefreqEnum) {
|
|
3
|
+
SitemapChangefreqEnum["always"] = "always";
|
|
4
|
+
SitemapChangefreqEnum["hourly"] = "hourly";
|
|
5
|
+
SitemapChangefreqEnum["daily"] = "daily";
|
|
6
|
+
SitemapChangefreqEnum["weekly"] = "weekly";
|
|
7
|
+
SitemapChangefreqEnum["monthly"] = "monthly";
|
|
8
|
+
SitemapChangefreqEnum["yearly"] = "yearly";
|
|
9
|
+
SitemapChangefreqEnum["never"] = "never";
|
|
10
|
+
})(SitemapChangefreqEnum || (SitemapChangefreqEnum = {}));
|
|
11
|
+
//# sourceMappingURL=sitemap-changefreq.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-changefreq.vo.js","sourceRoot":"","sources":["../src/sitemap-changefreq.vo.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,qBAQX;AARD,WAAY,qBAAqB;IAC/B,0CAAiB,CAAA;IACjB,0CAAiB,CAAA;IACjB,wCAAe,CAAA;IACf,0CAAiB,CAAA;IACjB,4CAAmB,CAAA;IACnB,0CAAiB,CAAA;IACjB,wCAAe,CAAA;AACjB,CAAC,EARW,qBAAqB,KAArB,qBAAqB,QAQhC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { SitemapEntriesProvider } from "./sitemap-entries-provider.port";
|
|
2
|
+
import type { SitemapEntry } from "./sitemap-entry.vo";
|
|
3
|
+
type Config<T> = {
|
|
4
|
+
fetcher: () => Promise<ReadonlyArray<T>>;
|
|
5
|
+
mapper: (item: T) => SitemapEntry;
|
|
6
|
+
};
|
|
7
|
+
export declare class SitemapEntriesProviderDynamicAdapter<T> implements SitemapEntriesProvider {
|
|
8
|
+
private readonly config;
|
|
9
|
+
constructor(config: Config<T>);
|
|
10
|
+
produce(): Promise<ReadonlyArray<SitemapEntry>>;
|
|
11
|
+
}
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=sitemap-entries-provider-dynamic.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider-dynamic.adapter.d.ts","sourceRoot":"","sources":["../src/sitemap-entries-provider-dynamic.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD,KAAK,MAAM,CAAC,CAAC,IAAI;IAAE,OAAO,EAAE,MAAM,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;IAAC,MAAM,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,YAAY,CAAA;CAAE,CAAC;AAEjG,qBAAa,oCAAoC,CAAC,CAAC,CAAE,YAAW,sBAAsB;IACxE,OAAO,CAAC,QAAQ,CAAC,MAAM;IAAnC,YAA6B,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,EAAI;IAE5C,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAIpD;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export class SitemapEntriesProviderDynamicAdapter {
|
|
2
|
+
config;
|
|
3
|
+
constructor(config) {
|
|
4
|
+
this.config = config;
|
|
5
|
+
}
|
|
6
|
+
async produce() {
|
|
7
|
+
const items = await this.config.fetcher();
|
|
8
|
+
return items.map(this.config.mapper);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=sitemap-entries-provider-dynamic.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider-dynamic.adapter.js","sourceRoot":"","sources":["../src/sitemap-entries-provider-dynamic.adapter.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,oCAAoC;IAClB,MAAM;IAAnC,YAA6B,MAAiB;sBAAjB,MAAM;IAAc,CAAC;IAElD,KAAK,CAAC,OAAO;QACX,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAE1C,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACvC,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SitemapEntriesProvider } from "./sitemap-entries-provider.port";
|
|
2
|
+
import type { SitemapEntry } from "./sitemap-entry.vo";
|
|
3
|
+
export declare class SitemapEntriesProviderStaticAdapter implements SitemapEntriesProvider {
|
|
4
|
+
private readonly entries;
|
|
5
|
+
constructor(entries: ReadonlyArray<SitemapEntry>);
|
|
6
|
+
produce(): Promise<ReadonlyArray<SitemapEntry>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=sitemap-entries-provider-static.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider-static.adapter.d.ts","sourceRoot":"","sources":["../src/sitemap-entries-provider-static.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD,qBAAa,mCAAoC,YAAW,sBAAsB;IACpE,OAAO,CAAC,QAAQ,CAAC,OAAO;IAApC,YAA6B,OAAO,EAAE,aAAa,CAAC,YAAY,CAAC,EAAI;IAE/D,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAEpD;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider-static.adapter.js","sourceRoot":"","sources":["../src/sitemap-entries-provider-static.adapter.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,mCAAmC;IACjB,OAAO;IAApC,YAA6B,OAAoC;uBAApC,OAAO;IAAgC,CAAC;IAErE,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;CACF"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
2
|
+
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
3
|
+
import type { SitemapEntriesProvider } from "./sitemap-entries-provider.port";
|
|
4
|
+
import type { SitemapEntry } from "./sitemap-entry.vo";
|
|
5
|
+
type Config = {
|
|
6
|
+
id: string;
|
|
7
|
+
inner: SitemapEntriesProvider;
|
|
8
|
+
};
|
|
9
|
+
type Dependencies = {
|
|
10
|
+
CacheResolver: CacheResolverStrategy;
|
|
11
|
+
HashContent: HashContentStrategy;
|
|
12
|
+
};
|
|
13
|
+
export declare class SitemapEntriesProviderWithCacheAdapter implements SitemapEntriesProvider {
|
|
14
|
+
private readonly config;
|
|
15
|
+
private readonly deps;
|
|
16
|
+
constructor(config: Config, deps: Dependencies);
|
|
17
|
+
produce(): Promise<ReadonlyArray<SitemapEntry>>;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=sitemap-entries-provider-with-cache.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider-with-cache.adapter.d.ts","sourceRoot":"","sources":["../src/sitemap-entries-provider-with-cache.adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AACvE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAIvD,KAAK,MAAM,GAAG;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,sBAAsB,CAAA;CAAE,CAAC;AAC5D,KAAK,YAAY,GAAG;IAAE,aAAa,EAAE,qBAAqB,CAAC;IAAC,WAAW,EAAE,mBAAmB,CAAA;CAAE,CAAC;AAE/F,qBAAa,sCAAuC,YAAW,sBAAsB;IAEjF,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,IAAI;IAFvB,YACmB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,YAAY,EACjC;IAEE,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAcpD;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
2
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
3
|
+
export class SitemapEntriesProviderWithCacheAdapter {
|
|
4
|
+
config;
|
|
5
|
+
deps;
|
|
6
|
+
constructor(config, deps) {
|
|
7
|
+
this.config = config;
|
|
8
|
+
this.deps = deps;
|
|
9
|
+
}
|
|
10
|
+
async produce() {
|
|
11
|
+
const resolver = new SubjectApplicationResolver([
|
|
12
|
+
new SubjectSegmentFixedStrategy("sitemap_entries_provider"),
|
|
13
|
+
new SubjectSegmentFixedStrategy(this.config.id),
|
|
14
|
+
], this.deps);
|
|
15
|
+
const subject = await resolver.resolve();
|
|
16
|
+
return this.deps.CacheResolver.resolve(subject.hex, () => this.config.inner.produce());
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=sitemap-entries-provider-with-cache.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider-with-cache.adapter.js","sourceRoot":"","sources":["../src/sitemap-entries-provider-with-cache.adapter.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAK/E,MAAM,OAAO,sCAAsC;IAE9B,MAAM;IACN,IAAI;IAFvB,YACmB,MAAc,EACd,IAAkB;sBADlB,MAAM;oBACN,IAAI;IACpB,CAAC;IAEJ,KAAK,CAAC,OAAO;QACX,MAAM,QAAQ,GAAG,IAAI,0BAA0B,CAC7C;YACE,IAAI,2BAA2B,CAAC,0BAA0B,CAAC;YAC3D,IAAI,2BAA2B,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;SAChD,EACD,IAAI,CAAC,IAAI,CACV,CAAC;QAEF,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,EAAE,CAAC;QAEzC,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAA8B,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,CACpF,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,CAC5B,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider.port.d.ts","sourceRoot":"","sources":["../src/sitemap-entries-provider.port.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD,MAAM,WAAW,sBAAsB;IACrC,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC;CACjD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entries-provider.port.js","sourceRoot":"","sources":["../src/sitemap-entries-provider.port.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { SitemapChangefreqEnum } from "./sitemap-changefreq.vo";
|
|
3
|
+
import type { SitemapPriorityType } from "./sitemap-priority.vo";
|
|
4
|
+
import type { SitemapUrlType } from "./sitemap-url.vo";
|
|
5
|
+
export type SitemapEntryType = {
|
|
6
|
+
loc: SitemapUrlType;
|
|
7
|
+
lastmod?: tools.DayIsoIdType;
|
|
8
|
+
changefreq?: SitemapChangefreqEnum;
|
|
9
|
+
priority?: SitemapPriorityType;
|
|
10
|
+
};
|
|
11
|
+
export declare class SitemapEntry {
|
|
12
|
+
private readonly entry;
|
|
13
|
+
constructor(entry: SitemapEntryType);
|
|
14
|
+
toXml(): string;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=sitemap-entry.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entry.vo.d.ts","sourceRoot":"","sources":["../src/sitemap-entry.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AACrE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AACjE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,GAAG,EAAE,cAAc,CAAC;IACpB,OAAO,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC;IAC7B,UAAU,CAAC,EAAE,qBAAqB,CAAC;IACnC,QAAQ,CAAC,EAAE,mBAAmB,CAAC;CAChC,CAAC;AAEF,qBAAa,YAAY;IACX,OAAO,CAAC,QAAQ,CAAC,KAAK;IAAlC,YAA6B,KAAK,EAAE,gBAAgB,EAAI;IAExD,KAAK,IAAI,MAAM,CAWd;CACF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export class SitemapEntry {
|
|
2
|
+
entry;
|
|
3
|
+
constructor(entry) {
|
|
4
|
+
this.entry = entry;
|
|
5
|
+
}
|
|
6
|
+
toXml() {
|
|
7
|
+
const lastmod = this.entry.lastmod ? `<lastmod>${this.entry.lastmod}</lastmod>` : "";
|
|
8
|
+
const changefreq = this.entry.changefreq ? `<changefreq>${this.entry.changefreq}</changefreq>` : "";
|
|
9
|
+
const priority = this.entry.priority !== undefined ? `<priority>${this.entry.priority.toFixed(1)}</priority>` : "";
|
|
10
|
+
const loc = `<loc>${this.entry.loc}</loc>`;
|
|
11
|
+
return ["<url>", loc, lastmod, changefreq, priority, "</url>"].join("");
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=sitemap-entry.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-entry.vo.js","sourceRoot":"","sources":["../src/sitemap-entry.vo.ts"],"names":[],"mappings":"AAYA,MAAM,OAAO,YAAY;IACM,KAAK;IAAlC,YAA6B,KAAuB;qBAAvB,KAAK;IAAqB,CAAC;IAExD,KAAK;QACH,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;QAErF,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,IAAI,CAAC,KAAK,CAAC,UAAU,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;QAEpG,MAAM,QAAQ,GACZ,IAAI,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,aAAa,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;QAEpG,MAAM,GAAG,GAAG,QAAQ,IAAI,CAAC,KAAK,CAAC,GAAG,QAAQ,CAAC;QAE3C,OAAO,CAAC,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC1E,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { HandlerHonoPort } from "./handler-hono.port";
|
|
2
|
+
import { type SitemapHandlerConfig } from "./sitemap.handler";
|
|
3
|
+
export declare class SitemapHonoHandler implements HandlerHonoPort {
|
|
4
|
+
private readonly handler;
|
|
5
|
+
constructor(config: SitemapHandlerConfig);
|
|
6
|
+
handle(): [import("hono/types").H<import("hono").Env, string, {}, Promise<Response & import("hono").TypedResponse<string, 200, "body">>>];
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=sitemap-hono.handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-hono.handler.d.ts","sourceRoot":"","sources":["../src/sitemap-hono.handler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAkB,KAAK,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAI9E,qBAAa,kBAAmB,YAAW,eAAe;IACxD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAiB;IAEzC,YAAY,MAAM,EAAE,oBAAoB,EAEvC;IAED,MAAM,oIAOL;CACF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { createFactory } from "hono/factory";
|
|
2
|
+
import { SitemapHandler } from "./sitemap.handler";
|
|
3
|
+
const factory = createFactory();
|
|
4
|
+
export class SitemapHonoHandler {
|
|
5
|
+
handler;
|
|
6
|
+
constructor(config) {
|
|
7
|
+
this.handler = new SitemapHandler(config);
|
|
8
|
+
}
|
|
9
|
+
handle() {
|
|
10
|
+
return factory.createHandlers(async (c) => {
|
|
11
|
+
const xml = await this.handler.generate();
|
|
12
|
+
c.header("Content-Type", "application/xml");
|
|
13
|
+
return c.body(xml, 200);
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=sitemap-hono.handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-hono.handler.js","sourceRoot":"","sources":["../src/sitemap-hono.handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE7C,OAAO,EAAE,cAAc,EAA6B,MAAM,mBAAmB,CAAC;AAE9E,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;AAEhC,MAAM,OAAO,kBAAkB;IACZ,OAAO,CAAiB;IAEzC,YAAY,MAA4B;QACtC,IAAI,CAAC,OAAO,GAAG,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAED,MAAM;QACJ,OAAO,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACxC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAE1C,CAAC,CAAC,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,CAAC;YAC5C,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as v from "valibot";
|
|
2
|
+
export declare const SitemapPriorityError: {
|
|
3
|
+
Invalid: string;
|
|
4
|
+
};
|
|
5
|
+
export declare const SitemapPriority: v.SchemaWithPipe<readonly [v.NumberSchema<string>, v.MinValueAction<number, 0, string>, v.MaxValueAction<number, 1, string>, v.BrandAction<number, "SitemapPriority">]>;
|
|
6
|
+
export type SitemapPriorityType = v.InferOutput<typeof SitemapPriority>;
|
|
7
|
+
//# sourceMappingURL=sitemap-priority.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-priority.vo.d.ts","sourceRoot":"","sources":["../src/sitemap-priority.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,SAAS,CAAC;AAE7B,eAAO,MAAM,oBAAoB;IAAK,OAAO;CAA8B,CAAC;AAE5E,eAAO,MAAM,eAAe,yKAM3B,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG,CAAC,CAAC,WAAW,CAAC,OAAO,eAAe,CAAC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import * as v from "valibot";
|
|
2
|
+
export const SitemapPriorityError = { Invalid: "sitemap.priority.invalid" };
|
|
3
|
+
export const SitemapPriority = v.pipe(v.number(SitemapPriorityError.Invalid), v.minValue(0, SitemapPriorityError.Invalid), v.maxValue(1, SitemapPriorityError.Invalid),
|
|
4
|
+
// Stryker disable next-line StringLiteral
|
|
5
|
+
v.brand("SitemapPriority"));
|
|
6
|
+
//# sourceMappingURL=sitemap-priority.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-priority.vo.js","sourceRoot":"","sources":["../src/sitemap-priority.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,SAAS,CAAC;AAE7B,MAAM,CAAC,MAAM,oBAAoB,GAAG,EAAE,OAAO,EAAE,0BAA0B,EAAE,CAAC;AAE5E,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,CAAC,IAAI,CACnC,CAAC,CAAC,MAAM,CAAC,oBAAoB,CAAC,OAAO,CAAC,EACtC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,oBAAoB,CAAC,OAAO,CAAC,EAC3C,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,oBAAoB,CAAC,OAAO,CAAC;AAC3C,0CAA0C;AAC1C,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAC3B,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as v from "valibot";
|
|
2
|
+
export declare const SitemapUrlError: {
|
|
3
|
+
Invalid: string;
|
|
4
|
+
};
|
|
5
|
+
export declare const SitemapUrl: v.SchemaWithPipe<readonly [v.UnionSchema<[v.SchemaWithPipe<readonly [v.StringSchema<string>, v.UrlAction<string, string>, v.EndsWithAction<string, "/", string>, v.BrandAction<string, "UrlWithSlash">]>, v.SchemaWithPipe<readonly [v.StringSchema<string>, v.UrlAction<string, string>, v.CheckAction<string, string>, v.BrandAction<string, "UrlWithoutSlash">]>], string>, v.BrandAction<(string & v.Brand<"UrlWithSlash">) | (string & v.Brand<"UrlWithoutSlash">), "SitemapUrl">]>;
|
|
6
|
+
export type SitemapUrlType = v.InferOutput<typeof SitemapUrl>;
|
|
7
|
+
//# sourceMappingURL=sitemap-url.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-url.vo.d.ts","sourceRoot":"","sources":["../src/sitemap-url.vo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,CAAC,MAAM,SAAS,CAAC;AAE7B,eAAO,MAAM,eAAe;IAAK,OAAO;CAAyB,CAAC;AAElE,eAAO,MAAM,UAAU,0dAItB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAAC,CAAC,WAAW,CAAC,OAAO,UAAU,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import * as v from "valibot";
|
|
3
|
+
export const SitemapUrlError = { Invalid: "sitemap.url.invalid" };
|
|
4
|
+
export const SitemapUrl = v.pipe(v.union([tools.UrlWithSlash, tools.UrlWithoutSlash], SitemapUrlError.Invalid),
|
|
5
|
+
// Stryker disable next-line StringLiteral
|
|
6
|
+
v.brand("SitemapUrl"));
|
|
7
|
+
//# sourceMappingURL=sitemap-url.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap-url.vo.js","sourceRoot":"","sources":["../src/sitemap-url.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,CAAC,MAAM,SAAS,CAAC;AAE7B,MAAM,CAAC,MAAM,eAAe,GAAG,EAAE,OAAO,EAAE,qBAAqB,EAAE,CAAC;AAElE,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAC9B,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,eAAe,CAAC,EAAE,eAAe,CAAC,OAAO,CAAC;AAC7E,0CAA0C;AAC1C,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CACtB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Sitemap } from "./sitemap.service";
|
|
2
|
+
export type SitemapHandlerConfig = {
|
|
3
|
+
sitemap: Sitemap;
|
|
4
|
+
};
|
|
5
|
+
export declare class SitemapHandler {
|
|
6
|
+
private readonly config;
|
|
7
|
+
constructor(config: SitemapHandlerConfig);
|
|
8
|
+
generate(): Promise<string>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=sitemap.handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap.handler.d.ts","sourceRoot":"","sources":["../src/sitemap.handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEjD,MAAM,MAAM,oBAAoB,GAAG;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,CAAC;AAExD,qBAAa,cAAc;IACb,OAAO,CAAC,QAAQ,CAAC,MAAM;IAAnC,YAA6B,MAAM,EAAE,oBAAoB,EAAI;IAEvD,QAAQ,IAAI,OAAO,CAAC,MAAM,CAAC,CAEhC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap.handler.js","sourceRoot":"","sources":["../src/sitemap.handler.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,cAAc;IACI,MAAM;IAAnC,YAA6B,MAA4B;sBAA5B,MAAM;IAAyB,CAAC;IAE7D,KAAK,CAAC,QAAQ;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACrC,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SitemapEntriesProvider } from "./sitemap-entries-provider.port";
|
|
2
|
+
export type SitemapXml = string;
|
|
3
|
+
export declare class Sitemap {
|
|
4
|
+
private readonly providers;
|
|
5
|
+
constructor(providers: ReadonlyArray<SitemapEntriesProvider>);
|
|
6
|
+
toXml(): Promise<SitemapXml>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=sitemap.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap.service.d.ts","sourceRoot":"","sources":["../src/sitemap.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAE9E,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC;AAEhC,qBAAa,OAAO;IACN,OAAO,CAAC,QAAQ,CAAC,SAAS;IAAtC,YAA6B,SAAS,EAAE,aAAa,CAAC,sBAAsB,CAAC,EAAI;IAE3E,KAAK,IAAI,OAAO,CAAC,UAAU,CAAC,CAWjC;CACF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export class Sitemap {
|
|
2
|
+
providers;
|
|
3
|
+
constructor(providers) {
|
|
4
|
+
this.providers = providers;
|
|
5
|
+
}
|
|
6
|
+
async toXml() {
|
|
7
|
+
const resolved = await Promise.all(this.providers.map((provider) => provider.produce()));
|
|
8
|
+
const xmls = resolved.flat().map((entry) => entry.toXml());
|
|
9
|
+
return [
|
|
10
|
+
'<?xml version="1.0" encoding="UTF-8"?>',
|
|
11
|
+
'<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">',
|
|
12
|
+
...xmls,
|
|
13
|
+
"</urlset>",
|
|
14
|
+
].join("");
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=sitemap.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sitemap.service.js","sourceRoot":"","sources":["../src/sitemap.service.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,OAAO;IACW,SAAS;IAAtC,YAA6B,SAAgD;yBAAhD,SAAS;IAA0C,CAAC;IAEjF,KAAK,CAAC,KAAK;QACT,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAEzF,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;QAE3D,OAAO;YACL,wCAAwC;YACxC,8DAA8D;YAC9D,GAAG,IAAI;YACP,WAAW;SACZ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACb,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bgord/bun",
|
|
3
|
-
"version": "1.18.
|
|
3
|
+
"version": "1.18.13",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"author": "Bartosz Gordon",
|
|
@@ -22,20 +22,20 @@
|
|
|
22
22
|
},
|
|
23
23
|
"devDependencies": {
|
|
24
24
|
"@biomejs/biome": "2.4.13",
|
|
25
|
-
"@commitlint/cli": "20.5.
|
|
26
|
-
"@commitlint/config-conventional": "20.5.
|
|
25
|
+
"@commitlint/cli": "20.5.3",
|
|
26
|
+
"@commitlint/config-conventional": "20.5.3",
|
|
27
27
|
"@standard-schema/spec": "1.1.0",
|
|
28
28
|
"@stryker-mutator/core": "9.6.1",
|
|
29
29
|
"@stryker-mutator/typescript-checker": "9.6.1",
|
|
30
30
|
"@types/bun": "1.3.13",
|
|
31
31
|
"@types/nodemailer": "8.0.0",
|
|
32
32
|
"@types/yazl": "3.3.1",
|
|
33
|
-
"@typescript/native-preview": "7.0.0-dev.
|
|
33
|
+
"@typescript/native-preview": "7.0.0-dev.20260501.1",
|
|
34
34
|
"better-auth": "1.6.9",
|
|
35
35
|
"croner": "10.0.1",
|
|
36
36
|
"cspell": "10.0.0",
|
|
37
37
|
"csv": "6.5.1",
|
|
38
|
-
"knip": "6.
|
|
38
|
+
"knip": "6.9.0",
|
|
39
39
|
"lefthook": "2.1.6",
|
|
40
40
|
"lockfile-lint": "5.0.0",
|
|
41
41
|
"nodemailer": "8.0.7",
|
|
@@ -49,7 +49,7 @@
|
|
|
49
49
|
"dependencies": {
|
|
50
50
|
"@bgord/tools": "1.5.7",
|
|
51
51
|
"emittery": "2.0.0",
|
|
52
|
-
"hono": "4.12.
|
|
52
|
+
"hono": "4.12.16",
|
|
53
53
|
"node-cache": "5.1.2"
|
|
54
54
|
},
|
|
55
55
|
"peerDependencies": {
|
package/readme.md
CHANGED
|
@@ -290,6 +290,11 @@ src/
|
|
|
290
290
|
├── job-failer-noop.adapter.ts
|
|
291
291
|
├── job-failer-sqlite.adapter.ts
|
|
292
292
|
├── job-failer.port.ts
|
|
293
|
+
├── job-pruner-collecting.adapter.ts
|
|
294
|
+
├── job-pruner-noop.adapter.ts
|
|
295
|
+
├── job-pruner-sqlite.adapter.ts
|
|
296
|
+
├── job-pruner.port.ts
|
|
297
|
+
├── job-pruner.service.ts
|
|
293
298
|
├── job-queue-noop.adapter.ts
|
|
294
299
|
├── job-queue-sqlite-store.service.ts
|
|
295
300
|
├── job-queue-stats-provider-noop.adapter.ts
|
|
@@ -310,6 +315,7 @@ src/
|
|
|
310
315
|
├── job-retry-policy-limit.strategy.ts
|
|
311
316
|
├── job-retry-policy-noop.strategy.ts
|
|
312
317
|
├── job-retry-policy.strategy.ts
|
|
318
|
+
├── job-status.vo.ts
|
|
313
319
|
├── job-worker.service.ts
|
|
314
320
|
├── job.types.ts
|
|
315
321
|
├── language-detector-cookie.strategy.ts
|
|
@@ -536,6 +542,17 @@ src/
|
|
|
536
542
|
├── shield-webhook.strategy.ts
|
|
537
543
|
├── simulated-error-hono.middleware.ts
|
|
538
544
|
├── simulated-error.middleware.ts
|
|
545
|
+
├── sitemap-changefreq.vo.ts
|
|
546
|
+
├── sitemap-entries-provider-dynamic.adapter.ts
|
|
547
|
+
├── sitemap-entries-provider-static.adapter.ts
|
|
548
|
+
├── sitemap-entries-provider-with-cache.adapter.ts
|
|
549
|
+
├── sitemap-entries-provider.port.ts
|
|
550
|
+
├── sitemap-entry.vo.ts
|
|
551
|
+
├── sitemap-hono.handler.ts
|
|
552
|
+
├── sitemap-priority.vo.ts
|
|
553
|
+
├── sitemap-url.vo.ts
|
|
554
|
+
├── sitemap.handler.ts
|
|
555
|
+
├── sitemap.service.ts
|
|
539
556
|
├── sleeper-noop.adapter.ts
|
|
540
557
|
├── sleeper-system.adapter.ts
|
|
541
558
|
├── sleeper.port.ts
|
package/src/index.ts
CHANGED
|
@@ -264,6 +264,11 @@ export * from "./job-failer.port";
|
|
|
264
264
|
export * from "./job-failer-collecting.adapter";
|
|
265
265
|
export * from "./job-failer-noop.adapter";
|
|
266
266
|
export * from "./job-failer-sqlite.adapter";
|
|
267
|
+
export * from "./job-pruner.port";
|
|
268
|
+
export * from "./job-pruner.service";
|
|
269
|
+
export * from "./job-pruner-collecting.adapter";
|
|
270
|
+
export * from "./job-pruner-noop.adapter";
|
|
271
|
+
export * from "./job-pruner-sqlite.adapter";
|
|
267
272
|
export * from "./job-queue.adapter";
|
|
268
273
|
export * from "./job-queue.port";
|
|
269
274
|
export * from "./job-queue-noop.adapter";
|
|
@@ -284,6 +289,7 @@ export * from "./job-retry-policy-composite.strategy";
|
|
|
284
289
|
export * from "./job-retry-policy-error-filter.strategy";
|
|
285
290
|
export * from "./job-retry-policy-limit.strategy";
|
|
286
291
|
export * from "./job-retry-policy-noop.strategy";
|
|
292
|
+
export * from "./job-status.vo";
|
|
287
293
|
export * from "./job-worker.service";
|
|
288
294
|
export * from "./language-detector.middleware";
|
|
289
295
|
export * from "./language-detector.strategy";
|
|
@@ -461,6 +467,17 @@ export * from "./shield-webhook.strategy";
|
|
|
461
467
|
export * from "./shield-webhook-hono.strategy";
|
|
462
468
|
export * from "./simulated-error.middleware";
|
|
463
469
|
export * from "./simulated-error-hono.middleware";
|
|
470
|
+
export * from "./sitemap.handler";
|
|
471
|
+
export * from "./sitemap.service";
|
|
472
|
+
export * from "./sitemap-changefreq.vo";
|
|
473
|
+
export * from "./sitemap-entries-provider.port";
|
|
474
|
+
export * from "./sitemap-entries-provider-dynamic.adapter";
|
|
475
|
+
export * from "./sitemap-entries-provider-static.adapter";
|
|
476
|
+
export * from "./sitemap-entries-provider-with-cache.adapter";
|
|
477
|
+
export * from "./sitemap-entry.vo";
|
|
478
|
+
export * from "./sitemap-hono.handler";
|
|
479
|
+
export * from "./sitemap-priority.vo";
|
|
480
|
+
export * from "./sitemap-url.vo";
|
|
464
481
|
export * from "./sleeper.port";
|
|
465
482
|
export * from "./sleeper-noop.adapter";
|
|
466
483
|
export * from "./sleeper-system.adapter";
|
|
@@ -3,6 +3,7 @@ import type * as tools from "@bgord/tools";
|
|
|
3
3
|
import type { ClockPort } from "./clock.port";
|
|
4
4
|
import type { GenericJob, GenericJobSerialized } from "./job.types";
|
|
5
5
|
import type { JobClaimerPort } from "./job-claimer.port";
|
|
6
|
+
import { JobStatusEnum } from "./job-status.vo";
|
|
6
7
|
|
|
7
8
|
type Dependencies = { db: Database; Clock: ClockPort };
|
|
8
9
|
|
|
@@ -20,10 +21,10 @@ export class JobClaimerSqliteAdapter implements JobClaimerPort {
|
|
|
20
21
|
GenericJobSerialized,
|
|
21
22
|
[...Array<GenericJob["name"]>, tools.TimestampValueType, tools.IntegerPositiveType]
|
|
22
23
|
>(
|
|
23
|
-
`UPDATE jobs SET status = 'claimed'
|
|
24
|
+
`UPDATE jobs SET status = '${JobStatusEnum.claimed}'
|
|
24
25
|
WHERE id IN (
|
|
25
26
|
SELECT id FROM jobs
|
|
26
|
-
WHERE status = 'pending'
|
|
27
|
+
WHERE status = '${JobStatusEnum.pending}'
|
|
27
28
|
AND name IN (${placeholders})
|
|
28
29
|
AND claimableAt <= ?
|
|
29
30
|
ORDER BY createdAt ASC
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { Database } from "bun:sqlite";
|
|
2
2
|
import type { GenericJob } from "./job.types";
|
|
3
3
|
import type { JobCompleterPort } from "./job-completer.port";
|
|
4
|
+
import { JobStatusEnum } from "./job-status.vo";
|
|
4
5
|
|
|
5
6
|
type Dependencies = { db: Database };
|
|
6
7
|
|
|
@@ -8,6 +9,9 @@ export class JobCompleterSqliteAdapter implements JobCompleterPort {
|
|
|
8
9
|
constructor(private readonly deps: Dependencies) {}
|
|
9
10
|
|
|
10
11
|
async complete(id: GenericJob["id"]): Promise<void> {
|
|
11
|
-
this.deps.db.run<[GenericJob["id"]]>(
|
|
12
|
+
this.deps.db.run<[GenericJob["id"]]>(
|
|
13
|
+
`UPDATE jobs SET status = '${JobStatusEnum.completed}' WHERE id = $id`,
|
|
14
|
+
[id],
|
|
15
|
+
);
|
|
12
16
|
}
|
|
13
17
|
}
|
|
@@ -3,6 +3,7 @@ import type * as tools from "@bgord/tools";
|
|
|
3
3
|
import type { ClockPort } from "./clock.port";
|
|
4
4
|
import type { GenericJobSerialized } from "./job.types";
|
|
5
5
|
import type { JobEnqueuerPort } from "./job-enqueuer.port";
|
|
6
|
+
import { JobStatusEnum } from "./job-status.vo";
|
|
6
7
|
|
|
7
8
|
type Dependencies = { db: Database; Clock: ClockPort };
|
|
8
9
|
|
|
@@ -24,7 +25,7 @@ export class JobEnqueuerSqliteAdapter implements JobEnqueuerPort {
|
|
|
24
25
|
]
|
|
25
26
|
>(
|
|
26
27
|
`INSERT INTO jobs (id, correlationId, createdAt, name, revision, payload, status, claimableAt)
|
|
27
|
-
VALUES (?, ?, ?, ?, ?, ?, 'pending', ?)`,
|
|
28
|
+
VALUES (?, ?, ?, ?, ?, ?, '${JobStatusEnum.pending}', ?)`,
|
|
28
29
|
[job.id, job.correlationId, job.createdAt, job.name, job.revision, job.payload, claimableAt.ms],
|
|
29
30
|
);
|
|
30
31
|
|