'use strict'; // ////////////////////////////////////////////////////////////////////////////// // / @brief Foxx Swagger documentation // / // / @file // / // / DISCLAIMER // / // / Copyright 2013 triagens GmbH, Cologne, Germany // / // / 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. // / // / Copyright holder is ArangoDB GmbH, Cologne, Germany // / // / @author Michael Hackstein // / @author Copyright 2015, ArangoDB GmbH, Cologne, Germany // ////////////////////////////////////////////////////////////////////////////// var _ = require('lodash'); var internal = require('internal'); // Wraps the docs object of a route to add swagger compatible documentation var SwaggerDocs = function (docs, models) { this.docs = docs; this.models = models; }; SwaggerDocs.prototype.addPathParam = function (paramName, description, dataType, required) { this.docs.parameters.push({ paramType: 'path', name: paramName, description: description, dataType: dataType, required: required }); }; SwaggerDocs.prototype.addQueryParam = function (paramName, description, dataType, required, allowMultiple) { this.docs.parameters.push({ paramType: 'query', name: paramName, description: description, dataType: dataType, required: required, allowMultiple: allowMultiple }); }; SwaggerDocs.prototype.addBodyParam = function (paramName, description, jsonSchema) { var token = internal.genRandomAlphaNumbers(32); while (this.models[token]) { // Brute-force against random collisions token = internal.genRandomAlphaNumbers(32); } this.models[token] = jsonSchema; delete jsonSchema.id; var param = _.find(this.docs.parameters, function (parameter) { return parameter.name === 'undocumented body'; }); if (_.isUndefined(param)) { this.docs.parameters.push({ name: paramName, paramType: 'body', description: description, dataType: token }); } else { param.name = paramName; param.description = description; param.dataType = token; } }; SwaggerDocs.prototype.addSummary = function (summary) { this.docs.summary = summary; }; SwaggerDocs.prototype.addNotes = function (notes) { this.docs.notes = notes; }; exports.Docs = SwaggerDocs;