fastman
Version:
快速api测试及文档生成
135 lines (117 loc) • 3.91 kB
text/typescript
/**
* @license
* Copyright 2017 Red Hat
*
* 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 {IOasNodeVisitor, IOas20NodeVisitor} from "../../visitors/visitor.iface";
import {Oas20Schema} from "./schema.model";
import {IOas20Items, Oas20Items} from "./items.model";
import {IOasReferenceNode} from "../reference.model";
import {OasParameterBase} from "../common/parameter.model";
/**
* Models an OAS 2.0 Parameter object. Example:
*
* {
* "name": "user",
* "in": "body",
* "description": "user to add to the system",
* "required": true,
* "schema": {
* "$ref": "#/definitions/User"
* }
* }
*/
export abstract class Oas20ParameterBase extends OasParameterBase implements IOas20Items {
public type: string; // required
public format: string;
public items: Oas20Items; // required if type is 'array'
public collectionFormat: string;
public default: any;
public maximum: number;
public exclusiveMaximum: boolean;
public minimum: number;
public exclusiveMinimum: boolean;
public maxLength: number; // Require: integer
public minLength: number; // Require: integer
public pattern: string;
public maxItems: number; // Require: integer
public minItems: number; // Require: integer
public uniqueItems: boolean;
public enum: any[];
public multipleOf: number;
/**
* Creates a child schema model.
* @return {Oas20Schema}
*/
public createSchema(): Oas20Schema {
let rval: Oas20Schema = new Oas20Schema();
rval._ownerDocument = this._ownerDocument;
rval._parent = this;
return rval;
}
/**
* Creates a child items model.
* @return {Oas20Items}
*/
public createItems(): Oas20Items {
let rval: Oas20Items = new Oas20Items();
rval._ownerDocument = this._ownerDocument;
rval._parent = this;
return rval;
}
}
/**
* Extends the base parameter to model a parameter that is a child of the OAS 2.0 Parameters Definitions
* object.
*/
export class Oas20ParameterDefinition extends Oas20ParameterBase {
private _parameterName: string;
/**
* Constructor.
* @param parameterName
*/
constructor(parameterName: string) {
super();
this._parameterName = parameterName;
}
/**
* Gets the parameter name.
* @return {string}
*/
public parameterName(): string {
return this._parameterName;
}
/**
* Accepts the given OAS node visitor and calls the appropriate method on it to visit this node.
* @param visitor
*/
public accept(visitor: IOasNodeVisitor): void {
let viz: IOas20NodeVisitor = <IOas20NodeVisitor> visitor;
viz.visitParameterDefinition(this);
}
}
/**
* Extends the base parameter to add support for references.
*/
export class Oas20Parameter extends Oas20ParameterBase implements IOasReferenceNode {
public $ref: string;
/**
* Accepts the given OAS node visitor and calls the appropriate method on it to visit this node.
* @param visitor
*/
public accept(visitor: IOasNodeVisitor): void {
let viz: IOas20NodeVisitor = visitor as IOas20NodeVisitor;
viz.visitParameter(this);
}
}