From 569cb0457b4cdcffdf325bdfe8959d55e48efc25 Mon Sep 17 00:00:00 2001 From: eug-vs Date: Fri, 4 Dec 2020 01:12:54 +0300 Subject: feat!: remove context schema from client This will allow for multiple event types in one Model. --- lib/client.ts | 9 ++++----- lib/event.model.ts | 13 ++++++------- lib/event.schema.ts | 8 ++++---- 3 files changed, 14 insertions(+), 16 deletions(-) (limited to 'lib') diff --git a/lib/client.ts b/lib/client.ts index eafdda5..15bd076 100644 --- a/lib/client.ts +++ b/lib/client.ts @@ -1,18 +1,17 @@ -import { Schema } from 'mongoose'; import Connection from './connection'; import createEventModel, { EventModel } from './event.model'; import createLogModel, { LogModel } from './log.model'; -class Client { +class Client { public connection: Connection; - public Event: EventModel; + public Event: EventModel; public Log: LogModel; - constructor(connection: Connection, contextSchema: Schema) { + constructor(connection: Connection) { this.connection = connection; this.Log = createLogModel(connection); - this.Event = createEventModel(connection, contextSchema); + this.Event = createEventModel(connection); } } diff --git a/lib/event.model.ts b/lib/event.model.ts index bea533d..665a35f 100644 --- a/lib/event.model.ts +++ b/lib/event.model.ts @@ -1,11 +1,11 @@ import { model, Schema, Model } from 'mongoose'; import cron from 'cron'; -import createEventSchema, { EventDocument } from './event.schema'; +import schema, { EventDocument } from './event.schema'; import { LogDocument } from './log.schema'; import { LogModel } from './log.model'; import Connection from './connection'; -export interface Event extends EventDocument { +export interface Event extends EventDocument { log(message: string): Promise; start(): void; complete(): void; @@ -14,15 +14,14 @@ export interface Event extends EventDocument { getLogs(): Promise; } -export interface EventModel extends Model> { +export interface EventModel extends Model> { findNextEvents(): Event[]; findMissedEvents(): Event[]; } const { CronJob } = cron; -const createEventModel = (connection: Connection, contextSchema: Schema): EventModel => { - const schema = createEventSchema(contextSchema); +const createEventModel = (connection: Connection): EventModel => { const LogModel: LogModel = connection.models['Log']; // Schema methods @@ -91,11 +90,11 @@ const createEventModel = (connection: Connection, contextSchema: Schema }); // Hooks - schema.pre>('save', async function () { + schema.pre('save', async function () { this.nextRunAt = this.computeNextRunAt(); }); - return connection.model, EventModel>('Event', schema); + return connection.model('Event', schema); }; diff --git a/lib/event.schema.ts b/lib/event.schema.ts index 8b9db8b..664b577 100644 --- a/lib/event.schema.ts +++ b/lib/event.schema.ts @@ -1,6 +1,6 @@ import { Schema, Document } from 'mongoose'; -export interface EventDocument extends Document { +export interface EventDocument extends Document { type: string; schedule: string; status?: 'notStarted' | 'running' | 'complete' | 'failed'; @@ -10,7 +10,7 @@ export interface EventDocument extends Document { lastRunAt?: Date; } -const createEventSchema = (contextSchema: Schema) => new Schema({ +const schema = new Schema({ type: { type: String, required: true @@ -24,11 +24,11 @@ const createEventSchema = (contextSchema: Schema) => new Schema({ default: 'notStarted' }, error: String, - context: contextSchema, + context: {}, nextRunAt: Date, lastRunAt: Date }, { timestamps: true }); -export default createEventSchema; +export default schema; -- cgit v1.2.3