Add logic for resolving route handlers
This commit is contained in:
@@ -105,7 +105,7 @@ export abstract class Canonical<T> extends Unit {
|
||||
}
|
||||
|
||||
public async initCanonicalItem(definition: CanonicalDefinition): Promise<T> {
|
||||
return definition.imported.default ?? definition.imported[definition.canonicalName]
|
||||
return definition.imported.default ?? definition.imported[definition.canonicalName.split(':').reverse()[0]]
|
||||
}
|
||||
|
||||
protected async buildCanonicalDefinition(filePath: string): Promise<CanonicalDefinition> {
|
||||
|
||||
@@ -17,8 +17,8 @@ export class CanonicalInstantiable<T> extends Canonical<Instantiable<T>> {
|
||||
return this.app().make(definition.imported.default)
|
||||
}
|
||||
|
||||
if ( isInstantiable(definition.imported[definition.canonicalName]) ) {
|
||||
return this.app().make(definition.imported[definition.canonicalName])
|
||||
if ( isInstantiable(definition.imported[definition.canonicalName.split(':').reverse()[0]]) ) {
|
||||
return this.app().make(definition.imported[definition.canonicalName.split(':').reverse()[0]])
|
||||
}
|
||||
|
||||
throw new InvalidCanonicalExportError(definition.originalName)
|
||||
|
||||
@@ -8,8 +8,8 @@ export class CanonicalStatic<T, T2> extends Canonical<StaticClass<T, T2>> {
|
||||
return definition.imported.default
|
||||
}
|
||||
|
||||
if ( isStaticClass(definition.imported[definition.canonicalName]) ) {
|
||||
return definition.imported[definition.canonicalName]
|
||||
if ( isStaticClass(definition.imported[definition.canonicalName.split(':').reverse()[0]]) ) {
|
||||
return definition.imported[definition.canonicalName.split(':').reverse()[0]]
|
||||
}
|
||||
|
||||
throw new InvalidCanonicalExportError(definition.originalName)
|
||||
|
||||
@@ -1,17 +1,17 @@
|
||||
import {CanonicalInstantiable} from "./CanonicalInstantiable";
|
||||
import {Singleton} from "@extollo/di";
|
||||
import {CanonicalStatic} from "./CanonicalStatic";
|
||||
import {Singleton, Instantiable} from "@extollo/di";
|
||||
import {Controller} from "../http/Controller";
|
||||
import {CanonicalDefinition} from "./Canonical";
|
||||
|
||||
@Singleton()
|
||||
export class Controllers extends CanonicalInstantiable<Controller> {
|
||||
export class Controllers extends CanonicalStatic<Instantiable<Controller>, Controller> {
|
||||
protected appPath = ['http', 'controllers']
|
||||
protected canonicalItem = 'controller'
|
||||
protected suffix = '.controller.js'
|
||||
|
||||
public async initCanonicalItem(definition: CanonicalDefinition) {
|
||||
const item = await super.initCanonicalItem(definition)
|
||||
if ( !(item instanceof Controller) ) {
|
||||
if ( !(item.prototype instanceof Controller) ) {
|
||||
throw new TypeError(`Invalid controller definition: ${definition.originalName}. Controllers must extend from @extollo/lib.http.Controller.`)
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user