jec-sandcat
Version:
JEC Sandcat - The default RESTful web services framework for GlassCat applications.
98 lines (90 loc) • 4 kB
text/typescript
// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
//
// Copyright 2016-2018 Pascal ECHEMANN.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import {MethodDescriptor} from "../reflect/MethodDescriptor";
import {RequestProperties} from "../utils/RequestProperties";
import {AnnotationType} from "../reflect/AnnotationType";
/**
* A helper class that provides methods for working with
* <code>AnnotationType</code> enum values.
*/
export class AnnotationTypeUtil {
////////////////////////////////////////////////////////////////////////////
// Constructor function
////////////////////////////////////////////////////////////////////////////
/**
* Creates a new <code>AnnotationTypeUtil</code> instance.
*/
constructor() {}
//////////////////////////////////////////////////////////////////////////////
// Public methods
//////////////////////////////////////////////////////////////////////////////
/**
* Retuns a string that represents the name of the specified
* <code>annotationType</code> parameter.
*
* @param {AnnotationType} annotationType a value of the
* <code>AnnotationType</code> Enum.
* @return {string} a string that represents the name of the specified
* <code>annotationType</code> parameter.
*/
public getParamStringRef(annotationType:AnnotationType):string {
let result:string = null;
if(annotationType === AnnotationType.EXIT) {
result = "AnnotationType.EXIT";
} else if(annotationType === AnnotationType.PATH_PARAM) {
result = "AnnotationType.PATH_PARAM";
} else if(annotationType === AnnotationType.HTTP_REQUEST) {
result = "AnnotationType.HTTP_REQUEST";
} else if(annotationType === AnnotationType.QUERY_PARAM) {
result = "AnnotationType.QUERY_PARAM";
} else if(annotationType === AnnotationType.REQUEST_BODY) {
result = "AnnotationType.REQUEST_BODY";
} else if(annotationType === AnnotationType.COOKIE_PARAM) {
result = "AnnotationType.COOKIE_PARAM";
}
return result;
}
/**
* Retuns a string that represents the name of the specified
* <code>annotationType</code> parameter.
*
* @param {AnnotationType} annotationType a value of the
* <code>AnnotationType</code> Enum.
* @return {string} a string that represents the name of the specified
* <code>annotationType</code> method.
*/
public getMethodStringRef(annotationType:AnnotationType):string {
let result:string = null;
if(annotationType === AnnotationType.GET) {
result = "AnnotationType.GET";
} else if(annotationType === AnnotationType.POST) {
result = "AnnotationType.POST";
} else if(annotationType === AnnotationType.PUT) {
result = "AnnotationType.PUT";
} else if(annotationType === AnnotationType.DELETE) {
result = "AnnotationType.DELETE";
} else if(annotationType === AnnotationType.CONNECT) {
result = "AnnotationType.CONNECT";
} else if(annotationType === AnnotationType.HEAD) {
result = "AnnotationType.HEAD";
} else if(annotationType === AnnotationType.OPTIONS) {
result = "AnnotationType.OPTIONS";
} else if(annotationType === AnnotationType.TRACE) {
result = "AnnotationType.TRACE";
}
return result;
}
};