aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/client.ts21
-rw-r--r--lib/connection.ts12
-rw-r--r--lib/event.model.ts8
-rw-r--r--lib/index.ts3
-rw-r--r--lib/log.model.ts9
5 files changed, 46 insertions, 7 deletions
diff --git a/lib/client.ts b/lib/client.ts
new file mode 100644
index 0000000..eafdda5
--- /dev/null
+++ b/lib/client.ts
@@ -0,0 +1,21 @@
+import { Schema } from 'mongoose';
+import Connection from './connection';
+import createEventModel, { EventModel } from './event.model';
+import createLogModel, { LogModel } from './log.model';
+
+
+class Client<Context> {
+ public connection: Connection;
+ public Event: EventModel<Context>;
+ public Log: LogModel;
+
+ constructor(connection: Connection, contextSchema: Schema) {
+ this.connection = connection;
+ this.Log = createLogModel(connection);
+ this.Event = createEventModel<Context>(connection, contextSchema);
+ }
+}
+
+
+export default Client;
+
diff --git a/lib/connection.ts b/lib/connection.ts
new file mode 100644
index 0000000..17ea59a
--- /dev/null
+++ b/lib/connection.ts
@@ -0,0 +1,12 @@
+import { model, Model } from 'mongoose';
+
+// An interface for mongoose.connection
+export interface Connection {
+ model: typeof model;
+ models: Record<string, Model<any, any>>;
+ dropCollection: (name: string) => Promise<void>;
+}
+
+
+export default Connection;
+
diff --git a/lib/event.model.ts b/lib/event.model.ts
index 62675d4..bea533d 100644
--- a/lib/event.model.ts
+++ b/lib/event.model.ts
@@ -2,7 +2,8 @@ import { model, Schema, Model } from 'mongoose';
import cron from 'cron';
import createEventSchema, { EventDocument } from './event.schema';
import { LogDocument } from './log.schema';
-import LogModel from './log.model';
+import { LogModel } from './log.model';
+import Connection from './connection';
export interface Event<Context> extends EventDocument<Context> {
log(message: string): Promise<LogDocument>;
@@ -20,8 +21,9 @@ export interface EventModel<Context> extends Model<Event<Context>> {
const { CronJob } = cron;
-const createEventModel = <Context>(name: string, contextSchema: Schema): EventModel<Context> => {
+const createEventModel = <Context>(connection: Connection, contextSchema: Schema): EventModel<Context> => {
const schema = createEventSchema(contextSchema);
+ const LogModel: LogModel = connection.models['Log'];
// Schema methods
schema.method('log', function (message: string) {
@@ -93,7 +95,7 @@ const createEventModel = <Context>(name: string, contextSchema: Schema): EventMo
this.nextRunAt = this.computeNextRunAt();
});
- return model<Event<Context>, EventModel<Context>>(name, schema);
+ return connection.model<Event<Context>, EventModel<Context>>('Event', schema);
};
diff --git a/lib/index.ts b/lib/index.ts
index 4f128b1..cb2f7ef 100644
--- a/lib/index.ts
+++ b/lib/index.ts
@@ -1,4 +1,3 @@
-export { default as model } from './event.model';
-export { default as LogModel } from './log.model';
+export { default as Client } from './client';
export { default as Scheduler } from './scheduler';
diff --git a/lib/log.model.ts b/lib/log.model.ts
index 7ea9cb9..1904d15 100644
--- a/lib/log.model.ts
+++ b/lib/log.model.ts
@@ -1,8 +1,13 @@
import { model, Model } from 'mongoose';
import schema, { LogDocument } from './log.schema';
+import Connection from './connection';
-const LogModel = model<LogDocument, Model<LogDocument>>('Log', schema);
+export type LogModel = Model<LogDocument>;
+const createLogModel = (connection: Connection): LogModel => {
+ return connection.model<LogDocument, LogModel>('Log', schema);
+};
-export default LogModel;
+
+export default createLogModel;