#1248 added partial
This commit is contained in:
505
src/main/javascript/view/partials/jsonSignature.js
Normal file
505
src/main/javascript/view/partials/jsonSignature.js
Normal file
@@ -0,0 +1,505 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
SwaggerUi.Views.partials.jsonSignature = (function () {
|
||||||
|
var getModelSignature = function (name, schema, models, modelPropertyMacro) {
|
||||||
|
var strongOpen = '<span class="strong">';
|
||||||
|
var strongClose = '</span>';
|
||||||
|
var resolveSchema = function (schema) {
|
||||||
|
if (_.isPlainObject(schema.schema)) {
|
||||||
|
schema = resolveSchema(schema.schema);
|
||||||
|
}
|
||||||
|
|
||||||
|
return schema;
|
||||||
|
};
|
||||||
|
|
||||||
|
var simpleRef = function (name) {
|
||||||
|
if (typeof name === 'undefined') {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (name.indexOf('#/definitions/') === 0) {
|
||||||
|
return name.substring('#/definitions/'.length);
|
||||||
|
} else {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var optionHtml = function (label, value) {
|
||||||
|
return '<tr><td class="optionName">' + label + ':</td><td>' + value + '</td></tr>';
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// Allow for ignoring the 'name' argument.... shifting the rest
|
||||||
|
if(_.isObject(arguments[0])) {
|
||||||
|
name = void 0;
|
||||||
|
schema = arguments[0];
|
||||||
|
models = arguments[1];
|
||||||
|
modelPropertyMacro = arguments[2];
|
||||||
|
}
|
||||||
|
|
||||||
|
models = models || {};
|
||||||
|
|
||||||
|
// Resolve the schema (Handle nested schemas)
|
||||||
|
schema = resolveSchema(schema);
|
||||||
|
|
||||||
|
// Return for empty object
|
||||||
|
if(_.isEmpty(schema)) {
|
||||||
|
return strongOpen + 'Empty' + strongClose;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Dereference $ref from 'models'
|
||||||
|
if(typeof schema.$ref === 'string') {
|
||||||
|
name = simpleRef(schema.$ref);
|
||||||
|
schema = models[name];
|
||||||
|
if(typeof schema === 'undefined')
|
||||||
|
{
|
||||||
|
return strongOpen + name + ' is not defined!' + strongClose;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(typeof name !== 'string') {
|
||||||
|
name = schema.title || 'Inline Model';
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we are a Model object... adjust accordingly
|
||||||
|
if(schema.definition) {
|
||||||
|
schema = schema.definition;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(typeof modelPropertyMacro !== 'function') {
|
||||||
|
modelPropertyMacro = function(prop){
|
||||||
|
return (prop || {}).default;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
var references = {};
|
||||||
|
var seenModels = [];
|
||||||
|
var inlineModels = 0;
|
||||||
|
|
||||||
|
// Generate current HTML
|
||||||
|
var html = processModel(schema, name);
|
||||||
|
|
||||||
|
// Generate references HTML
|
||||||
|
while (_.keys(references).length > 0) {
|
||||||
|
/* jshint ignore:start */
|
||||||
|
_.forEach(references, function (schema, name) {
|
||||||
|
var seenModel = _.indexOf(seenModels, name) > -1;
|
||||||
|
|
||||||
|
delete references[name];
|
||||||
|
|
||||||
|
if (!seenModel) {
|
||||||
|
seenModels.push(name);
|
||||||
|
|
||||||
|
html += '<br />' + processModel(schema, name);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
/* jshint ignore:end */
|
||||||
|
}
|
||||||
|
|
||||||
|
return html;
|
||||||
|
|
||||||
|
|
||||||
|
function addReference(schema, name, skipRef) {
|
||||||
|
var modelName = name;
|
||||||
|
var model;
|
||||||
|
|
||||||
|
if (schema.$ref) {
|
||||||
|
modelName = schema.title || simpleRef(schema.$ref);
|
||||||
|
model = models[modelName];
|
||||||
|
} else if (_.isUndefined(name)) {
|
||||||
|
modelName = schema.title || 'Inline Model ' + (++inlineModels);
|
||||||
|
model = {definition: schema};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (skipRef !== true) {
|
||||||
|
references[modelName] = _.isUndefined(model) ? {} : model.definition;
|
||||||
|
}
|
||||||
|
|
||||||
|
return modelName;
|
||||||
|
}
|
||||||
|
|
||||||
|
function primitiveToHTML(schema) {
|
||||||
|
var html = '<span class="propType">';
|
||||||
|
var type = schema.type || 'object';
|
||||||
|
|
||||||
|
if (schema.$ref) {
|
||||||
|
html += addReference(schema, simpleRef(schema.$ref));
|
||||||
|
} else if (type === 'object') {
|
||||||
|
if (!_.isUndefined(schema.properties)) {
|
||||||
|
html += addReference(schema);
|
||||||
|
} else {
|
||||||
|
html += 'object';
|
||||||
|
}
|
||||||
|
} else if (type === 'array') {
|
||||||
|
html += 'Array[';
|
||||||
|
|
||||||
|
if (_.isArray(schema.items)) {
|
||||||
|
html += _.map(schema.items, addReference).join(',');
|
||||||
|
} else if (_.isPlainObject(schema.items)) {
|
||||||
|
if (_.isUndefined(schema.items.$ref)) {
|
||||||
|
if (!_.isUndefined(schema.items.type) && _.indexOf(['array', 'object'], schema.items.type) === -1) {
|
||||||
|
html += schema.items.type;
|
||||||
|
} else {
|
||||||
|
html += addReference(schema.items);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
html += addReference(schema.items, simpleRef(schema.items.$ref));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Array type\'s \'items\' schema is not an array or an object, cannot process');
|
||||||
|
html += 'object';
|
||||||
|
}
|
||||||
|
|
||||||
|
html += ']';
|
||||||
|
} else {
|
||||||
|
html += schema.type;
|
||||||
|
}
|
||||||
|
|
||||||
|
html += '</span>';
|
||||||
|
|
||||||
|
return html;
|
||||||
|
}
|
||||||
|
|
||||||
|
function primitiveToOptionsHTML(schema, html) {
|
||||||
|
var options = '';
|
||||||
|
var type = schema.type || 'object';
|
||||||
|
var isArray = type === 'array';
|
||||||
|
|
||||||
|
if (isArray) {
|
||||||
|
if (_.isPlainObject(schema.items) && !_.isUndefined(schema.items.type)) {
|
||||||
|
type = schema.items.type;
|
||||||
|
} else {
|
||||||
|
type = 'object';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!_.isUndefined(schema.default)) {
|
||||||
|
options += optionHtml('Default', schema.default);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case 'string':
|
||||||
|
if (schema.minLength) {
|
||||||
|
options += optionHtml('Min. Length', schema.minLength);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.maxLength) {
|
||||||
|
options += optionHtml('Max. Length', schema.maxLength);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.pattern) {
|
||||||
|
options += optionHtml('Reg. Exp.', schema.pattern);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'integer':
|
||||||
|
case 'number':
|
||||||
|
if (schema.minimum) {
|
||||||
|
options += optionHtml('Min. Value', schema.minimum);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.exclusiveMinimum) {
|
||||||
|
options += optionHtml('Exclusive Min.', 'true');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.maximum) {
|
||||||
|
options += optionHtml('Max. Value', schema.maximum);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.exclusiveMaximum) {
|
||||||
|
options += optionHtml('Exclusive Max.', 'true');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.multipleOf) {
|
||||||
|
options += optionHtml('Multiple Of', schema.multipleOf);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isArray) {
|
||||||
|
if (schema.minItems) {
|
||||||
|
options += optionHtml('Min. Items', schema.minItems);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.maxItems) {
|
||||||
|
options += optionHtml('Max. Items', schema.maxItems);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.uniqueItems) {
|
||||||
|
options += optionHtml('Unique Items', 'true');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema.collectionFormat) {
|
||||||
|
options += optionHtml('Coll. Format', schema.collectionFormat);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_.isUndefined(schema.items)) {
|
||||||
|
if (_.isArray(schema.enum)) {
|
||||||
|
var enumString;
|
||||||
|
|
||||||
|
if (type === 'number' || type === 'integer') {
|
||||||
|
enumString = schema.enum.join(', ');
|
||||||
|
} else {
|
||||||
|
enumString = '"' + schema.enum.join('", "') + '"';
|
||||||
|
}
|
||||||
|
|
||||||
|
options += optionHtml('Enum', enumString);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.length > 0) {
|
||||||
|
html = '<span class="propWrap">' + html + '<table class="optionsWrapper"><tr><th colspan="2">' + type + '</th></tr>' + options + '</table></span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
return html;
|
||||||
|
}
|
||||||
|
|
||||||
|
function processModel(schema, name) {
|
||||||
|
var type = schema.type || 'object';
|
||||||
|
var isArray = schema.type === 'array';
|
||||||
|
var html = strongOpen + name + ' ' + (isArray ? '[' : '{') + strongClose;
|
||||||
|
var contents;
|
||||||
|
|
||||||
|
if (name) {
|
||||||
|
seenModels.push(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isArray) {
|
||||||
|
if (_.isArray(schema.items)) {
|
||||||
|
html += '<div>' + _.map(schema.items, function (item) {
|
||||||
|
var type = item.type || 'object';
|
||||||
|
|
||||||
|
if (_.isUndefined(item.$ref)) {
|
||||||
|
if (_.indexOf(['array', 'object'], type) > -1) {
|
||||||
|
if (type === 'object' && _.isUndefined(item.properties)) {
|
||||||
|
return 'object';
|
||||||
|
} else {
|
||||||
|
return addReference(item);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return primitiveToOptionsHTML(item, type);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return addReference(item, simpleRef(item.$ref));
|
||||||
|
}
|
||||||
|
}).join(',</div><div>');
|
||||||
|
} else if (_.isPlainObject(schema.items)) {
|
||||||
|
if (_.isUndefined(schema.items.$ref)) {
|
||||||
|
if (_.indexOf(['array', 'object'], schema.items.type || 'object') > -1) {
|
||||||
|
if ((_.isUndefined(schema.items.type) || schema.items.type === 'object') && _.isUndefined(schema.items.properties)) {
|
||||||
|
html += '<div>object</div>';
|
||||||
|
} else {
|
||||||
|
html += '<div>' + addReference(schema.items) + '</div>';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
html += '<div>' + primitiveToOptionsHTML(schema.items, schema.items.type) + '</div>';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
html += '<div>' + addReference(schema.items, simpleRef(schema.items.$ref)) + '</div>';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Array type\'s \'items\' property is not an array or an object, cannot process');
|
||||||
|
html += '<div>object</div>';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (schema.$ref) {
|
||||||
|
html += '<div>' + addReference(schema, name) + '</div>';
|
||||||
|
} else if (type === 'object') {
|
||||||
|
if (_.isPlainObject(schema.properties)) {
|
||||||
|
contents = _.map(schema.properties, function (property, name) {
|
||||||
|
var propertyIsRequired = (_.indexOf(schema.required, name) >= 0);
|
||||||
|
var cProperty = _.cloneDeep(property);
|
||||||
|
|
||||||
|
var requiredClass = propertyIsRequired ? 'required' : '';
|
||||||
|
var html = '<div' + (property.readOnly ? ' class="readOnly"' : '') + '><span class="propName ' + requiredClass + '">' + name + '</span> (';
|
||||||
|
var model;
|
||||||
|
var propDescription;
|
||||||
|
|
||||||
|
// Allow macro to set the default value
|
||||||
|
cProperty.default = modelPropertyMacro(cProperty);
|
||||||
|
|
||||||
|
// Resolve the schema (Handle nested schemas)
|
||||||
|
cProperty = resolveSchema(cProperty);
|
||||||
|
|
||||||
|
propDescription = property.description || cProperty.description;
|
||||||
|
|
||||||
|
// We need to handle property references to primitives (Issue 339)
|
||||||
|
if (!_.isUndefined(cProperty.$ref)) {
|
||||||
|
model = models[simpleRef(cProperty.$ref)];
|
||||||
|
|
||||||
|
if (!_.isUndefined(model) && _.indexOf([undefined, 'array', 'object'], model.definition.type) === -1) {
|
||||||
|
// Use referenced schema
|
||||||
|
cProperty = resolveSchema(model.definition);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
html += primitiveToHTML(cProperty);
|
||||||
|
|
||||||
|
if(!propertyIsRequired) {
|
||||||
|
html += ', <span class="propOptKey">optional</span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if(property.readOnly) {
|
||||||
|
html += ', <span class="propReadOnly">read only</span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
html += ')';
|
||||||
|
|
||||||
|
if (!_.isUndefined(propDescription)) {
|
||||||
|
html += ': ' + '<span class="propDesc">' + propDescription + '</span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cProperty.enum) {
|
||||||
|
html += ' = <span class="propVals">[\'' + cProperty.enum.join('\', \'') + '\']</span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
return primitiveToOptionsHTML(cProperty, html);
|
||||||
|
}).join(',</div>');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contents) {
|
||||||
|
html += contents + '</div>';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
html += '<div>' + primitiveToOptionsHTML(schema, type) + '</div>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return html + strongOpen + (isArray ? ']' : '}') + strongClose;
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
var schemaToJSON = function (schema, models, modelsToIgnore, modelPropertyMacro) {
|
||||||
|
var resolveSchema = function (schema) {
|
||||||
|
if (_.isPlainObject(schema.schema)) {
|
||||||
|
schema = resolveSchema(schema.schema);
|
||||||
|
}
|
||||||
|
|
||||||
|
return schema;
|
||||||
|
};
|
||||||
|
|
||||||
|
var simpleRef = function (name) {
|
||||||
|
if (typeof name === 'undefined') {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (name.indexOf('#/definitions/') === 0) {
|
||||||
|
return name.substring('#/definitions/'.length);
|
||||||
|
} else {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Resolve the schema (Handle nested schemas)
|
||||||
|
schema = resolveSchema(schema);
|
||||||
|
|
||||||
|
if(typeof modelPropertyMacro !== 'function') {
|
||||||
|
modelPropertyMacro = function(prop){
|
||||||
|
return (prop || {}).default;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
modelsToIgnore= modelsToIgnore || {};
|
||||||
|
|
||||||
|
var type = schema.type || 'object';
|
||||||
|
var format = schema.format;
|
||||||
|
var model;
|
||||||
|
var output;
|
||||||
|
|
||||||
|
if (!_.isUndefined(schema.example)) {
|
||||||
|
output = schema.example;
|
||||||
|
} else if (_.isUndefined(schema.items) && _.isArray(schema.enum)) {
|
||||||
|
output = schema.enum[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_.isUndefined(output)) {
|
||||||
|
if (schema.$ref) {
|
||||||
|
model = models[simpleRef(schema.$ref)];
|
||||||
|
|
||||||
|
if (!_.isUndefined(model)) {
|
||||||
|
if (_.isUndefined(modelsToIgnore[model.name])) {
|
||||||
|
modelsToIgnore[model.name] = model;
|
||||||
|
output = schemaToJSON(model.definition, models, modelsToIgnore, modelPropertyMacro);
|
||||||
|
delete modelsToIgnore[model.name];
|
||||||
|
} else {
|
||||||
|
if (model.type === 'array') {
|
||||||
|
output = [];
|
||||||
|
} else {
|
||||||
|
output = {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (!_.isUndefined(schema.default)) {
|
||||||
|
output = schema.default;
|
||||||
|
} else if (type === 'string') {
|
||||||
|
if (format === 'date-time') {
|
||||||
|
output = new Date().toISOString();
|
||||||
|
} else if (format === 'date') {
|
||||||
|
output = new Date().toISOString().split('T')[0];
|
||||||
|
} else {
|
||||||
|
output = 'string';
|
||||||
|
}
|
||||||
|
} else if (type === 'integer') {
|
||||||
|
output = 0;
|
||||||
|
} else if (type === 'number') {
|
||||||
|
output = 0.0;
|
||||||
|
} else if (type === 'boolean') {
|
||||||
|
output = true;
|
||||||
|
} else if (type === 'object') {
|
||||||
|
output = {};
|
||||||
|
|
||||||
|
_.forEach(schema.properties, function (property, name) {
|
||||||
|
var cProperty = _.cloneDeep(property);
|
||||||
|
|
||||||
|
// Allow macro to set the default value
|
||||||
|
cProperty.default = modelPropertyMacro(property);
|
||||||
|
|
||||||
|
output[name] = schemaToJSON(cProperty, models, modelsToIgnore, modelPropertyMacro);
|
||||||
|
});
|
||||||
|
} else if (type === 'array') {
|
||||||
|
output = [];
|
||||||
|
|
||||||
|
if (_.isArray(schema.items)) {
|
||||||
|
_.forEach(schema.items, function (item) {
|
||||||
|
output.push(schemaToJSON(item, models, modelsToIgnore, modelPropertyMacro));
|
||||||
|
});
|
||||||
|
} else if (_.isPlainObject(schema.items)) {
|
||||||
|
output.push(schemaToJSON(schema.items, models, modelsToIgnore, modelPropertyMacro));
|
||||||
|
} else if (_.isUndefined(schema.items)) {
|
||||||
|
output.push({});
|
||||||
|
} else {
|
||||||
|
console.log('Array type\'s \'items\' property is not an array or an object, cannot process');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return output;
|
||||||
|
};
|
||||||
|
|
||||||
|
var createJSONSample = function (value, modelsToIgnore) {
|
||||||
|
modelsToIgnore = modelsToIgnore || {};
|
||||||
|
|
||||||
|
modelsToIgnore[value.name] = value;
|
||||||
|
|
||||||
|
// Response support
|
||||||
|
if (value.examples && _.isPlainObject(value.examples) && value.examples['application/json']) {
|
||||||
|
value.definition.example = value.examples['application/json'];
|
||||||
|
|
||||||
|
if (_.isString(value.definition.example)) {
|
||||||
|
value.definition.example = jsyaml.safeLoad(value.definition.example);
|
||||||
|
}
|
||||||
|
} else if (!value.definition.example) {
|
||||||
|
value.definition.example = value.examples;
|
||||||
|
}
|
||||||
|
|
||||||
|
return schemaToJSON(value.definition, value.models, modelsToIgnore, value.modelPropertyMacro);
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
getModelSignature: getModelSignature,
|
||||||
|
createJSONSample: createJSONSample
|
||||||
|
};
|
||||||
|
|
||||||
|
})();
|
||||||
Reference in New Issue
Block a user