fix(core): update

This commit is contained in:
Philipp Kunz 2020-03-25 20:15:46 +00:00
parent e4ebd99c8f
commit df96f08038
5 changed files with 26 additions and 14 deletions

View File

@ -3,9 +3,9 @@ import * as sdk from '../ts/index';
import { ISimpleRequest } from '@tsclass/tsclass/dist_ts/network';
tap.test('should create a valid Handler', async () => {
class MyHandler extends sdk.AAgHandler {
class MyHandler extends sdk.AAgHandler<any> {
slug: 'testapi';
public async handleRequest(request: ISimpleRequest) {
public async handleRequest(authInfo: sdk.AuthInfo<any>, request: ISimpleRequest) {
// this.authenticationHandler
let response: any;
return response;

View File

@ -1 +1,2 @@
export * from './sdk.classes.aghandler';
export * from './sdk.classes.aghandler';
export * from './sdk.classes.authinfo';

View File

@ -1,16 +1,11 @@
import * as plugins from './sdk.plugins';
import { AuthInfo } from './sdk.classes.authinfo';
export abstract class AAgHandler {
public authenticationHandler: any;
export abstract class AAgHandler<TClaim> {
/**
* a slug that separates the handler from other handlers
*/
public abstract slug: string;
public abstract handleRequest (request: plugins.tsclass.network.ISimpleRequest): Promise<plugins.tsclass.network.ISimpleResponse>;
public setAuthenticationHandler(authHandler) {
this.authenticationHandler = authHandler;
}
public abstract handleRequest (authInfoArg: AuthInfo<TClaim>, request: plugins.tsclass.network.ISimpleRequest): Promise<plugins.tsclass.network.ISimpleResponse>;
}

View File

@ -1,3 +0,0 @@
import * as plugins from './sdk.plugins';
export abstract class AAuthenticationHandler {}

View File

@ -0,0 +1,19 @@
import * as plugins from './sdk.plugins';
/**
* AuthInfo is created for every single incoming request
*/
export abstract class AuthInfo<TClaim> {
/**
* wether the request is generally authenticated
*/
public abstract authenticated: boolean;
/**
* A heuristic analysis result wether the request might be fishy.
* Note: DDOS attacks should never make it anywhere near your code and are filtered by api.global itself.
*/
public abstract potentiallyMalicious: boolean;
public abstract claim: TClaim;
}