-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathswagger-parser-loader.js
More file actions
56 lines (50 loc) · 1.7 KB
/
swagger-parser-loader.js
File metadata and controls
56 lines (50 loc) · 1.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
// Este script se asegura de que SwaggerParser esté disponible globalmente
(function () {
// Función para validar sin usar SwaggerParser
function validateOpenAPIBasic(spec) {
return new Promise((resolve, reject) => {
// Validación básica
try {
// Comprobar que es un objeto
if (typeof spec !== 'object' || spec === null) {
return reject(new Error('La especificación debe ser un objeto'));
}
// Comprobar version de OpenAPI
if (!spec.openapi && !spec.swagger) {
return reject(new Error('La especificación debe tener una propiedad "openapi" o "swagger"'));
}
// Comprobar info
if (!spec.info) {
return reject(new Error('La especificación debe tener una propiedad "info"'));
}
// Comprobar paths
if (!spec.paths) {
return reject(new Error('La especificación debe tener una propiedad "paths"'));
}
// Si llegamos aquí, la validación básica ha pasado
resolve(spec);
} catch (err) {
reject(err);
}
});
}
// Crear un objeto SwaggerParser básico si no existe
window.SwaggerParser = {
validate: validateOpenAPIBasic,
parse: function (spec) {
return Promise.resolve(spec);
},
};
// Verificar si la biblioteca SwaggerParser real está disponible
setTimeout(function () {
if (
typeof SwaggerParser !== 'undefined' &&
typeof SwaggerParser.validate === 'function' &&
SwaggerParser.validate !== validateOpenAPIBasic
) {
console.log('SwaggerParser oficial detectado y cargado');
} else {
console.log('Usando SwaggerParser básico de respaldo');
}
}, 500);
})();