@tyravel/core 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/adapters/node-server.d.ts +7 -0
- package/dist/adapters/node-server.d.ts.map +1 -0
- package/dist/adapters/node-server.js +78 -0
- package/dist/adapters/node-server.js.map +1 -0
- package/dist/application.d.ts +23 -0
- package/dist/application.d.ts.map +1 -0
- package/dist/application.js +65 -0
- package/dist/application.js.map +1 -0
- package/dist/application.test.d.ts +2 -0
- package/dist/application.test.d.ts.map +1 -0
- package/dist/application.test.js +29 -0
- package/dist/application.test.js.map +1 -0
- package/dist/auth-service-provider.d.ts +6 -0
- package/dist/auth-service-provider.d.ts.map +1 -0
- package/dist/auth-service-provider.js +71 -0
- package/dist/auth-service-provider.js.map +1 -0
- package/dist/auth.d.ts +14 -0
- package/dist/auth.d.ts.map +1 -0
- package/dist/auth.js +32 -0
- package/dist/auth.js.map +1 -0
- package/dist/cache-service-provider.d.ts +5 -0
- package/dist/cache-service-provider.d.ts.map +1 -0
- package/dist/cache-service-provider.js +14 -0
- package/dist/cache-service-provider.js.map +1 -0
- package/dist/cache.d.ts +12 -0
- package/dist/cache.d.ts.map +1 -0
- package/dist/cache.js +19 -0
- package/dist/cache.js.map +1 -0
- package/dist/config-service-provider.d.ts +5 -0
- package/dist/config-service-provider.d.ts.map +1 -0
- package/dist/config-service-provider.js +11 -0
- package/dist/config-service-provider.js.map +1 -0
- package/dist/config-service-provider.test.d.ts +2 -0
- package/dist/config-service-provider.test.d.ts.map +1 -0
- package/dist/config-service-provider.test.js +27 -0
- package/dist/config-service-provider.test.js.map +1 -0
- package/dist/controller.d.ts +8 -0
- package/dist/controller.d.ts.map +1 -0
- package/dist/controller.js +30 -0
- package/dist/controller.js.map +1 -0
- package/dist/controller.test.d.ts +2 -0
- package/dist/controller.test.d.ts.map +1 -0
- package/dist/controller.test.js +34 -0
- package/dist/controller.test.js.map +1 -0
- package/dist/database-service-provider.d.ts +5 -0
- package/dist/database-service-provider.d.ts.map +1 -0
- package/dist/database-service-provider.js +14 -0
- package/dist/database-service-provider.js.map +1 -0
- package/dist/event.d.ts +11 -0
- package/dist/event.d.ts.map +1 -0
- package/dist/event.js +22 -0
- package/dist/event.js.map +1 -0
- package/dist/events-service-provider.d.ts +8 -0
- package/dist/events-service-provider.d.ts.map +1 -0
- package/dist/events-service-provider.js +68 -0
- package/dist/events-service-provider.js.map +1 -0
- package/dist/events-service-provider.test.d.ts +2 -0
- package/dist/events-service-provider.test.d.ts.map +1 -0
- package/dist/events-service-provider.test.js +30 -0
- package/dist/events-service-provider.test.js.map +1 -0
- package/dist/gate.d.ts +10 -0
- package/dist/gate.d.ts.map +1 -0
- package/dist/gate.js +16 -0
- package/dist/gate.js.map +1 -0
- package/dist/http-kernel.d.ts +7 -0
- package/dist/http-kernel.d.ts.map +1 -0
- package/dist/http-kernel.js +45 -0
- package/dist/http-kernel.js.map +1 -0
- package/dist/index.d.ts +43 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +29 -0
- package/dist/index.js.map +1 -0
- package/dist/mail-service-provider.d.ts +7 -0
- package/dist/mail-service-provider.d.ts.map +1 -0
- package/dist/mail-service-provider.js +49 -0
- package/dist/mail-service-provider.js.map +1 -0
- package/dist/mail.d.ts +10 -0
- package/dist/mail.d.ts.map +1 -0
- package/dist/mail.js +16 -0
- package/dist/mail.js.map +1 -0
- package/dist/notification-service-provider.d.ts +8 -0
- package/dist/notification-service-provider.d.ts.map +1 -0
- package/dist/notification-service-provider.js +71 -0
- package/dist/notification-service-provider.js.map +1 -0
- package/dist/notifications.d.ts +9 -0
- package/dist/notifications.d.ts.map +1 -0
- package/dist/notifications.js +9 -0
- package/dist/notifications.js.map +1 -0
- package/dist/password.d.ts +12 -0
- package/dist/password.d.ts.map +1 -0
- package/dist/password.js +15 -0
- package/dist/password.js.map +1 -0
- package/dist/queue-service-provider.d.ts +7 -0
- package/dist/queue-service-provider.d.ts.map +1 -0
- package/dist/queue-service-provider.js +49 -0
- package/dist/queue-service-provider.js.map +1 -0
- package/dist/queue.d.ts +15 -0
- package/dist/queue.d.ts.map +1 -0
- package/dist/queue.js +29 -0
- package/dist/queue.js.map +1 -0
- package/dist/route.d.ts +22 -0
- package/dist/route.d.ts.map +1 -0
- package/dist/route.js +28 -0
- package/dist/route.js.map +1 -0
- package/dist/server.d.ts +7 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +18 -0
- package/dist/server.js.map +1 -0
- package/dist/service-provider.d.ts +8 -0
- package/dist/service-provider.d.ts.map +1 -0
- package/dist/service-provider.js +9 -0
- package/dist/service-provider.js.map +1 -0
- package/dist/view-service-provider.d.ts +5 -0
- package/dist/view-service-provider.d.ts.map +1 -0
- package/dist/view-service-provider.js +16 -0
- package/dist/view-service-provider.js.map +1 -0
- package/dist/view.d.ts +9 -0
- package/dist/view.d.ts.map +1 -0
- package/dist/view.js +15 -0
- package/dist/view.js.map +1 -0
- package/package.json +47 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { Response } from '@tyravel/http';
|
|
3
|
+
import { Application } from './application.js';
|
|
4
|
+
import { createControllerHandler } from './controller.js';
|
|
5
|
+
import { HttpKernel } from './http-kernel.js';
|
|
6
|
+
import { Route, setRouteApplication } from './route.js';
|
|
7
|
+
class UserController {
|
|
8
|
+
index() {
|
|
9
|
+
return Response.json({ users: [] });
|
|
10
|
+
}
|
|
11
|
+
show(request) {
|
|
12
|
+
return Response.json({ id: request.param('id') });
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
describe('Controller resolution', () => {
|
|
16
|
+
it('dispatches controller actions through the container', async () => {
|
|
17
|
+
const app = new Application();
|
|
18
|
+
setRouteApplication(app);
|
|
19
|
+
Route.get('/users', [UserController, 'index']);
|
|
20
|
+
Route.get('/users/:id', [UserController, 'show']);
|
|
21
|
+
const kernel = new HttpKernel(app);
|
|
22
|
+
const indexResponse = await kernel.handle(new Request('http://localhost/users'));
|
|
23
|
+
const showResponse = await kernel.handle(new Request('http://localhost/users/7'));
|
|
24
|
+
expect(await indexResponse.json()).toEqual({ users: [] });
|
|
25
|
+
expect(await showResponse.json()).toEqual({ id: '7' });
|
|
26
|
+
});
|
|
27
|
+
it('creates a route handler from a controller tuple', async () => {
|
|
28
|
+
const app = new Application();
|
|
29
|
+
const handler = createControllerHandler(app, [UserController, 'index']);
|
|
30
|
+
const response = await handler(new Request('http://localhost'));
|
|
31
|
+
expect(await response.json()).toEqual({ users: [] });
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=controller.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"controller.test.js","sourceRoot":"","sources":["../src/controller.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEzC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAExD,MAAM,cAAc;IAClB,KAAK;QACH,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;IACtC,CAAC;IAED,IAAI,CAAC,OAAuB;QAC1B,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACpD,CAAC;CACF;AAED,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC;QAC9B,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAEzB,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC;QAC/C,KAAK,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC,CAAC;QAElD,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,aAAa,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,wBAAwB,CAAC,CAAC,CAAC;QACjF,MAAM,YAAY,GAAG,MAAM,MAAM,CAAC,MAAM,CACtC,IAAI,OAAO,CAAC,0BAA0B,CAAC,CACxC,CAAC;QAEF,MAAM,CAAC,MAAM,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAC1D,MAAM,CAAC,MAAM,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC;QAC9B,MAAM,OAAO,GAAG,uBAAuB,CAAC,GAAG,EAAE,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC;QACxE,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,IAAI,OAAO,CAAC,kBAAkB,CAAU,CAAC,CAAC;QAEzE,MAAM,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database-service-provider.d.ts","sourceRoot":"","sources":["../src/database-service-provider.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,qBAAa,uBAAwB,SAAQ,eAAe;IACjD,QAAQ;CAWlB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { DatabaseManager, Model } from '@tyravel/database';
|
|
2
|
+
import { ServiceProvider } from './service-provider.js';
|
|
3
|
+
export class DatabaseServiceProvider extends ServiceProvider {
|
|
4
|
+
register() {
|
|
5
|
+
const config = this.app.make('config');
|
|
6
|
+
const databaseConfig = config.get('database');
|
|
7
|
+
const manager = new DatabaseManager(databaseConfig, this.app.basePath);
|
|
8
|
+
this.app.instance('db', manager);
|
|
9
|
+
this.app.singleton(DatabaseManager, () => manager);
|
|
10
|
+
const connection = manager.connection();
|
|
11
|
+
Model.setConnectionResolver(() => connection);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=database-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database-service-provider.js","sourceRoot":"","sources":["../src/database-service-provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE3D,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,MAAM,OAAO,uBAAwB,SAAQ,eAAe;IACjD,QAAQ;QACf,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAmB,QAAQ,CAAC,CAAC;QACzD,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,CAAiB,UAAU,CAAC,CAAC;QAC9D,MAAM,OAAO,GAAG,IAAI,eAAe,CAAC,cAAc,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAEvE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACjC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC;QAEnD,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QACxC,KAAK,CAAC,qBAAqB,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,CAAC;IAChD,CAAC;CACF"}
|
package/dist/event.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Event, EventConstructor, EventDispatcher, ListenerHandler } from '@tyravel/events';
|
|
2
|
+
import type { Application } from './application.js';
|
|
3
|
+
export declare function setEventApplication(app: Application): void;
|
|
4
|
+
export interface EventsFacade {
|
|
5
|
+
listen<TEvent extends Event>(event: EventConstructor<TEvent>, handler: ListenerHandler<TEvent>): EventDispatcher;
|
|
6
|
+
dispatch<TEvent extends Event>(event: TEvent): Promise<void>;
|
|
7
|
+
dispatchUntil<TEvent extends Event>(event: TEvent, predicate: (event: TEvent) => boolean): Promise<boolean>;
|
|
8
|
+
}
|
|
9
|
+
export declare const Events: EventsFacade;
|
|
10
|
+
export declare function fire<T extends Event>(instance: T): Promise<void>;
|
|
11
|
+
//# sourceMappingURL=event.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.d.ts","sourceRoot":"","sources":["../src/event.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,KAAK,EACL,gBAAgB,EAChB,eAAe,EACf,eAAe,EAChB,MAAM,iBAAiB,CAAC;AACzB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAIpD,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,WAAW,GAAG,IAAI,CAE1D;AAeD,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,MAAM,SAAS,KAAK,EACzB,KAAK,EAAE,gBAAgB,CAAC,MAAM,CAAC,EAC/B,OAAO,EAAE,eAAe,CAAC,MAAM,CAAC,GAC/B,eAAe,CAAC;IACnB,QAAQ,CAAC,MAAM,SAAS,KAAK,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7D,aAAa,CAAC,MAAM,SAAS,KAAK,EAChC,KAAK,EAAE,MAAM,EACb,SAAS,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,GACpC,OAAO,CAAC,OAAO,CAAC,CAAC;CACrB;AAED,eAAO,MAAM,MAAM,EAAE,YAIpB,CAAC;AAEF,wBAAsB,IAAI,CAAC,CAAC,SAAS,KAAK,EAAE,QAAQ,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAEtE"}
|
package/dist/event.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
let activeApp;
|
|
2
|
+
export function setEventApplication(app) {
|
|
3
|
+
activeApp = app;
|
|
4
|
+
}
|
|
5
|
+
function application() {
|
|
6
|
+
if (!activeApp) {
|
|
7
|
+
throw new Error('Events facade is not ready. Boot the application before dispatching events.');
|
|
8
|
+
}
|
|
9
|
+
return activeApp;
|
|
10
|
+
}
|
|
11
|
+
function dispatcher() {
|
|
12
|
+
return application().make('events');
|
|
13
|
+
}
|
|
14
|
+
export const Events = {
|
|
15
|
+
listen: (event, handler) => dispatcher().listen(event, handler),
|
|
16
|
+
dispatch: (event) => dispatcher().dispatch(event),
|
|
17
|
+
dispatchUntil: (event, predicate) => dispatcher().dispatchUntil(event, predicate),
|
|
18
|
+
};
|
|
19
|
+
export async function fire(instance) {
|
|
20
|
+
return Events.dispatch(instance);
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=event.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.js","sourceRoot":"","sources":["../src/event.ts"],"names":[],"mappings":"AAQA,IAAI,SAAkC,CAAC;AAEvC,MAAM,UAAU,mBAAmB,CAAC,GAAgB;IAClD,SAAS,GAAG,GAAG,CAAC;AAClB,CAAC;AAED,SAAS,WAAW;IAClB,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CACb,6EAA6E,CAC9E,CAAC;IACJ,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,SAAS,UAAU;IACjB,OAAO,WAAW,EAAE,CAAC,IAAI,CAAkB,QAAQ,CAAC,CAAC;AACvD,CAAC;AAcD,MAAM,CAAC,MAAM,MAAM,GAAiB;IAClC,MAAM,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,UAAU,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC;IAC/D,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC;IACjD,aAAa,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC,UAAU,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,CAAC;CAClF,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,IAAI,CAAkB,QAAW;IACrD,OAAO,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AACnC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ServiceProvider } from './service-provider.js';
|
|
2
|
+
export declare class EventServiceProvider extends ServiceProvider {
|
|
3
|
+
register(): void;
|
|
4
|
+
boot(): void;
|
|
5
|
+
private registerQueuedListenerJob;
|
|
6
|
+
private createQueueBridge;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=events-service-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-service-provider.d.ts","sourceRoot":"","sources":["../src/events-service-provider.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,qBAAa,oBAAqB,SAAQ,eAAe;IAC9C,QAAQ;IA4BR,IAAI;IAab,OAAO,CAAC,yBAAyB;IASjC,OAAO,CAAC,iBAAiB;CAqB1B"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { CallQueuedListener, EventDispatcher, EventRegistry, ListenerRegistry, registerEventsConfig, setQueuedListenerContext, } from '@tyravel/events';
|
|
2
|
+
import { Dispatcher } from '@tyravel/queue';
|
|
3
|
+
import { ServiceProvider } from './service-provider.js';
|
|
4
|
+
export class EventServiceProvider extends ServiceProvider {
|
|
5
|
+
register() {
|
|
6
|
+
const eventRegistry = new EventRegistry();
|
|
7
|
+
const listenerRegistry = new ListenerRegistry();
|
|
8
|
+
const queueBridge = this.createQueueBridge();
|
|
9
|
+
const dispatcher = new EventDispatcher({
|
|
10
|
+
container: this.app,
|
|
11
|
+
eventRegistry,
|
|
12
|
+
listenerRegistry,
|
|
13
|
+
queue: queueBridge,
|
|
14
|
+
});
|
|
15
|
+
this.app.instance('events.registry', eventRegistry);
|
|
16
|
+
this.app.singleton(EventRegistry, () => eventRegistry);
|
|
17
|
+
this.app.instance('events.listeners', listenerRegistry);
|
|
18
|
+
this.app.singleton(ListenerRegistry, () => listenerRegistry);
|
|
19
|
+
this.app.instance('events', dispatcher);
|
|
20
|
+
this.app.singleton(EventDispatcher, () => dispatcher);
|
|
21
|
+
setQueuedListenerContext({
|
|
22
|
+
container: this.app,
|
|
23
|
+
events: eventRegistry,
|
|
24
|
+
listeners: listenerRegistry,
|
|
25
|
+
});
|
|
26
|
+
this.registerQueuedListenerJob();
|
|
27
|
+
}
|
|
28
|
+
boot() {
|
|
29
|
+
const config = this.app.make('config');
|
|
30
|
+
const eventsConfig = config.get('events', { listen: [] });
|
|
31
|
+
const dispatcher = this.app.make('events');
|
|
32
|
+
dispatcher.setQueueDefaults({
|
|
33
|
+
connection: eventsConfig.queueConnection,
|
|
34
|
+
queue: eventsConfig.queue,
|
|
35
|
+
});
|
|
36
|
+
registerEventsConfig(dispatcher, eventsConfig, this.app);
|
|
37
|
+
}
|
|
38
|
+
registerQueuedListenerJob() {
|
|
39
|
+
try {
|
|
40
|
+
const jobs = this.app.make('jobs.registry');
|
|
41
|
+
jobs.register(CallQueuedListener);
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
// Queue provider not registered.
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
createQueueBridge() {
|
|
48
|
+
try {
|
|
49
|
+
const manager = this.app.make('queue');
|
|
50
|
+
return {
|
|
51
|
+
dispatch: async (job, options) => {
|
|
52
|
+
const connection = manager.connection(options.connection);
|
|
53
|
+
const dispatcher = new Dispatcher(connection);
|
|
54
|
+
const delaySeconds = options.delaySeconds ?? 0;
|
|
55
|
+
if (delaySeconds > 0) {
|
|
56
|
+
await dispatcher.dispatchLater(delaySeconds, job, options.queue);
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
await dispatcher.dispatch(job, options.queue);
|
|
60
|
+
},
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
catch {
|
|
64
|
+
return undefined;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=events-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-service-provider.js","sourceRoot":"","sources":["../src/events-service-provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-service-provider.test.d.ts","sourceRoot":"","sources":["../src/events-service-provider.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { ConfigRepository } from '@tyravel/config';
|
|
3
|
+
import { Event, Listener } from '@tyravel/events';
|
|
4
|
+
import { Application } from './application.js';
|
|
5
|
+
import { EventServiceProvider } from './events-service-provider.js';
|
|
6
|
+
class SampleEvent extends Event {
|
|
7
|
+
}
|
|
8
|
+
class SampleListener extends Listener {
|
|
9
|
+
static count = 0;
|
|
10
|
+
async handle() {
|
|
11
|
+
SampleListener.count += 1;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
describe('EventServiceProvider', () => {
|
|
15
|
+
it('loads listener mappings from config during boot', async () => {
|
|
16
|
+
SampleListener.count = 0;
|
|
17
|
+
const app = new Application('/tmp/tyravel-events-test');
|
|
18
|
+
const config = new ConfigRepository({
|
|
19
|
+
events: {
|
|
20
|
+
listen: [[SampleEvent, [SampleListener]]],
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
app.instance('config', config);
|
|
24
|
+
app.register(EventServiceProvider);
|
|
25
|
+
await app.boot();
|
|
26
|
+
await app.make('events').dispatch(new SampleEvent({ ok: true }));
|
|
27
|
+
expect(SampleListener.count).toBe(1);
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
//# sourceMappingURL=events-service-provider.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-service-provider.test.js","sourceRoot":"","sources":["../src/events-service-provider.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAM,MAAM,QAAQ,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AAEpE,MAAM,WAAY,SAAQ,KAAsB;CAAG;AAEnD,MAAM,cAAe,SAAQ,QAAqB;IAChD,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;IAER,KAAK,CAAC,MAAM;QACnB,cAAc,CAAC,KAAK,IAAI,CAAC,CAAC;IAC5B,CAAC;;AAGH,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC;QAEzB,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,0BAA0B,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,IAAI,gBAAgB,CAAC;YAClC,MAAM,EAAE;gBACN,MAAM,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;aAC1C;SACF,CAAC,CAAC;QAEH,GAAG,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAC/B,GAAG,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC;QACnC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QAEjB,MAAM,GAAG,CAAC,IAAI,CAA4C,QAAQ,CAAC,CAAC,QAAQ,CAC1E,IAAI,WAAW,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAC9B,CAAC;QAEF,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/dist/gate.d.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Application } from './application.js';
|
|
2
|
+
import type { Authenticatable } from '@tyravel/auth';
|
|
3
|
+
export declare function setGateApplication(app: Application): void;
|
|
4
|
+
export interface GateFacade {
|
|
5
|
+
allows(user: Authenticatable | null, ability: string, model?: unknown): Promise<boolean>;
|
|
6
|
+
authorize(user: Authenticatable | null, ability: string, model?: unknown): Promise<void>;
|
|
7
|
+
denyUnless(user: Authenticatable | null, ability: string, model?: unknown): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
export declare const Gate: GateFacade;
|
|
10
|
+
//# sourceMappingURL=gate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gate.d.ts","sourceRoot":"","sources":["../src/gate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEpD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAIrD,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,WAAW,GAAG,IAAI,CAEzD;AASD,MAAM,WAAW,UAAU;IACzB,MAAM,CAAC,IAAI,EAAE,eAAe,GAAG,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IACzF,SAAS,CAAC,IAAI,EAAE,eAAe,GAAG,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzF,UAAU,CAAC,IAAI,EAAE,eAAe,GAAG,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3F;AAED,eAAO,MAAM,IAAI,EAAE,UAIlB,CAAC"}
|
package/dist/gate.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
let gateApplication;
|
|
2
|
+
export function setGateApplication(app) {
|
|
3
|
+
gateApplication = app;
|
|
4
|
+
}
|
|
5
|
+
function resolveGate() {
|
|
6
|
+
if (!gateApplication) {
|
|
7
|
+
throw new Error('Gate facade requires setGateApplication(app) during bootstrap.');
|
|
8
|
+
}
|
|
9
|
+
return gateApplication.make('gate');
|
|
10
|
+
}
|
|
11
|
+
export const Gate = {
|
|
12
|
+
allows: (user, ability, model) => resolveGate().allows(user, ability, model),
|
|
13
|
+
authorize: (user, ability, model) => resolveGate().authorize(user, ability, model),
|
|
14
|
+
denyUnless: (user, ability, model) => resolveGate().denyUnless(user, ability, model),
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=gate.js.map
|
package/dist/gate.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gate.js","sourceRoot":"","sources":["../src/gate.ts"],"names":[],"mappings":"AAIA,IAAI,eAAwC,CAAC;AAE7C,MAAM,UAAU,kBAAkB,CAAC,GAAgB;IACjD,eAAe,GAAG,GAAG,CAAC;AACxB,CAAC;AAED,SAAS,WAAW;IAClB,IAAI,CAAC,eAAe,EAAE,CAAC;QACrB,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAC;IACpF,CAAC;IACD,OAAO,eAAe,CAAC,IAAI,CAAoB,MAAM,CAAC,CAAC;AACzD,CAAC;AAQD,MAAM,CAAC,MAAM,IAAI,GAAe;IAC9B,MAAM,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC;IAC5E,SAAS,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC;IAClF,UAAU,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC;CACrF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-kernel.d.ts","sourceRoot":"","sources":["../src/http-kernel.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEpD,qBAAa,UAAU;IACT,OAAO,CAAC,QAAQ,CAAC,GAAG;gBAAH,GAAG,EAAE,WAAW;IAEvC,MAAM,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC;CAuClD"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { RouteNotFoundException } from '@tyravel/http';
|
|
2
|
+
import { Response } from '@tyravel/http';
|
|
3
|
+
import { ValidationException } from '@tyravel/validation';
|
|
4
|
+
import { AuthenticationException } from '@tyravel/auth';
|
|
5
|
+
import { InvalidCredentialsException } from '@tyravel/auth';
|
|
6
|
+
import { AuthorizationException } from '@tyravel/auth';
|
|
7
|
+
import { InvalidResetTokenException } from '@tyravel/auth';
|
|
8
|
+
export class HttpKernel {
|
|
9
|
+
app;
|
|
10
|
+
constructor(app) {
|
|
11
|
+
this.app = app;
|
|
12
|
+
}
|
|
13
|
+
async handle(request) {
|
|
14
|
+
try {
|
|
15
|
+
return await this.app.router().dispatch(request);
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
if (error instanceof RouteNotFoundException) {
|
|
19
|
+
return Response.json({ message: error.message }, { status: 404 });
|
|
20
|
+
}
|
|
21
|
+
if (error instanceof ValidationException) {
|
|
22
|
+
const validationError = error;
|
|
23
|
+
return Response.json({
|
|
24
|
+
message: validationError.message,
|
|
25
|
+
errors: validationError.errors,
|
|
26
|
+
}, { status: 422 });
|
|
27
|
+
}
|
|
28
|
+
if (error instanceof AuthenticationException) {
|
|
29
|
+
return Response.json({ message: error.message }, { status: 401 });
|
|
30
|
+
}
|
|
31
|
+
if (error instanceof InvalidCredentialsException) {
|
|
32
|
+
return Response.json({ message: error.message }, { status: 401 });
|
|
33
|
+
}
|
|
34
|
+
if (error instanceof AuthorizationException) {
|
|
35
|
+
return Response.json({ message: error.message }, { status: 403 });
|
|
36
|
+
}
|
|
37
|
+
if (error instanceof InvalidResetTokenException) {
|
|
38
|
+
return Response.json({ message: error.message }, { status: 422 });
|
|
39
|
+
}
|
|
40
|
+
console.error(error);
|
|
41
|
+
return Response.json({ message: 'Server Error' }, { status: 500 });
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=http-kernel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-kernel.js","sourceRoot":"","sources":["../src/http-kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,2BAA2B,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,eAAe,CAAC;AAG3D,MAAM,OAAO,UAAU;IACQ;IAA7B,YAA6B,GAAgB;QAAhB,QAAG,GAAH,GAAG,CAAa;IAAG,CAAC;IAEjD,KAAK,CAAC,MAAM,CAAC,OAAgB;QAC3B,IAAI,CAAC;YACH,OAAO,MAAM,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACnD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,sBAAsB,EAAE,CAAC;gBAC5C,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACpE,CAAC;YAED,IAAI,KAAK,YAAY,mBAAmB,EAAE,CAAC;gBACzC,MAAM,eAAe,GAAG,KAA4B,CAAC;gBACrD,OAAO,QAAQ,CAAC,IAAI,CAClB;oBACE,OAAO,EAAE,eAAe,CAAC,OAAO;oBAChC,MAAM,EAAE,eAAe,CAAC,MAAM;iBAC/B,EACD,EAAE,MAAM,EAAE,GAAG,EAAE,CAChB,CAAC;YACJ,CAAC;YAED,IAAI,KAAK,YAAY,uBAAuB,EAAE,CAAC;gBAC7C,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACpE,CAAC;YAED,IAAI,KAAK,YAAY,2BAA2B,EAAE,CAAC;gBACjD,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACpE,CAAC;YAED,IAAI,KAAK,YAAY,sBAAsB,EAAE,CAAC;gBAC5C,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACpE,CAAC;YAED,IAAI,KAAK,YAAY,0BAA0B,EAAE,CAAC;gBAChD,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACpE,CAAC;YAED,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACrB,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;CACF"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export { AuthServiceProvider } from './auth-service-provider.js';
|
|
2
|
+
export { CacheServiceProvider } from './cache-service-provider.js';
|
|
3
|
+
export { MailServiceProvider } from './mail-service-provider.js';
|
|
4
|
+
export { NotificationServiceProvider } from './notification-service-provider.js';
|
|
5
|
+
export { Application } from './application.js';
|
|
6
|
+
export { ConfigServiceProvider } from './config-service-provider.js';
|
|
7
|
+
export { DatabaseServiceProvider } from './database-service-provider.js';
|
|
8
|
+
export { EventServiceProvider } from './events-service-provider.js';
|
|
9
|
+
export { QueueServiceProvider } from './queue-service-provider.js';
|
|
10
|
+
export { ViewServiceProvider } from './view-service-provider.js';
|
|
11
|
+
export { View, setViewApplication } from './view.js';
|
|
12
|
+
export type { ViewFacade } from './view.js';
|
|
13
|
+
export { createControllerHandler, isControllerAction, } from './controller.js';
|
|
14
|
+
export type { ControllerAction, ControllerConstructor } from './controller.js';
|
|
15
|
+
export { HttpKernel } from './http-kernel.js';
|
|
16
|
+
export { Route, setRouteApplication } from './route.js';
|
|
17
|
+
export type { RouteFacade } from './route.js';
|
|
18
|
+
export { Auth, setAuthApplication } from './auth.js';
|
|
19
|
+
export type { AuthFacade } from './auth.js';
|
|
20
|
+
export { Gate, setGateApplication } from './gate.js';
|
|
21
|
+
export type { GateFacade } from './gate.js';
|
|
22
|
+
export { Password, setPasswordApplication } from './password.js';
|
|
23
|
+
export type { PasswordFacade } from './password.js';
|
|
24
|
+
export { Events, fire, setEventApplication } from './event.js';
|
|
25
|
+
export type { EventsFacade } from './event.js';
|
|
26
|
+
export { Queue, dispatch, setQueueApplication } from './queue.js';
|
|
27
|
+
export type { QueueConnectionFacade, QueueFacade } from './queue.js';
|
|
28
|
+
export { Cache, setCacheApplication } from './cache.js';
|
|
29
|
+
export type { CacheFacade } from './cache.js';
|
|
30
|
+
export { Mail, setMailApplication } from './mail.js';
|
|
31
|
+
export type { MailFacade } from './mail.js';
|
|
32
|
+
export { Notifications, setNotificationApplication } from './notifications.js';
|
|
33
|
+
export type { NotificationsFacade } from './notifications.js';
|
|
34
|
+
export { serve } from './server.js';
|
|
35
|
+
export type { ServeOptions } from './server.js';
|
|
36
|
+
export { ServiceProvider } from './service-provider.js';
|
|
37
|
+
export { Event, EventSubscriber, Listener, EventDispatcher, QueuedListener } from '@tyravel/events';
|
|
38
|
+
export type { EventConstructor, EventListenerRegistration, EventSubscriberConstructor, EventsConfig, ListenerCallback, ListenerConstructor, ListenerHandler, } from '@tyravel/events';
|
|
39
|
+
export type { Authenticatable, AuthConfig, NewAccessToken } from '@tyravel/auth';
|
|
40
|
+
export { AuthenticationException, InvalidCredentialsException, AuthorizationException, InvalidResetTokenException, Policy, OAuthManager, PasswordResetBroker, PersonalAccessTokenRepository, Gate as AuthorizationGate, } from '@tyravel/auth';
|
|
41
|
+
export { Mailable, SendMailable } from '@tyravel/mail';
|
|
42
|
+
export { Notification, type Notifiable, NotificationRegistry } from '@tyravel/notifications';
|
|
43
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export { AuthServiceProvider } from './auth-service-provider.js';
|
|
2
|
+
export { CacheServiceProvider } from './cache-service-provider.js';
|
|
3
|
+
export { MailServiceProvider } from './mail-service-provider.js';
|
|
4
|
+
export { NotificationServiceProvider } from './notification-service-provider.js';
|
|
5
|
+
export { Application } from './application.js';
|
|
6
|
+
export { ConfigServiceProvider } from './config-service-provider.js';
|
|
7
|
+
export { DatabaseServiceProvider } from './database-service-provider.js';
|
|
8
|
+
export { EventServiceProvider } from './events-service-provider.js';
|
|
9
|
+
export { QueueServiceProvider } from './queue-service-provider.js';
|
|
10
|
+
export { ViewServiceProvider } from './view-service-provider.js';
|
|
11
|
+
export { View, setViewApplication } from './view.js';
|
|
12
|
+
export { createControllerHandler, isControllerAction, } from './controller.js';
|
|
13
|
+
export { HttpKernel } from './http-kernel.js';
|
|
14
|
+
export { Route, setRouteApplication } from './route.js';
|
|
15
|
+
export { Auth, setAuthApplication } from './auth.js';
|
|
16
|
+
export { Gate, setGateApplication } from './gate.js';
|
|
17
|
+
export { Password, setPasswordApplication } from './password.js';
|
|
18
|
+
export { Events, fire, setEventApplication } from './event.js';
|
|
19
|
+
export { Queue, dispatch, setQueueApplication } from './queue.js';
|
|
20
|
+
export { Cache, setCacheApplication } from './cache.js';
|
|
21
|
+
export { Mail, setMailApplication } from './mail.js';
|
|
22
|
+
export { Notifications, setNotificationApplication } from './notifications.js';
|
|
23
|
+
export { serve } from './server.js';
|
|
24
|
+
export { ServiceProvider } from './service-provider.js';
|
|
25
|
+
export { Event, EventSubscriber, Listener, EventDispatcher, QueuedListener } from '@tyravel/events';
|
|
26
|
+
export { AuthenticationException, InvalidCredentialsException, AuthorizationException, InvalidResetTokenException, Policy, OAuthManager, PasswordResetBroker, PersonalAccessTokenRepository, Gate as AuthorizationGate, } from '@tyravel/auth';
|
|
27
|
+
export { Mailable, SendMailable } from '@tyravel/mail';
|
|
28
|
+
export { Notification, NotificationRegistry } from '@tyravel/notifications';
|
|
29
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,2BAA2B,EAAE,MAAM,oCAAoC,CAAC;AACjF,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AACrE,OAAO,EAAE,uBAAuB,EAAE,MAAM,gCAAgC,CAAC;AACzE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,IAAI,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAErD,OAAO,EACL,uBAAuB,EACvB,kBAAkB,GACnB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAExD,OAAO,EAAE,IAAI,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAErD,OAAO,EAAE,IAAI,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAErD,OAAO,EAAE,QAAQ,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AAEjE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAE/D,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAElE,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAExD,OAAO,EAAE,IAAI,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAErD,OAAO,EAAE,aAAa,EAAE,0BAA0B,EAAE,MAAM,oBAAoB,CAAC;AAE/E,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,QAAQ,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAWpG,OAAO,EACL,uBAAuB,EACvB,2BAA2B,EAC3B,sBAAsB,EACtB,0BAA0B,EAC1B,MAAM,EACN,YAAY,EACZ,mBAAmB,EACnB,6BAA6B,EAC7B,IAAI,IAAI,iBAAiB,GAC1B,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,YAAY,EAAmB,oBAAoB,EAAE,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mail-service-provider.d.ts","sourceRoot":"","sources":["../src/mail-service-provider.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,qBAAa,mBAAoB,SAAQ,eAAe;IAC7C,QAAQ;IAkBjB,OAAO,CAAC,iBAAiB;IAuBzB,OAAO,CAAC,uBAAuB;CAQhC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { MailManager, SendMailable, setQueuedMailContext } from '@tyravel/mail';
|
|
2
|
+
import { Dispatcher } from '@tyravel/queue';
|
|
3
|
+
import { ServiceProvider } from './service-provider.js';
|
|
4
|
+
export class MailServiceProvider extends ServiceProvider {
|
|
5
|
+
register() {
|
|
6
|
+
const config = this.app.make('config');
|
|
7
|
+
const mailConfig = config.get('mail');
|
|
8
|
+
const queueBridge = this.createQueueBridge();
|
|
9
|
+
const manager = new MailManager(mailConfig, queueBridge);
|
|
10
|
+
manager.setQueueDefaults({
|
|
11
|
+
connection: mailConfig.queueConnection,
|
|
12
|
+
queue: mailConfig.queue,
|
|
13
|
+
});
|
|
14
|
+
this.app.instance('mail', manager);
|
|
15
|
+
this.app.singleton(MailManager, () => manager);
|
|
16
|
+
setQueuedMailContext({ manager });
|
|
17
|
+
this.registerSendMailableJob();
|
|
18
|
+
}
|
|
19
|
+
createQueueBridge() {
|
|
20
|
+
try {
|
|
21
|
+
const manager = this.app.make('queue');
|
|
22
|
+
return {
|
|
23
|
+
dispatch: async (job, options = {}) => {
|
|
24
|
+
const connection = manager.connection(options.connection);
|
|
25
|
+
const dispatcher = new Dispatcher(connection);
|
|
26
|
+
const delay = options.delaySeconds ?? 0;
|
|
27
|
+
if (delay > 0) {
|
|
28
|
+
await dispatcher.dispatchLater(delay, job, options.queue);
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
await dispatcher.dispatch(job, options.queue);
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
return undefined;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
registerSendMailableJob() {
|
|
40
|
+
try {
|
|
41
|
+
const jobs = this.app.make('jobs.registry');
|
|
42
|
+
jobs.register(SendMailable);
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
// Queue provider not registered.
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=mail-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mail-service-provider.js","sourceRoot":"","sources":["../src/mail-service-provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,oBAAoB,EAAyC,MAAM,eAAe,CAAC;AACvH,OAAO,EAAE,UAAU,EAA6B,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,MAAM,OAAO,mBAAoB,SAAQ,eAAe;IAC7C,QAAQ;QACf,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAmB,QAAQ,CAAC,CAAC;QACzD,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAa,MAAM,CAAC,CAAC;QAClD,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7C,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QAEzD,OAAO,CAAC,gBAAgB,CAAC;YACvB,UAAU,EAAE,UAAU,CAAC,eAAe;YACtC,KAAK,EAAE,UAAU,CAAC,KAAK;SACxB,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACnC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC;QAC/C,oBAAoB,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;QAElC,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAe,OAAO,CAAC,CAAC;YACrD,OAAO;gBACL,QAAQ,EAAE,KAAK,EACb,GAAQ,EACR,UAA0E,EAAE,EAC5E,EAAE;oBACF,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;oBAC1D,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC;oBAC9C,MAAM,KAAK,GAAG,OAAO,CAAC,YAAY,IAAI,CAAC,CAAC;oBACxC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;wBACd,MAAM,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;wBAC1D,OAAO;oBACT,CAAC;oBACD,MAAM,UAAU,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;gBAChD,CAAC;aACF,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAc,eAAe,CAAC,CAAC;YACzD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC9B,CAAC;QAAC,MAAM,CAAC;YACP,iCAAiC;QACnC,CAAC;IACH,CAAC;CACF"}
|
package/dist/mail.d.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Mailer, Mailable, MailMessage } from '@tyravel/mail';
|
|
2
|
+
import type { Application } from './application.js';
|
|
3
|
+
export declare function setMailApplication(app: Application): void;
|
|
4
|
+
export interface MailFacade {
|
|
5
|
+
mailer(connection?: string): Mailer;
|
|
6
|
+
to(address: Parameters<Mailer['to']>[0]): Mailer;
|
|
7
|
+
send(mailable: Mailable | MailMessage): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
export declare const Mail: MailFacade;
|
|
10
|
+
//# sourceMappingURL=mail.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mail.d.ts","sourceRoot":"","sources":["../src/mail.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAe,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAChF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAIpD,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,WAAW,GAAG,IAAI,CAEzD;AASD,MAAM,WAAW,UAAU;IACzB,MAAM,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACpC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;IACjD,IAAI,CAAC,QAAQ,EAAE,QAAQ,GAAG,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACvD;AAED,eAAO,MAAM,IAAI,EAAE,UAIlB,CAAC"}
|
package/dist/mail.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
let mailApplication;
|
|
2
|
+
export function setMailApplication(app) {
|
|
3
|
+
mailApplication = app;
|
|
4
|
+
}
|
|
5
|
+
function resolveMail() {
|
|
6
|
+
if (!mailApplication) {
|
|
7
|
+
throw new Error('Mail facade is not ready. Boot the application first.');
|
|
8
|
+
}
|
|
9
|
+
return mailApplication.make('mail');
|
|
10
|
+
}
|
|
11
|
+
export const Mail = {
|
|
12
|
+
mailer: (connection) => resolveMail().mailer(connection),
|
|
13
|
+
to: (address) => resolveMail().mailer().to(address),
|
|
14
|
+
send: (mailable) => resolveMail().mailer().send(mailable),
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=mail.js.map
|
package/dist/mail.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mail.js","sourceRoot":"","sources":["../src/mail.ts"],"names":[],"mappings":"AAGA,IAAI,eAAwC,CAAC;AAE7C,MAAM,UAAU,kBAAkB,CAAC,GAAgB;IACjD,eAAe,GAAG,GAAG,CAAC;AACxB,CAAC;AAED,SAAS,WAAW;IAClB,IAAI,CAAC,eAAe,EAAE,CAAC;QACrB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;IAC3E,CAAC;IACD,OAAO,eAAe,CAAC,IAAI,CAAc,MAAM,CAAC,CAAC;AACnD,CAAC;AAQD,MAAM,CAAC,MAAM,IAAI,GAAe;IAC9B,MAAM,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;IACxD,EAAE,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC;IACnD,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;CAC1D,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ServiceProvider } from './service-provider.js';
|
|
2
|
+
export declare class NotificationServiceProvider extends ServiceProvider {
|
|
3
|
+
register(): void;
|
|
4
|
+
private resolveDatabase;
|
|
5
|
+
private createQueueBridge;
|
|
6
|
+
private registerQueuedNotificationJob;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=notification-service-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notification-service-provider.d.ts","sourceRoot":"","sources":["../src/notification-service-provider.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,qBAAa,2BAA4B,SAAQ,eAAe;IACrD,QAAQ;IAkCjB,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,iBAAiB;IAuBzB,OAAO,CAAC,6BAA6B;CAQtC"}
|