Skip to content

Commit

Permalink
feat(types): update types of utils.ts (#259)
Browse files Browse the repository at this point in the history
feat(types): update types of utils.ts
  • Loading branch information
czy88840616 authored Jul 1, 2019
2 parents ce4b9fb + fb534bb commit b7d478a
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 28 deletions.
51 changes: 28 additions & 23 deletions packages/midway-web/src/loader/webLoader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import {
import * as extend from 'extend2';
import * as fs from 'fs';
import { getClassMetadata, getMethodDataFromClass, getProviderId, listModule } from 'injection';
import { ContainerLoader, MidwayHandlerKey } from 'midway-core';
import { ContainerLoader, MidwayHandlerKey, MidwayContainer } from 'midway-core';
import * as path from 'path';
import { MidwayLoaderOptions, WebMiddleware } from '../interface';
import { isTypeScriptEnvironment } from '../utils';
Expand All @@ -33,7 +33,7 @@ export class MidwayWebLoader extends EggLoader {
priority: number,
router: Router,
}> = [];
private containerLoader;
private containerLoader: ContainerLoader;

constructor(options: MidwayLoaderOptions) {
super(options);
Expand All @@ -42,32 +42,32 @@ export class MidwayWebLoader extends EggLoader {
/**
* 判断是否是 ts 模式,在构造器内就会被执行
*/
get isTsMode() {
get isTsMode(): boolean {
return this.app.options.typescript;
}

get applicationContext() {
get applicationContext(): MidwayContainer {
return this.containerLoader.getApplicationContext();
}

get pluginContext() {
get pluginContext(): any {
return this.containerLoader.getPluginContext();
}

// loadPlugin -> loadConfig -> afterLoadConfig
protected loadConfig() {
protected loadConfig(): void {
this.loadPlugin();
super.loadConfig();
}

// Get the real plugin path
protected getPluginPath(plugin) {
if (plugin.path) {
protected getPluginPath(plugin: any): string {
if (plugin && plugin.path) {
return plugin.path;
}

const name = plugin.package || plugin.name;
const lookupDirs = [];
const name: string = plugin.package || plugin.name;
const lookupDirs: string[] = [];

// 尝试在以下目录找到匹配的插件
// -> {APP_PATH}/node_modules
Expand All @@ -77,7 +77,7 @@ export class MidwayWebLoader extends EggLoader {

// 到 egg 中查找,优先从外往里查找
for (let i = this.eggPaths.length - 1; i >= 0; i--) {
const eggPath = this.eggPaths[i];
const eggPath: string = this.eggPaths[i];
lookupDirs.push(path.join(eggPath, 'node_modules'));
}

Expand All @@ -98,7 +98,7 @@ export class MidwayWebLoader extends EggLoader {
throw new Error(`Can not find plugin ${name} in "${lookupDirs.join(', ')}"`);
}

protected registerTypescriptDirectory() {
protected registerTypescriptDirectory(): void {
const app = this.app;
// 处理 ts 的初始路径
this.appDir = this.baseDir = app.options.baseDir;
Expand All @@ -118,16 +118,16 @@ export class MidwayWebLoader extends EggLoader {
}
}

protected getEggPaths() {
protected getEggPaths(): string[] {
if (!this.appDir) {
// register appDir here
this.registerTypescriptDirectory();
}
return super.getEggPaths();
}

protected getServerEnv() {
let serverEnv;
protected getServerEnv(): string {
let serverEnv: string;

const envPath = path.join(this.appDir, 'config/env');
if (fs.existsSync(envPath)) {
Expand All @@ -141,9 +141,9 @@ export class MidwayWebLoader extends EggLoader {
return serverEnv;
}

protected getAppInfo() {
protected getAppInfo(): EggAppInfo {
if (!this.appInfo) {
const appInfo = super.getAppInfo();
const appInfo: EggAppInfo | undefined = super.getAppInfo();
// ROOT == HOME in prod env
this.appInfo = extend(true, appInfo, {
root: appInfo.env === 'local' || appInfo.env === 'unittest' ? this.appDir : appInfo.root,
Expand All @@ -153,7 +153,7 @@ export class MidwayWebLoader extends EggLoader {
return this.appInfo;
}

protected loadApplicationContext() {
protected loadApplicationContext(): void {
// this.app.options.container 测试用例编写方便点
const containerConfig = this.config.container || this.app.options.container || {};
if (!containerConfig.loadDir) {
Expand All @@ -172,23 +172,23 @@ export class MidwayWebLoader extends EggLoader {
this.containerLoader.loadDirectory(containerConfig);

// register handler for container
this.containerLoader.registerAllHook(MidwayHandlerKey.CONFIG, (key) => {
this.containerLoader.registerAllHook(MidwayHandlerKey.CONFIG, (key: string) => {
return this.config[key];
});

this.containerLoader.registerAllHook(MidwayHandlerKey.PLUGIN, (key) => {
this.containerLoader.registerAllHook(MidwayHandlerKey.PLUGIN, (key: string) => {
return this.app[key] || this.pluginContext.get(key);
});

this.containerLoader.registerAllHook(MidwayHandlerKey.LOGGER, (key) => {
this.containerLoader.registerAllHook(MidwayHandlerKey.LOGGER, (key: string) => {
if (this.app.getLogger) {
return this.app.getLogger(key);
}
return this.options.logger;
});
}

protected async preRegisterRouter(target, controllerId) {
protected async preRegisterRouter(target: any, controllerId: string): Promise<void> {
const controllerOption: ControllerOption = getClassMetadata(CONTROLLER_KEY, target);
const newRouter = this.createEggRouter(controllerOption);

Expand Down Expand Up @@ -240,7 +240,12 @@ export class MidwayWebLoader extends EggLoader {

}

private async handlerWebMiddleware(middlewares, handlerCallback) {

private async handlerWebMiddleware<T extends any = any>(
middlewares: T[],
handlerCallback: (ps: T | ReturnType<WebMiddleware['resolve']>) => any,
): Promise<void> {

if (middlewares && middlewares.length) {
for (const middleware of middlewares) {
if (typeof middleware === 'function') {
Expand Down
10 changes: 5 additions & 5 deletions packages/midway-web/src/utils.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
const STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg;
const ARGUMENT_NAMES = /([^\s,]+)/g;

export function getParamNames(func) {
export function getParamNames(func: () => any): RegExpMatchArray {
const fnStr = func.toString().replace(STRIP_COMMENTS, '');
let result = fnStr.slice(fnStr.indexOf('(') + 1, fnStr.indexOf(')')).match(ARGUMENT_NAMES);
if (result === null) {
Expand All @@ -16,8 +16,8 @@ export function getParamNames(func) {
* @param {*} obj - object to enumerate on
* @returns {string[]} - method names
*/
export function getMethodNames(obj) {
const enumerableOwnKeys = Object.keys(obj);
export function getMethodNames(obj: object): string[] {
const enumerableOwnKeys: string[] = Object.keys(obj);
const ownKeysOnObjectPrototype = Object.getOwnPropertyNames(Object.getPrototypeOf({}));
// methods on obj itself should be always included
const result = enumerableOwnKeys.filter(k => typeof obj[k] === 'function');
Expand All @@ -26,7 +26,7 @@ export function getMethodNames(obj) {
let proto = obj;
do {
proto = Object.getPrototypeOf(proto);
const allOwnKeysOnPrototype = Object.getOwnPropertyNames(proto);
const allOwnKeysOnPrototype: string[] = Object.getOwnPropertyNames(proto);
// get methods from es6 class
allOwnKeysOnPrototype.forEach(k => {
if (typeof obj[k] === 'function' && k !== 'constructor') {
Expand All @@ -42,6 +42,6 @@ export function getMethodNames(obj) {
});
}

export function isTypeScriptEnvironment() {
export function isTypeScriptEnvironment(): boolean {
return !!require.extensions['.ts'];
}

0 comments on commit b7d478a

Please sign in to comment.